gpt4 book ai didi

c# - 为什么 StreamReader 返回字符串而不是字节数组

转载 作者:太空宇宙 更新时间:2023-11-03 21:03:24 26 4
gpt4 key购买 nike

两个相关问题:

  1. 为什么他们选择从 StreamReader.ReadToEnd() 返回 string 而不是 byte[]
  2. 我知道我可以使用 System.Text.Encoding 转换它,但我究竟应该使用哪种编码? UTF8、UTF7、ASCII 还是 Unicode?我正在处理二进制文件。

注意:我被要求澄清。只是 stream 这个词给人的印象是字节级的……好吧……stream 数据(想想网络流、文件流、缓冲区,都不是它们应该是一个 char 类型的概念)。正如 Joel 在他的回答中正确指出的那样,这更像是一个命名问题。

最佳答案

“为什么”问题很少成为 Stack Overflow 的好素材,因为唯一能够真正回答这些问题的是产品设计委员会中的那些人。

但是,在这种情况下,我们至少可以通过将您指向 StreamReader documentation 来给您一个很好的指示。 ,你会在哪里找到这个:

Implements a TextReader that reads characters from a byte stream in a particular encoding.

因此我们看到,处理文本而不是字节是 StreamReader 的全部内容。也许你会问为什么它被命名为“StreamReader”而不是“TextStreamReader”,但我不得不让你回到我的第一句话。

至于得到一个字节数组……这取决于你想做什么。 .Net 对其字符串使用 Unicode,但底层流可能有所不同,无论您打算如何处理这些数据,都可能需要完全不同的编码。

不过,在这种情况下,您有二进制文件,并且需要 Byte[]。与其搞乱流,不如看看 File.ReadAllBytes() .如果您必须处理流,您可能还需要 BinaryReader .

关于c# - 为什么 StreamReader 返回字符串而不是字节数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43083926/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com