前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Python 聊天程序

Python 聊天程序

作者头像
py3study
发布于 2020-01-07 12:21:23
发布于 2020-01-07 12:21:23
1.2K0
举报
文章被收录于专栏:python3python3

一、套接字

套接字是为特定网络协议(例如TCP/IP,ICMP/IP,UDP/IP等)套件对上的网络应用程序提供者提供当前可移植标准的对象。它们允许程序接受并进行连接,如发送和接受数据。为了建立通信通道,网络通信的每个端点拥有一个套接字对象极为重要。

套接字为BSD UNIX系统核心的一部分,而且他们也被许多其他类似UNIX的操作系统包括Linux所采纳。许多非BSD UNIX系统(如ms-dos,windows,os/2,mac os及大部分主机环境)都以库形式提供对套接字的支持。

三种最流行的套接字类型是:stream,datagram和raw 。 stream和datagram套接字可以直接与TCP协议进行接口,而raw套接字则接口到IP协议。但套接字并不限于TCP/IP。

二、套接字模块

套接字模块是一个非常简单的基于对象的接口,它提供对低层BSD套接字样式网络的访问。使用该模块可以实现客户机和服务器套接字。要在python中建立具有TCP和流套接字的简单服务器,需要使用socket模块。利用该模块包含的函数和类定义,可生成通过网络通信的程序。一般来说,建立服务器连接需要六个步骤。

第1步是创建socket对象。调用socket 构造函数。

socket=socket.socket(familly,type)

family的值可以是AF_UNIX(Unix域,用于同一台机器上的进程间通讯),也可以是AF_INET(对于IPV4协议的TCP和UDP),至于type参数,SOCK_STREAM(流套接字)或者 SOCK_DGRAM(数据报文套接字),SOCK_RAW(raw套接字)。

第2步则是将socket绑定(指派)到指定地址上,socket.bind (address)

address必须是一个双元素元组,((host,port)), 主机名或者ip地址+端口号。如果端口号正在被使用或者保留,或者主机名或ip地址错误,则引发socke.error异常。

第3步,绑定后,必须准备好套接字,以便接受连接请求。

socket.listen (backlog)

backlog指定了最多连接数,至少为1,接到连接请求后,这些请求必须排队,如果队列已满,则拒绝请求。

第4步,服务器套接字通过socket的accept 方法等待客户请求一个连接:

connection,address=socket.accept()

调用accept方法时,socket会进入'waiting'(或阻塞)状态。客户请求连接时,方法建立连接并返回服务器。accept方法返回一个含有俩个元素的元组,形如(connection,address)。第一个元素(connection)是新的 socket对象,服务器通过它与客户通信;第二个元素(address)是客户的internet地址。

第5步是处理阶段,服务器和客户通过sendrecv 方法通信(传输数据)。服务器调用send,并采用字符串形式向客户发送信息。send方法返回已发送的字符个数。服务器使用recv方法从客户接受信息。调用recv时,必须指定一个整数来控制本次调用所接受的最大数据量。recv方法在接受数据时会进入'blocket'状态,最后返回一个字符串,用它来表示收到的数据。如果发送的量超过recv所允许,数据会被截断。多余的数据将缓冲于接受端。以后调用recv时,多余的数据会从缓冲区删除。

第6步,传输结束,服务器调用socket的close 方法以关闭连接。

建立一个简单客户连接则需要4个步骤。

第1步,创建一个socket以连接服务器 socket=socket.socket (family,type)

第2步,使用socket的connect方法连接服务器 socket.connect ((host,port))

第3步,客户和服务器通过sendrecv 方法通信。

第4步,结束后,客户通过调用socket的close 方法来关闭连接。

三、一个简单的服务器和客户端通信的例子

服务器:

import socket s=socket.socket() s.bind(('xxx.xxx.xxx.xxx',xxxx))    #ip地址和端口号 s.listen(5) cs,address = s.accept() print 'got connected from',address cs.send('byebye') ra=cs.recv(512) print ra cs.close()

客户端:

import socket s=socket.socket() s.connect(('xxx.xxx.xxx.xxx',xxxx))   #与服务器程序ip地址和端口号相同 data=s.recv(512) s.send('hihi') s.close() print 'the data received is',data

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/09/06 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
python 算法 两数之和 的多种解法
两数之和问题是LeetCode上的一道经典算法题,也是面试中常见的问题。题目要求在一个整数数组中找到两个数,使它们的和等于一个特定的目标值,并返回这两个数的下标。
编程小白狼
2024/12/31
1030
【leetcode刷题】20T11-最接近的三数之和
https://leetcode-cn.com/problems/3sum-closest
木又AI帮
2020/02/16
3560
【LeetCode刷题】:双指针篇(三数之和,四数之和)
题目的意思是给了我们一个数组nums,让我们找出三个下标不相同的数nums[i],nums[j],nums[k],要求这三个数的和恰好等于,然后返回这三个数
爱喝兽奶的熊孩子
2025/01/22
961
【LeetCode刷题】:双指针篇(三数之和,四数之和)
算法:数组
•https://tianchi.aliyun.com/course/932/14631
用户3578099
2022/03/15
2860
算法:数组
日拱算法:双指针解决三数、四数之和
双指针算法通常不难,双指针算法是基于暴力解法的优化,它是很好的学习算法的入门问题。
掘金安东尼
2022/09/19
2140
日拱算法:双指针解决三数、四数之和
LeetCode通关:数组十七连,真是不简单
数组基本上是我们最熟悉的数据结构了,刚会写“Hello World”不久,接着就是“杨辉三角”之类的练习。
三分恶
2021/08/10
3960
打卡群2刷题总结1001——两数之和 II - 输入有序数组
https://leetcode-cn.com/problems/two-sum-ii-input-array-is-sorted/
木又AI帮
2020/10/10
2360
优先算法 —— 双指针系列 - 四数之和
https://blog.csdn.net/hedhjd/article/details/144129358?spm=1001.2014.3001.5502
迷迭所归处
2024/12/24
590
优先算法 —— 双指针系列 - 四数之和
算法-数组-三数之和
给你一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?请你找出所有和为 0 且不重复的三元组。
用户3578099
2022/06/10
6220
[Leetcode][Python/Java]两数之和 Two Sum/两数之和 II - 输入有序数组 Two Sum II
https://leetcode-cn.com/problems/two-sum/solution/
蛮三刀酱
2019/03/26
8750
实战 LeetCode 15.三数之和、18.四数之和,并扩展至 N 数之和
链接:https://leetcode-cn.com/problems/3sum/
与你一起学算法
2021/03/23
1.6K0
小白刷力扣之两数之和
作为一个半路出家的算法小白,最近尝试着刷一下力扣,来扩展些思维,毕竟总是写一些复杂度非常高的代码也不是那么回事。
周萝卜
2020/05/22
7890
[leetcode数组系列]2三数之和
在思考两数之和解决方法的时候,我们使用了两层循环把所有的结果给求出来,相信读者很快就想到三数之和我就用三个循环,很棒,思路是一样,只是之前的a+b=0,现在的b=c+d了。好了代码呈上。
我是程序员小贱
2020/06/05
4880
leetcode 两数之和、三数之和、最接近的三数之和、四数之和
因为 nums[0] + nums[1] = 2 + 7 = 9 所以返回 [0, 1] 最容易想到的方法是用一个双重循环来枚举数组中两两组合的情况,然后判断和是否为 target ,时间复杂度是 O(n^2)。 我们还可以先对数组元素从小到大升序排序,然后在一个循环中利用头尾指针扫描排序后的数组,每次扫描比较两个数的和和 target 的值。因为需要得到元素的排序前下标,所以用一个结构体数组来保存数组元素的值和未排序之前元素所在下标,这样的话采用快速排序,时间复杂度为 O(n*logn),空间复杂度为 O(n)。
指点
2019/01/18
2.7K0
九键输入组合与四数之和——LeetCode 16、17 题记
同样是两道中等难度题目,但题目间没啥关联:第一道类似于我们之前按键手机时代九键输入组合的展示,第二道题将昨天的三数之和改造成了四数之和。现在做题,有时候做着做着提交通过了,就不愿深挖了,挺偷懒的,希望写题记时可以多拓展学习下。
TTTEED
2020/07/08
7420
☆打卡算法☆LeetCode 18、四数之和 算法解析
链接:18. 四数之和 - 力扣(LeetCode) (leetcode-cn.com)
恬静的小魔龙
2022/08/07
1760
☆打卡算法☆LeetCode 18、四数之和  算法解析
leetcode 15. 三数之和
注意:这里要固定一个最左的指针K,可以理解为从[i,j]范围里面选出两个值相加为K指针指向值的相反数 K每次往后移动一次,[i,j]范围都会缩小一个单元 代码:
大忽悠爱学习
2021/11/15
3540
[LeetCode题解]开篇!求和问题总结:2Sum/3Sum/4Sum/KSum
之前在美国做访学,日子比较清闲。当时对数据结构和算法几乎一窍不通,便开始在Leetcode上刷算法题,也算是为找工作做准备,经过了一年多,也积累了很多Leetcode题解文章,并在CSDN上开了题解专栏。
Rude3Knife的公众号
2019/08/06
1.7K0
【优选算法】探索双指针之美(一):双指针与单调性的完美邂逅
在上一章中我们已经认识到了双指针,在这章里我们就来探索一下当双指针和单调性遇见后会擦出怎样的火花呢?
_孙同学
2024/10/21
870
【优选算法】探索双指针之美(一):双指针与单调性的完美邂逅
LeetCode-15 三数之和
今天我们学习第15题三数之和,这是一道中等题。像这样字符串的题目经常作为面试题来考察面试者算法能力和写代码能力,因此最好能手写出该题。下面我们看看这道题的题目描述。
用户3470542
2019/06/26
9000
LeetCode-15 三数之和
推荐阅读
相关推荐
python 算法 两数之和 的多种解法
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档