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

通常我們通過網(wǎng)絡(luò)傳送大型字節(jié)數(shù)據(jù),一般都進(jìn)行復(fù)制、切片、修改等操作,這樣操作是非常低效。我們可以通過緩沖區(qū)協(xié)議對(duì)象,實(shí)現(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ū)對(duì)象
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é)議對(duì)象,實(shí)現(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)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

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

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