一、基于UDP协议的套接字

TCP是建立可靠连接,并且通信双方都可以以流的形式发送数据。相对TCP,UDP则是面向无连接的协议。

使用UDP协议时,不需要建立连接,只需要知道对方的IP地址和端口号,就可以直接发数据包。但是,能不能到达就不知道了。

虽然用UDP传输数据不可靠,但它的优点是和TCP比,速度快,对于不要求可靠到达的数据,就可以使用UDP协议。

我们来看看如何通过UDP协议传输数据。和TCP类似,使用UDP的通信双方也分为客户端和服务器。服务器首先需要绑定端口:

1. TCP与UDP的比较:

TCP(流式协议):可靠性高。会因为网络原因丢包,但只有在一端收到另一端发来的ack确认信息才会将信息在内存中删除,如果发现丢包(一段时间内没有回复)会将信息再发一份。TCP会存在粘包问题,收与发可以不是对应的。必须先启动服务端,否则报错。

UDP(数据包协议):可靠性低。信息一旦发出即在内存中删除,如果发生丢包,信息即丢失。UDP效率高速度快的主要原因,一是因为不建连接,二是因为接受后不会确认。 UDP没有粘包问题,收与发一一对应。 如果发hello,但收一个字符,在windows系统中会报错;在linunx系统中不报错,只接收h。

s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)

# 绑定端口:

s.bind(('127.0.0.1', 9999))

创建Socket时,SOCK_DGRAM指定了这个Socket的类型是UDP。绑定端口和TCP一样,但是不需要调用listen()方法,而是直接接收来自任何客户端的数据:

print('Bind UDP on 9999...')

while True:

# 接收数据:

data, addr = s.recvfrom(1024)

print('Received from %s:%s.' % addr)

s.sendto(b'Hello, %s!' % data, addr)

recvfrom()方法返回数据和客户端的地址与端口,这样,服务器收到数据后,直接调用sendto()就可以把数据用UDP发给客户端。

注意这里省掉了多线程,因为这个例子很简单。

客户端使用UDP时,首先仍然创建基于UDP的Socket,然后,不需要调用connect(),直接通过sendto()给服务器发数据:

s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)

for data in [b'Michael', b'Tracy', b'Sarah']:

# 发送数据:

s.sendto(data, ('127.0.0.1', 9999))

# 接收数据:

print(s.recv(1024).decode('utf-8'))

s.close()

从服务器接收数据仍然调用recv()方法。

仍然用两个命令行分别启动服务器和客户端测试,结果如下:

小结:

UDP的使用与TCP类似,但是不需要建立连接。此外,服务器绑定UDP端口和TCP端口互不冲突,也就是说,UDP的9999端口与TCP的9999端口可以各自绑定。

2. socketserver实现并发

基于tcp的套接字,关键就是两个循环,一个链接循环,一个通信循环

socketserver模块中分两大类:server类(解决链接问题)和request类(解决通信问题)

server类:

request类:

继承关系:

二、python并发编程之多进程

1、什么是程序?什么是进程?

程序说白了就是一堆文件

进程就是一个正在执行的过程/程序,所以说进程是一个抽象的概念。这个概念起源操作系统

2、什么是操作系统

定义:操作系统是位于计算机硬件与应用软件之间,用于协调、管理、控制计算机硬件与软件的资源的一种控制程序

3、操作系统的两大作用:

1、把复杂丑陋的硬件操作都封装成美丽的接口,提供给应用程序使用

2、把进程对硬件的竞争变的有序

4、多道技术(单个CPU在多个程序中切换以实现并发)

多道的产生背景是想要在单个cpu的情况下实现多个进程并发执行的效果

a、空间上的复用 (多道程序复用内存的空间)

b、时间上的复用  (多道程序复用CPU时间)

cpu遇到IO操作要切换(提升效率)

一个进程占用cpu时间过长也切(降低效率)

进程与进程之间的内存空间是互相隔离的。

转载于:https://www.cnblogs.com/zhaijihai/p/9584896.html

网络编程(基于udp协议的套接字/socketserver模块/进程简介)相关推荐

  1. 基于UDP协议的套接字+socketserver模块

    基于UDP协议的套接字 user datagram protocal 数据报协议 无双向通道.自带报头.类似发短信.不会粘包 不可靠:数据发送时,丢就丢了 UDP socket: 服务端: impor ...

  2. udp协议没有粘包问题、基于socketserver实现并发的socket(基于tcp、udp协议)、基于udp协议的套接字、操作系统原理以及进程知识

    基于udp协议的套接字通信服务端 from socket import *server=socket(AF_INET,SOCK_DGRAM) #数据报协议->udp server.bind((' ...

  3. Java网络编程——基于UDP协议的聊天室

    UDP简述    UDP(User Datagram Protocol)协议是Internet 协议集支持的一个无连接的传输协议,中文名为用户数据报协议.它为应用程序提供了一种无需建立连接就可以发送封 ...

  4. step5 . day5 网络编程 基于UDP协议的多人网络在线聊天功能

    模拟在线群聊功能,使用多进程完成聊天内容的接受和服务器端的转发,demo代码记录参考 //client_chat_UDP code #include <stdio.h> #include ...

  5. step5 . day4 网络编程 基于UDP协议的网络编程流程及API

    UDP协议是面向无连接,不可靠的传输协议,编程流程如下; 服务器端: 1. socket(),返回一个文件描述符,用于通信 2. bind(); //得先完成结构体的填充sockaddr_in 3. ...

  6. 网络编程: 基于UDP协议的socket

    udp是无链接的,启动服务之后可以直接接受消息,不需要提前建立链接 UDP协议的通信优势: 允许一个服务器同时和多个客户端通信, TCP不行 服务端 import socketsk = socket. ...

  7. day26-2 基于TCP协议的套接字编程

    目录 基于TCP协议的套接字编程 套接字 套接字工作流程 基于TCP协议的套接字编程(简单) 服务端 客户端 基于TCP协议的套接字编程(循环) 服务端 客户端1 客户端2 基于TCP协议的套接字编程 ...

  8. 网络编程——基于TCP协议的通讯录【课程设计】

    网络编程--基于TCP协议的通讯录[课程设计] 本文目录 网络编程--基于TCP协议的通讯录[课程设计] 一.设计题目和要求 设计目标: 课程设计系统组成及模块功能: 二.设计内容 服务端 客户端 S ...

  9. tcp/ip网络编程--accept()函数返回的套接字

    tcp/ip网络编程–accept()函数返回的套接字 套接字:1)套接字是对网络中不同主机的应用进程之间进行双向通信的端点的抽象:一个套接字就是网络进程通信的一端.[1] 2)套接字是用来与另一个进 ...

  10. python网络编程--创建简单的UPD套接字实现两个进程间互相通信

    Socket 什么是socket Socket通常又称"套接字",应用程序通常会通过"套接字"实现向网络发出请求或者相应网络请求,从而实现不同计算机之间或同一计 ...

最新文章

  1. JS 正则表达式 0.001 ~99.999
  2. R语言message函数、warning()函数和stop()函数输出程序运行健康状态信息实战
  3. 4篇SCI,获得多次国奖,这个硕士小姐姐分享科研之路
  4. 伍冬睿教授:脑机接口中迁移学习的完整流程
  5. O/R Mapping 研究报告(转)
  6. layoutSubviews何时被调用
  7. 【软考-软件设计师】编译程序基本原理
  8. 老板怒了,“我们赚钱你们花钱,还总出毛病!”
  9. 嵌入式中常见的存储器总结(一)存储器分类
  10. VUE自学日志04-Data Property 和方法
  11. agx 安装ros opencv_Linux下配置深度学习开发环境(及ros)
  12. kali linux下sqlmap使用教程
  13. 基于VS2019+QT的Coin3D三维可视化库的安装预测测试
  14. 三级数据库技术思维导图
  15. 从三方面分析,Java程序员如何晋升为高薪Java架构师?
  16. Nero Burning ROM 11.0.10500附序列号
  17. 二叉树期权定价python代码_期权的二叉树定价模型
  18. pdf在线免费去水印 以及图片去水印 方法
  19. 前苏格拉底时期的古希腊哲学流派
  20. C/S 和 B/S 模式的区别与联系

热门文章

  1. webpack 优化react项目没有解决的问题
  2. SpringCloud之 Feign的简单使用
  3. [AlwaysOn Availability Groups]排查:AG配置
  4. 浏览器内核选型列表,请大家继续补充
  5. 考虑云计算来降成本:良药或毒药?
  6. Gson 与 fastJson 在使用上的差异(fastJson的优点)
  7. linux面试题(填空部分)
  8. java用户注册模块_用户注册登录模块设计方案报告.docx
  9. cfda计算机管理化系统,计算机化系统清单
  10. 微型计算机系统视频适配器为,计算机硬件基础1-微型计算机系统组成(含教材6,8,9章内容).ppt...