面向对象中多继承所用算法以及简单的网络编程
一.小知识
# 完全可以实现 users = [ {"name":"亚索","price":6300}, {"naem":"盖伦","price":3150}, {"name":"赵信","price":3150}, ] for item in users: temp = "英雄: %s,价格: %s" % (item["name"],item["price"]) print(temp)
# 代码拆分,是业务逻辑代码更加简洁 class Person: def __init__(self,name,price): self.name = name self.price = price def message(self): return "英雄: %s,年龄: %s" % (self.name,self.price) users = [Person("亚索",6300),Person("盖伦",3150),Person("赵信",3150)] for obj in users: print(obj.message())
二.面向对象多继承
1. 规则:先找左再找右

class A(object): pass class B(object): def f1(self): print('B') class C(A,B): pass obj = C() obj.f1()
2.经典类和新式类

python2:
经典类
新式类
python3:
新式类
经典类和新式类的查找成员的顺序不一样
经典类:一条道走到黑(深度优先).
新式类:C3算法(Python2.3更新时,加入了C3算法)

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__) #查看继承关系的特殊方法,内置C3
C3算法:获取第一个表头和其他表位进行比较
不存在则拿走
如果存在,则放弃,然后获取第二个表的表头再次和其他表的表尾进行比较
三.网络编程
1.软件:
客户端:CS架构. client -> server
浏览器:BS架构. browser -> server
2.如何实现相互通信
(1).需求一:编写两个软件,软件之间互相通信
(2).需求二:两个人直接连接(网线)
(3).需求三:测试地点相互通信(交换机)
查看IP:win+r -> ipconfig
(4).和不在局域网内的人通信(交换机+n*路由器)

import socket # 创建服务端socket对象 server = socket.socket() # 绑定IP和端口 server.bind(('192.168.13.168',8000)) # 后边可以等5个人 server.listen(5) print('服务端准备开始接收客户端的连接') # 等待客户端来连接,如果没人来就傻傻的等待。 # conn是客户端和服务端连接的对象(连接中介是伞),服务端以后要通过该对象进行收发数据。 # # addr是客户端的地址信息。 # #### 阻塞,只有有客户端进行连接,则获取客户端连接然后开始进行通信。 conn,addr = server.accept() print('已经有人连接上了,客户端信息:',conn,addr) # 通过对象去获取(客户端通过伞给我发送的消息) # 1024表示:服务端通过(伞)获取数据时,一次性最多拿1024字节。 data = conn.recv(1024) print('已经有人发来消息了',data) # 服务端通过连接对象(伞)给客户端回复了一个消息。 conn.send(b'stop') # 与客户端断开连接(放开那把伞) conn.close() # 关闭服务端的服务 server.close()

import socket client = socket.socket() # 客户端向服务端发起连接请求(递伞) # 阻塞,去连接,直到连接成功后才会继续向下走。 client.connect(('192.168.13.168',8000)) # # 链接上服务端后,向服务端发送消息 client.send(b'hello') # 客户端等待服务端给他发送消息 data = client.recv(1024) print(data) # 关闭自己 client.close()
3.总结:
(1).相互通信本质是发送 001001010110
(2).交换机作用
(3).通过ipconfig查看自己的内网IP
(4).公网IP,掏钱
4.基于socket模块实现网络通信
(1).为什么要网络通信发送的是字节?而不是字符串?
python3: send/recv 都是字节
python2: send/recv 都是字符串
python2是由ASCII码编写的,而python3是由Unicode编写的,如果传送字符串的话,万国码占32字节太大了

import socket server = socket.socket() server.bind(('192.168.13.168',8001)) server.listen(5) while True: conn,addr = server.accept() # 字节类型 while True: data = conn.recv(1024) # 阻塞 if data == b'exit': break response = data + b' SB' conn.send(response) conn.close()

import socket sk = socket.socket() sk.connect(('192.168.13.168',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()