zoukankan      html  css  js  c++  java
  • 粘包2

    客户端

     1 from socket import *
     2 
     3 tcp_server = socket(AF_INET, SOCK_STREAM)
     4 tcp_server.bind(('127.0.0.1', 8080))
     5 tcp_server.listen(124)
     6 coon, addr = tcp_server.accept()
     7 data1 = coon.recv(1024)
     8 print('第一次收', data1.decode())
     9 
    10 data2 = coon.recv(1024)
    11 print('第二次收', data2.decode())
    12 
    13 data3 = coon.recv(1024)
    14 print('第三次收', data3.decode())

    服务端

    1 from socket import *
    2 
    3 tcp_client = socket(AF_INET,SOCK_STREAM)
    4 tcp_client.connect(('127.0.0.1',8080))
    5 tcp_client.send('hello'.encode())
    6 tcp_client.send('world'.encode())
    7 tcp_client.send('中国'.encode())   # 套接字没有规定一发一收
    8 # 套接字都是往缓冲区中发

    运行可知,tcp协议:当发送接收数据时,如果发送的数据包很小,操作系统会将多个小的数据包合并发送。接收方就一次接受所有的数据包。

    这个原理就是Nagle算法。

    下面是发送的数据量小的一种情况:

    用了时间模块后,发现这个是由系统决定的。

    第二种情况,发送的数据量大的情况:服务端:

    1 from socket import *
    2 
    3 udp_server = socket(AF_INET, SOCK_DGRAM)
    4 udp_server.bind(('127.0.0.1', 8080))
    5 data = udp_server.recvfrom(1024)  # 哪怕是发送了很多个包在缓冲区,但是一次接受只能接受一个包
    6 print('收到的数据包为:', data)

    客户端:

    1 from socket import *
    2 
    3 udp_client = socket(AF_INET, SOCK_DGRAM)
    4 udp_client.sendto(b'hello', ('127.0.0.1', 8080))
    5 udp_client.sendto(b'world', ('127.0.0.1', 8080))
    6 udp_client.sendto(b'egon', ('127.0.0.1', 8080))

    原因:udp是基于数据报的工作方式工作的    一个包就是一个包,操作系统不会把多个包进行合并

    udp   一发一收

  • 相关阅读:
    一二类斯特林数小结
    我的博客搬家了!
    常用编程思想与算法
    【spring专题】spring简介
    九、 Java程序初始化的顺序(二)
    八、 Java程序初始化的顺序(一)
    python的上下文管理
    七、 面向对象(二)
    六、 面向对象基础
    paramiko模块及ssh远程登陆
  • 原文地址:https://www.cnblogs.com/ch2020/p/12528378.html
Copyright © 2011-2022 走看看