day 27 网路编程 面向对象多继承
知识补充:
字符串转化为字节
string1 = input(“请输入你的名字”)
string1.encode('utf-8')
字节转化为字符串
byte1 = b"alex"
byte1.decode("utf-8")
一、面向对象多继承
1、先从左再找右
1 class A(object): 2 pass 3 4 5 class B(object): 6 def f1(self): 7 print('B') 8 9 10 class C(A,B): #c类中没有的话去A里面找,A里面再没有的话去B里面找 11 pass 12 13 obj = C() 14 15 obj.f1()
2、经典类和新式类
py2: 经典类 新式类,如果自己或自己的前辈只要有人继承object,那么此类就是新式类。 py3: 新式类 经典类和新式类的查找成员的顺序不一样。 经典类,一条道走到黑(深度优先)。 新式类,C3算法实现(python2.3更新时c3算法)。 Foo + (C,D,F,G) + (G,D,G,W) + (I,G,D,G,W) Foo, I,B, 获取第一个表头 和 其他表位进行比较 不存在则拿走。 如果存在,则放弃,然后获取第二个表的表头再次和其他表的表尾进行比较。 简单: 经典类,一条道走到黑(深度优先)。 新式类,留个根。(科学C3算法)
注意事项:
super是遵循__mro__执行顺序。
(类名.__mro__) 查看类名的继承关系
# by luffycity.com class A(object): pass class B(A): pass class C(B): pass class D(object): pass class E(D,C): pass class F(object): pass class G(F): pass class H(C,G): pass class Foo(E,H): pass # print(E.__mro__) # print(H.__mro__) """ L(Foo + L(E) + L(H) ) L(E) = E,D,C,B,A,object L(H) = H,C,B,A,G,F,object Foo = (object) + (G,F,object) Foo,E,D,H,C,B,A,G,F,object """ print(Foo.__mro__)
二、网络编程
1、软件
客户端:CS架构, client --> server
浏览器:BS架构, browser --> server
2、如何实现相互通信
方式思路
1 需要一: 编写两个软件,软件之间相互通信 2 3 需要二:两个人直接连接(网线) 4 5 需要三:监视相互通信(交换机) 6 7 需求四:交换机+n*路由器 8 总结: 9 1. 相互通信本质发送 0101010101 10 2. 交换机作用 11 3. 通过ipconfig查看自己的内网IP 12 4. 公网IP,掏钱。
3、基于socket模块实现网络通信
import socket # 创建服务端socket对象 server = socket.socket() # 绑定IP和端口 server.bind(('192.168.13.155',8000)) # 后边可以等5个人 server.listen(5) print('服务端准备开始接收客户端的连接') # 等待客户端来连接,如果没人来就傻傻的等待。 # conn是客户端和服务端连接的对象(伞),服务端以后要通过该对象进行收发数据。 # addr是客户端的地址信息。 ## 阻塞,只有有客户端进行连接,则获取客户端连接然后开始进行通信。 conn,addr = server.accept() #接收客户端的数据 print('已经有人连接上了,客户端信息:',conn,addr) # 通过对象去获取(王晓东通过伞给我发送的消息) data = conn.recv(1024) #1024表示:服务端通过(伞)获取数据时,一次性最多拿1024字节 print('已经有人发来消息了',data) # 服务端通过连接对象(伞)给客户端回复了一个消息。 conn.send(b'stop') # 与客户端断开连接(放开那把伞) conn.close() # 关闭服务端的服务 server.close()
import socket client = socket.socket() # 王晓东向服务端发起连接请求(递伞) # 阻塞,去连接,直到连接成功后才会继续向下走。 client.connect(('192.168.13.155',8000)) # # 链接上服务端后,向服务端发送消息 client.send(b'hello') # 王晓东等待服务端给他发送消息 data = client.recv(1024) print(data) # 关闭自己 client.close()
c. 基于socket模块实现网络通信 为什么要网络通信发送的是字节?而不是字符串? py3, send/recv 都是字节 py2, send/recv 都是字符串 服务端: accept,阻塞:等待客户端来连接。 recv, 阻塞:等待客户端发来数据。 客户端: connect,阻塞:一直在连接,直到连接成功才往下运行其他代码。 recv, 阻塞:等待服务端发来数据。
课上所讲实例:
服务段
import socket server = socket.socket() server.bind(('192.168.13.155',8001)) server.listen(5) while True: conn,addr = server.accept() # 字节类型 while True: data = conn.recv(1024) # 阻塞 if data == b'exit': # 客户输入exit 程序 释放内存地址,让下一个等待进来的客户进入 break response = data + b' SB' conn.send(response) conn.close()
客户端
import socket sk = socket.socket() sk.connect(('192.168.13.155',8001)) while True: name = input("请输入姓名:") sk.send(name.encode('utf-8')) # 字节 if name == 'exit': break response = sk.recv(1024) # 字节 print(response.decode('utf-8')) sk.close()