python29day
内容回顾
网络编程
- 概念
- B/S C/S架构
- B/S browser server
- C/S client 装客户端使用的 server远程服务器的
- osi七层协议
今日内容
tcp协议的编程
如何在连接内多和客户端说几句
能够接收多个客户端的请求
import socket sk=socket.socket()
sk.bind(('127.0.0.1',9000))
sk.listen() #就可以等人来连接了 while True:
conn,addr=sk.accept() #能和多个客户端握手了
print('conn:',conn)
while True:
send_msg=input('>>>')
conn.send(send_msg.encode('utf-8'))
if send_msg.upper()=='Q':
break
msg=conn.recv(1024).decode('utf-8')
if msg.upper() == 'Q':
break
print(msg)
conn.close() #挥手 断开连接 sk.close()
import socket sk=socket.socket()
sk.connect(('127.0.0.1',9000)) while True:
msg=sk.recv(1024)
msg2=msg.decode('utf-8')
if msg2.upper()=='Q':
break
print(msg,msg2)
send_msg=input('>>>')
sk.send(send_msg.encode('utf-8'))
if send_msg.upper()=='Q':
break sk.close()
udp协议的编程
import socket sk=socket.socket(type=socket.SOCK_DGRAM) #创建套接字
sk.bind(('127.0.0.1',9000)) #绑定端口
while True:
msg,addr=sk.recvfrom(1024) #被动等待
print(msg.decode('utf-8'))
msg=input('>>>')
sk.sendto(msg.encode('utf-8'),addr)
import socket sk=socket.socket(type=socket.SOCK_DGRAM) #创建套接字
server=(('127.0.0.1',9000)) while True:
msg = input('>>>')
if msg.upper()=='Q':
break
sk.sendto(msg.encode('utf-8'),server)
msg=sk.recv(1024).decode('utf-8')
if msg.upper()=='Q':
break
print(msg)
粘包现象
- 两条连续发送的数据黏在一起了
- 只出现在tcp协议中
- 因为tcp协议 多条消息之间没有边界,并且还有一大堆优化算法
- 发送端:两条消息都很短,发送的间隔时间也非常短
- 接收端:多条消息由于没有及时接收,而在接收方的缓存短 堆在一起导致的粘包现象
- 网络最大带宽限制 MTU=1500字节
- tcp发多大都行 因为会在中途拆分
struct模块
选课系统讲解I
代码总行数2856+174=3030行
python29day的更多相关文章
随机推荐
- 【LeetCode】405. Convert a Number to Hexadecimal 解题报告(Java & Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 Java解法 Python解法 日期 题目地址:ht ...
- 【九度OJ】题目1023:EXCEL排序 解题报告
[九度OJ]题目1023:EXCEL排序 解题报告 标签(空格分隔): 九度OJ [LeetCode] http://ac.jobdu.com/problem.php?pid=1023 题目描述: E ...
- 【九度OJ】题目1072:有多少不同的面值组合? 解题报告
[九度OJ]题目1072:有多少不同的面值组合? 解题报告 标签(空格分隔): 九度OJ http://ac.jobdu.com/problem.php?pid=1072 题目描述: 某人有8角的邮票 ...
- 【LeetCode】673. Number of Longest Increasing Subsequence 解题报告(Python)
[LeetCode]673. Number of Longest Increasing Subsequence 解题报告(Python) 标签(空格分隔): LeetCode 题目地址:https:/ ...
- codeforce 597C-Subsequences(dp+树状数组)
题目和南阳那道题一样链接http://www.cnblogs.com/zzuli2sjy/p/4943774.html 代码: 1 #include<stdio.h> 2 #include ...
- Codeforces 567B:Berland National Library(模拟)
time limit per test : 1 second memory limit per test : 256 megabytes input : standard input output : ...
- RotateRect(旋转矩形)的倾斜旋转变换矫正
在Opencv中的图像处理中,经常要用到minAreaRect()函数求最小外接矩形,该函数的返回值就是一个RotatedRect类对象. RotatedRect类定义如下: class CV_EXP ...
- EDP转LVDS屏转接板方案|基于INTELX86主板和商显应用EDP转LVDS设计CS5211
众所周知LVDS接口是美国NS美国国家半导体公司为克服以TTL电平方式传输宽带高码率数据时功耗大,电磁干扰大等缺点而研制的一种数字视频信号传输方式.由于其采用低压和低电流驱动方式,实现了低噪声和低功耗 ...
- x86-1-32位x86 处理器编程架构
x86(32位)-1-32位x86 处理器编程架构 Intel 32 位处理器架构简称IA-32(Intel Architecture,32-bit) x86是指intel的86系列的CPU统称,比如 ...
- 深入 Laravel 内核之 PHP 反射机制和依赖注入
结论: PHP中提供了反射类来解析类的结构: 通过反射类可以获取到类的构造函数及其参数和依赖: 给构造函数的参数递归设置默认值后,即可使用这些带默认值的参数通过 newInstanceArgs 实例化 ...