python緩沖區(qū)零復(fù)制

通常我們通過網(wǎng)絡(luò)傳送大型字節(jié)數(shù)據(jù),一般都進行復(fù)制、切片、修改等操作,這樣操作是非常低效。我們可以通過緩沖區(qū)協(xié)議對象,實現(xiàn)緩沖區(qū)零復(fù)制,避免復(fù)制、切片等頻繁而低效操作。

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

## 沒有使用緩沖區(qū)對象
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緩沖區(qū)協(xié)議對象,實現(xiàn)零復(fù)制
# memoryview直接引用原內(nèi)存地址來操作
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)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

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

友情鏈接更多精彩內(nèi)容