python缓冲区零复制

通常我们通过网络传送大型字节数据,一般都进行复制、切片、修改等操作,这样操作是非常低效。我们可以通过缓冲区协议对象,实现缓冲区零复制,避免复制、切片等频繁而低效操作。

server.py

import socket

port = 8081
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
s.bind(('', 8081))
while True:
    data, addr = s.recvfrom(1024)
    print "%s bytes from %s" % (len(data), addr)

client1.py

import  socket, time
port = 8081
host = "localhost"
bufsize = 1024

## 没有使用缓冲区对象
data = b'a' * 1024 * 1024 * 10
start = time.time()
while data:
          sent_bytes = s.sendto(data[:bufsize], (host,port))
          data = data[send_bytes]
end = time.time()
print "used_time:  %s"  % (end -start)

client2.py

import  socket, time
port = 8081
host = "localhost"
bufsize = 1024

# memoryview缓冲区协议对象,实现零复制
# memoryview直接引用原内存地址来操作
data =memoryview( b'a' * 1024 * 1024 * 10)
start = time.time()
while data:
          sent_bytes = s.sendto(data[:bufsize], (host,port))
          data = data[send_bytes]
end = time.time()
print "used_time:  %s"  % (end -start)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,174评论 19 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,506评论 25 709
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,510评论 11 349
  • 机缘巧合,或者更像是幡然悔悟,遇到某家长的朋友圈里文章,继而又看到书童姗姗制作的学员文章,于是触动了心灵机关,啪嗒...
    歌麦子阅读 1,432评论 0 0
  • 一些你平日不相信的,在梦里也不相信的事情,那就是深入骨髓的不相信。每种不相信都有各自的前提,我想把八年来我从未改变...
    宋初心阅读 2,144评论 0 0

友情链接更多精彩内容