面向对象多继承(C3算法)/网络编程
https://www.cnblogs.com/aylin/p/5572104.html
一、面向对象多继承(c3算法)
a、有多个父类先找左,再找右,如下示例:
class A(object):
pass class B(object):
def f1(self):
print('B') class C(A,B):
pass obj = C()
obj.f1()
print(C.__mro__) # 打印出C类的继承顺序,结果如下一行:
# (<class '__main__.C'>, <class '__main__.A'>, <class '__main__.B'>, <class 'object'>) 先找左,再找右
先找左再找右
b、经典类和新式类
python2(其实是python2.2以后):
经典类
新式类:如果自己或自己的前辈只要有人继承object,那么此类就是新式类。
python3:
没有经典类
新式类 :如果自己或自己的前辈只要有人继承object,那么此类就是新式类。
经典类和新式类的查找成员的顺序不一样:
经典类:一条道走到黑(深度优先);
新式类:c3算法实现(python2.3更新时有介绍c3算法);
Foo + (C,D,F,G) + (G,D,G,W) + (I,G,D,G,W)
Foo, I,B,……
获取第一个表头 和 其他表尾进行比较:
不存在则拿走。
如果存在,则放弃,然后获取第二个表的表头再次和其他表的表尾进行比较。
# 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__)
C3算法
总结:
经典类:一条道走到黑(深度优先);
新式类:简单理解就是留个根,(科学原理是c3算法);
注意事项:super是遵循__mro__的执行顺序的。
python3中如何获取指定类成员的查询顺序 -----__mro__
二、网络基础
a、开发模式:
(开发一个软件)需要安装客户端:CS架构,client -- > server
(开发一个网站)使用浏览器访问:BS架构,browser -- > server
b、如何实现相互通信:
方式一:编写两个软件,软件之间相互通信;
方式二:两个人直接连接(通过网线);
方式三:同一个教室中的多台电脑相互通信(通过交换机);
使用IP地址:ipconfig/ifconfig查看
方式四:和三亚的女友通信(通过交换机 + n*路由器);
三亚女友需要 租公网IP
总结:
1)相互通信的本质是发送01010101(高低电频);
2)交换机的作用(组成一个局域网,并在局域网内发广播);
3)通过ipconfig(windows系统)/ifconfig(苹果系统和linux系统)查看自己的内网IP;
4)花钱 租公网IP;
三、编写网络相关的程序
a、基于socket模块实现网络通信,如下代码示例:
服务端简单示例:
import socket
server = socket.socket() # 创建服务端socket对象
server.bind(('192.168.13.130',8000)) # 绑定IP和端口
server.listen(5) # 后边可以等5个人
print('服务端准备开始接收客户端的连接')
# 等待客户端来连接,如果没人来就傻傻的等待。
# conn 是客户端和服务端连接的对象(伞),服务端以后要通过该对象进行收发数据。
# addr 是客户端的地址信息。
# #### 阻塞,只有有客户端进行连接,则获取客户端连接然后开始进行通信。
conn,addr = server.accept()
print('已经有人连接上了,客户端信息:',conn,addr)
# 通过对象去获取(客户端通过伞给我发送的消息)
# 1024表示:服务端通过对象(伞)获取数据时,一次性最多拿1024字节。
data = conn.recv(1024)
print('已经有人发来信息了',data)
# 服务端通过连接对象(伞)给客户端回复了一个消息。
conn.send(b'stop') # send不能发空 ''
conn.close() # 与客户端断开连接(放开那把伞)
server.close() # 关闭服务端的服务
客户端简单示例:
import socket
client = socket.socket() # 创建客户端socket对象
# 客户端向服务端发起连接请求(递伞)
# 阻塞,去连接,直到连接成功后才会继续向下走
client.connect(('192.168.13.130',8000))
# 连接上服务端后,向服务端发送消息
client.send(b'hello')
# 客户端等待服务端给他发送消息
data = client.recv(1024)
print('服务端发来消息了',data)
# 关闭自己
client.close()
总结:
服务端:
accept,阻塞:等待客户端来连接。
recv, 阻塞:等待客户端发来数据。
客户端:
connect,阻塞:一直在连接,直到连接成功才往下运行其他代码。
recv, 阻塞:等待服务端发来数据。
问题一:为什么要网络通信发送的是字节?而不是字符串?
python3,send/recv 都是字节
python2,send/recv 都是字符串
b、上述示例运行一次,服务端和客户端只能连接一次,发送和接收一次消息后服务端关闭,无法再连接其他客户端,现要实现服务端一旦启动,服务端和客户端之间可以持续发送和接收消息,且与某个客户端断开后还可以继续等待其他客户端来连接,如下示例:
服务端程序:
import socket
server = socket.socket() # 创建服务端socket对象
server.bind(('192.168.13.130',8000)) # 绑定IP和端口
server.listen(5) # 后边可以等5个人
print('服务端准备开始接收客户端的连接') while True:
conn,addr = server.accept()
print('已经有人连接上了,客户端信息:',conn,addr)
while True:
data = conn.recv(1024)
print('已经有人发来信息了',data)
if data == b'exit':
break
conn.send(b'stop')
print('断开与客户端连接')
conn.close() # 与客户端断开连接
客户端程序:
import socket
client = socket.socket() # 创建客户端socket对象
client.connect(('192.168.13.130', 8000)) while True:
name = input('请输入姓名:')
client.send(name.encode('utf-8'))
if name == 'exit':
break
data = client.recv(1024)
print('服务端发来消息了',data)
client.close()
面向对象多继承(C3算法)/网络编程的更多相关文章
- 面向对象多继承(c3算法)、网络基础和编写网络相关的程序
一.面向对象多继承(c3算法) a.有多个父类先找左,再找右,如下示例: class A(object): pass class B(object): def f1(self): print('B') ...
- python 面向对象(六)MRO C3算法 super
########################总结################ 面向对象回顾 类:对某一个事物的描述,对一些属性和方法的归类 class 类名: var=123#类变量 def ...
- python中多继承C3算法研究
在python的面向对象继承问题中,单继承简单易懂,全部接受传承类的属性,并可添加自带属性, 但是,在多继承情况下,会遇到多个被继承者的顺序问题,以及多次继承后查找前几次继承者需求属性时,可能不易发现 ...
- python学习 day20 (3月27日)----(单继承多继承c3算法)
继承: 提高代码的重用性,减少了代码的冗余 这两个写法是一样的 Wa('青蛙').walk() #青蛙 can walk wa = Wa('青蛙') wa.walk() #青蛙 can walk 1. ...
- 多继承c3算法
一.mro mro即 method resolution order (方法解释顺序),主要用于在多继承时判断属性的路径(来自于哪个类). print(类.mro)得到属性路径按继承顺序 在pytho ...
- Python多继承C3算法
Python3 多继承的MRO算法选择.MRO(Method Resolution Order):方法解析顺序. Python3 只保留了C3算法! C3算法解析: 1.C3算法解析 C3算法:MRO ...
- python新式类继承------C3算法
一.引入 mro即method resolution order,主要用于在多继承时判断调的属性的路径(来自于哪个类).之前查看了很多资料,说mro是基于深度优先搜索算法的.但不完全正确在Python ...
- python面向对象、类、socket网络编程
类和对象 python3统一了类与类型的概念:类==类型:从一组对象中提取相似的部分就是类:特征与技能的结合体就叫做对象: 类的功能: 初始实例化: 属性引用: 1.数据属性: 2.函数属性: 对于一 ...
- python----多继承C3算法
https://blog.csdn.net/fmblzf/article/details/52512145
随机推荐
- 【bzoj2286】[Sdoi2011]消耗战
虚树入门题: #include<cstdio> #include<cstring> #include<algorithm> #include<ctime> ...
- android DHCP流程【转】
本文转载自:http://blog.csdn.net/myvest/article/details/51483647 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] 1 ...
- hibernate入门(-)
1.struts2的支持 在web.xml中配置struts2的支持 <?xml version="1.0" encoding="UTF-8"?> ...
- 图片预览JavaScript方法
实现要点 ● 对于 Chrome.Firefox.IE10 使用 FileReader 来实现. ● 对于 IE6~9 使用滤镜 filter:progid:DXImageTransform.Mi ...
- DFS序+线段树(bzoj 4034)
题目链接 题目就不多说了. 本题目,可以用dfs序+线段树做:题目给定了一棵树,树上节点告诉了权值.我们可以先将这棵树进行dfs将一棵树变成线性结构:如图 变成这样后,然后就可以用线段树. 操作1:也 ...
- 51Nod - 1821:最优集合 (求第一个不能被表示为多个数的和的数)(不错的动脑题)
一个集合S的优美值定义为:最大的x,满足对于任意i∈1,x1,x,都存在一个S的子集S',使得S'中元素之和为i. 给定n个集合,对于每一次询问,指定一个集合S1和一个集合S2,以及一个数k,要求选择 ...
- 多线程之:lock和synchronized的区别
多次思考过这个问题,都没有形成理论,今天有时间了,我把他总结出来,希望对大家有所帮助 1.ReentrantLock 拥有Synchronized相同的并发性和内存语义,此外还多了 锁投票,定时锁等候 ...
- linux下printf函数为什么不加\n就不能输出相关的内容 ?
转载请注明出处:http://blog.csdn.net/qq_26093511/article/details/53255970 原因: 输出缓冲区的问题. unix上标准输入输出都是带有缓存的, ...
- 4月超棒的JavaScript游戏开发框架推荐(1) – 51CTO.COM
基于JavaScript开发的游戏是唯一一个能够跨桌面,Web和移动三种平台的.… 查阅全文 ›
- Hadoop中Yarnrunner里面submit Job以及AM生成 至Job处理过程源码解析
参考 http://blog.csdn.net/caodaoxi/article/details/12970993 Hadoop中Yarnrunner里面submit Job以及AM生成 至Job处理 ...