当您再次将代码读回字符串时,您的代码不会将UTF-8存入内存,因此它不再存在于UTF-8中,而是返回到UTF-16中(尽管理想情况下,最好考虑使用比字符串更高的级别)任何编码,除非被迫这样做)。
要获取实际的UTF-8八位字节,可以使用:
var serializer = new XmlSerializer(typeof(SomeSerializableObject));var memoryStream = new MemoryStream();var streamWriter = new StreamWriter(memoryStream, System.Text.Encoding.UTF8);serializer.Serialize(streamWriter, entry);byte[] utf8EnpredXml = memoryStream.ToArray();
我已经没有了你留下的同样的东西。我稍微赞成以下内容(保留常规处理):
var serializer = new XmlSerializer(typeof(SomeSerializableObject));using(var memStm = new MemoryStream())using(var xw = XmlWriter.Create(memStm)){ serializer.Serialize(xw, entry); var utf8 = memStm.ToArray();}复杂度几乎相同,但确实表明在每个阶段都有合理的选择来做其他事情,其中最紧迫的是将序列化到内存以外的其他地方,例如文件,TCP /
IP流,数据库等。总而言之,它并不是那么冗长。



