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)
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,992評論 19 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 173,558評論 25 708
  • 從三月份找實習到現在,面了一些公司,掛了不少,但最終還是拿到小米、百度、阿里、京東、新浪、CVTE、樂視家的研發崗...
    時芥藍閱讀 42,374評論 11 349
  • 機緣巧合,或者更像是幡然悔悟,遇到某家長的朋友圈里文章,繼而又看到書童姍姍制作的學員文章,于是觸動了心靈機關,啪嗒...
    歌麥子閱讀 186評論 0 0
  • 一些你平日不相信的,在夢里也不相信的事情,那就是深入骨髓的不相信。每種不相信都有各自的前提,我想把八年來我從未改變...
    宋初心閱讀 289評論 0 0