it编程 > 编程语言 > Asp.net

C# MemoryStream中ToArray和GetBuffer的区别小小结

45人参与 2025-07-31 Asp.net

前言

memorystream 中的 getbuffer()toarray() 是两个用于获取流数据的方法,但它们的核心区别在于 数据范围、内存占用和安全性

一、核心区别

特性getbuffer()toarray()
返回内容返回 底层缓冲区的完整数组
(包含未使用的空间)。
返回 仅包含有效数据的数组
(排除未使用的空间)。
内存占用可能包含大量未使用的空字节(0 填充),
占用更多内存。
仅包含实际写入的数据,
内存更高效。
性能速度快(直接返回引用,无需复制)。速度较慢(需复制数据到新数组)。
安全性可能暴露未初始化的字节(0 填充),
可能导致数据污染或解析错误。
仅返回有效数据,
避免未初始化字节的干扰。

二、具体示例

1.getbuffer()的示例

public class program
{
    public static void main(string[] args)
    {
        using (memorystream ms = new memorystream())
        {
            byte[] data = encoding.utf8.getbytes("test");
            ms.write(data, 0, data.length);

            byte[] buffer = ms.getbuffer(); // 返回长度为 256 的数组(默认初始容量为 256)
            console.writeline(buffer.length); // 输出:256
            console.writeline(ms.length);     // 输出:4(实际数据长度)
            console.writeline(bitconverter.tostring(buffer));
            // 输出:74-65-73-74-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
        }
    }
}

2.toarray()的示例

public class program
{
    public static void main(string[] args)
    {
        using (memorystream ms = new memorystream())
        {
            byte[] data = encoding.utf8.getbytes("test");
            ms.write(data, 0, data.length);

            byte[] bytes = ms.toarray(); // 返回长度为 4 的数组
            console.writeline(bytes.length); // 输出:4
            console.writeline(ms.length);     // 输出:4(实际数据长度)
            console.writeline(bitconverter.tostring(bytes));//输出:74-65-73-74
        }
    }
}

三、关键场景对比

场景推荐方法原因
需要高效访问底层缓冲区(如直接操作内存)getbuffer()避免复制开销,但需确保仅使用有效数据范围。
需要精确数据(如网络传输、文件保存)toarray()确保数据不含未使用的 0,避免解析错误(如 excel 文件损坏问题)。
流的容量远大于实际数据toarray()避免浪费内存(如示例中 256 字节 vs 4 字节)。
需要避免未初始化字节的干扰toarray()仅返回有效数据,安全性更高。

四、注意事项

1. 异常情况

2. 容量与长度

3. 性能权衡

五、使用建议

到此这篇关于c# memorystream 中 toarray 和 getbuffer 的区别的文章就介绍到这了,更多相关c# toarray getbuffer内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

您想发表意见!!点此发布评论

推荐阅读

C# 可空值类型的具体使用

07-31

C# MemoryStream的具体使用

07-31

C# checked和unchecked的使用小结

07-31

C# WinForm实现Socket异步通讯的步骤详解

07-30

C# System.Text.Encoding使用小结

07-30

C# SerialPort类中清空缓存区的两种方法

07-30

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论