原来在内存申请地址也是一个费时的过程
2016-02-25 17:25
253 查看
最近用C#写一个UDP通讯的程序,为了测试设备通讯能力。特定的时间内向设备发大量的数据。
先是以随机数填充了一个设定大小的byte[] 数组;再每次截取其中一段来发送。
结果发现发送数据量始终上不去。
一直查原因无果,最后改变方式:开始申请一个固定大小的数组,后来发送直接发送申请的固定数组,不用截取Copy 内存。
结果当然:
以下是动态生成字节数组的结果:
累计发送时长(毫秒):23559;累计发送数据(字节):1577472
累计发送时长(毫秒):25270;累计发送数据(字节):1597489
累计发送时长(毫秒):15305;累计发送数据(字节):1028000
累计发送时长(毫秒):30626;累计发送数据(字节):2054000
累计发送时长(毫秒):10122;累计发送数据(字节):1931776
以下两条是非动生成数组结果
累计发送时长(毫秒):6389;累计发送数据(字节):2054000
累计发送时长(毫秒):8680;累计发送数据(字节):3081000
以下两条是放弃线程阻塞结果:
累计发送时长(毫秒):4086;累计发送数据(字节):46244000
累计发送时长(毫秒):4549;累计发送数据(字节):52550000
终结:申请内存地址,内存copy 是一个比较耗时的过程。
本文版权:成都至诚恒远物联网技术有限公司
网址:www.heryit.cn
联系电话:028-87657875 13060063607
先是以随机数填充了一个设定大小的byte[] 数组;再每次截取其中一段来发送。
结果发现发送数据量始终上不去。
一直查原因无果,最后改变方式:开始申请一个固定大小的数组,后来发送直接发送申请的固定数组,不用截取Copy 内存。
结果当然:
以下是动态生成字节数组的结果:
累计发送时长(毫秒):23559;累计发送数据(字节):1577472
累计发送时长(毫秒):25270;累计发送数据(字节):1597489
累计发送时长(毫秒):15305;累计发送数据(字节):1028000
累计发送时长(毫秒):30626;累计发送数据(字节):2054000
累计发送时长(毫秒):10122;累计发送数据(字节):1931776
以下两条是非动生成数组结果
累计发送时长(毫秒):6389;累计发送数据(字节):2054000
累计发送时长(毫秒):8680;累计发送数据(字节):3081000
以下两条是放弃线程阻塞结果:
累计发送时长(毫秒):4086;累计发送数据(字节):46244000
累计发送时长(毫秒):4549;累计发送数据(字节):52550000
终结:申请内存地址,内存copy 是一个比较耗时的过程。
本文版权:成都至诚恒远物联网技术有限公司
网址:www.heryit.cn
联系电话:028-87657875 13060063607
相关文章推荐
- leetcode 326 Power of Three(数论)
- Nginx日志过滤 使用ngx_log_if不记录特定日志
- gdb commands命令用法
- 阿里架构之旅(二)——Dubbo解析
- The magic behind configure, make, make install
- Maven项目在eclipse中使用junit进行单元测试时报错:ClassNotFoundException
- php 去掉Url里的 index.php
- Protobuf-net 在Unity3D中使用的小技巧 (解决JIT错误)
- iOS应用内跳转到App Store详情页或者评论页
- 大型网站架构系列:负载均衡详解(4)
- 苹果Xcode帮助文档阅读指南
- 利用location对象控制文档显示的位置
- Matrix
- java设计模式(二)---工厂方法模式
- linux kernel 动态输出模块调试log的方法
- The method add(int, Fragment) in the type FragmentTransaction is not applicable for the arguments (i
- 福利,一张图看懂IT售前工程师修炼之道
- ServletConfig和ServletContext
- AngularJS整合Springmvc、Spring、Mybatis搭建开发环境
- C++ PIMPL模式