为什么我的 C# 文本编写器文件的末尾会出现空格?



我使用TextWriter C#创建了一个文本文件,在最终创建时,文本文件通常在文件末尾有各种空格行。空格不包含在构成文件的任何字符串对象中,我不知道是什么原因造成的。文件越大,空格越多。

我已经尝试了各种测试,以查看是否根据字符串上的内容出现空格,但事实并非如此。 即我已经确定了空格开始的行数,并将字符串更改为完全不同的内容,但空格仍然存在。

//To start:
MemoryStream memoryStream = new MemoryStream();
TextWriter tw = new StreamWriter(memoryStream);
//Loop through records & create a concatenated string object
string strUTL1 = string.Format("{0}{1}{2}{3}{4}{5}{6}{7}", strUTL1_1, strUTL1_2, strUTL1_3, strUTL1_4, strUTL1_5, strUTL1_6, strUTL1_7, strUTL1_8);
//Add the line to the text file
tw.WriteLine(strUTL1);
//Once all rows are added I complete the file
tw.Flush();
tw.Close();

//Then return the file
return File(memoryStream.GetBuffer(), "text/plain", txtFileName);

我不想在完成后操作文件(例如替换空格(,因为这可能会导致其他问题。该文件将与第三方交换,需要精确格式化。

感谢您的协助。

正如MemoryStream.GetBuffer的文档所解释的那样:

请注意,缓冲区包含可能未使用的已分配字节。例如,如果将字符串"test"写入 MemoryStream 对象,则从 GetBuffer 返回的缓冲区长度为 256,而不是 4,其中 252 字节未使用。若要仅获取缓冲区中的数据,请使用 ToArray 方法;但是,ToArray 会在内存中创建数据的副本。

使用.ToArray()(这将分配一个大小合适的新数组(,或者您可以使用从.GetBuffer()返回的缓冲区,但您需要检查.Length以查看其中有多少有效字节。

GetBuffer(( 返回所有分配的内存,这几乎总是比你实际写入其中的字节数多。

我可以建议改用Encoding.UTF8.GetBytes(...)

string strUTL1 = string.Format("{0}{1}{2}{3}{4}{5}{6}{7}", strUTL1_1, strUTL1_2, strUTL1_3, strUTL1_4, strUTL1_5, strUTL1_6, strUTL1_7, strUTL1_8);
var bytes = Encoding.UTF8.GetBytes(strUTL1);
return File(bytes, "text/plain", txtFileName);

使用ToArray()而不是GetBuffer(),因为缓冲区大于需要。

这种情况经常发生。使用缓冲区的类或函数通常保留一定大小的内存来保存数据。然后,该函数将返回一个值,即已写入缓冲区的字节数。然后,应仅使用缓冲区的前n个字节。

引用 MSDN:

例如,如果将字符串"test"写入 MemoryStream 对象,则从 GetBuffer(( 返回的缓冲区长度为 256,而不是 4,其中 252 字节未使用。要仅获取缓冲区中的数据,请使用 ToArray(( 方法;但是,ToArray(( 会在内存中创建数据的副本。

相关内容

  • 没有找到相关文章

最新更新