一、面向对象多继承(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:

  新式类

  经典类和新式类的查找成员的顺序不一样:

  经典类:一条道走到黑(深度优先);

  新式类:c3算法实现(python2.3更新时有介绍c3算法);

  Foo + (C,D,F,G) + (G,D,G,W) + (I,G,D,G,W)

  Foo, I,B,……

  获取第一个表头 和 其他表尾进行比较:

  不存在则拿走。

  如果存在,则放弃,然后获取第二个表的表头再次和其他表的表尾进行比较。

总结:

  经典类:一条道走到黑(深度优先);

  新式类:简单理解就是留个根,(科学原理是c3算法);

注意事项:super是遵循__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 #导入模块                  socket(骚k特)

server = socket.socket() # 创建服务端socket 对象
ip_port = ('192.168.15.57',8001) #创建ip和端口
server.bind(ip_port)#绑定ip和端口            bind(班的)
server.listen()#开机                   listen(雷森) 
print('服务端准备开始接收客户端的连接') # 等待客户端来连接,如果没人来就傻傻的等待。
# conn 是客户端和服务端连接的对象(伞),服务端以后要通过该对象进行收发数据。
# addr 是客户端的地址信息。
# #### 阻塞,只有有客户端进行连接,则获取客户端连接然后开始进行通信。
print('等待中')
conn,addr = server.accept()#阻塞中          accept(A可赛科特)
print('已经有人连接上了,客户端信息:',conn,addr) # 通过对象去获取(客户端通过伞给我发送的消息)
# 1024表示:服务端通过对象(伞)获取数据时,一次性最多拿1024字节。
client_smg = conn.recv(1024)
client_smg = client_smg.decode('utf-8')#解码  decode(抵扣的)解码
print(client_smg)#看一下客户端发给我什么内容 conn.send('你猜'.encode('utf-8'))#给客户端回复一个消息 encode(银扣的)编码 conn.close()# 与客户端断开连接(放开那把伞) close(可楼子)
server.close()# 关闭服务器的服务

客户端简单示例:

import socket

client= socket.socket()#创建客户端socket对象

#客户端向服务器发起连接请求(递伞)
#阻塞,去连接,直到连接成功后才会继续向下走
server_ip_port = ('192.168.15.57',8001)
client.connect(server_ip_port)#        链接服务端connect(肯奶可特) #连接上服务端后,向服务端发送信息
client.send('约吗'.encode('utf-8')) #客户端等待服务器给他发送消息
from_msg = client.recv(1024)      recv(蕊c无)
from_msg_0 = from_msg.decode('utf-8')#解码
print(from_msg_0)#消息发送来了 client.close()

  

总结:

  服务端:

accept,阻塞:等待客户端来连接。

recv,   阻塞:等待客户端发来数据。

  客户端:

connect,阻塞:一直在连接,直到连接成功才往下运行其他代码。

recv,    阻塞:等待服务端发来数据。

问题一:为什么要网络通信发送的是字节?而不是字符串?

python3,send/recv 都是字节

python2,send/recv 都是字符串

b、上述示例运行一次,服务端和客户端只能连接一次,发送和接收一次消息后服务端关闭,无法再连接其他客户端,现要实现服务端一旦启动,服务端和客户端之间可以持续发送和接收消息,且与某个客户端断开后还可以继续等待其他客户端来连接,如下示例:

加一个while循环

  

socket模块实现网络通信UDP

服务端

import socket
#创建一个udp协议下的socket,需要使用参数type
udp_server = socket.socket(type=socket.SOCK_DGRAM) #DGRAM : datagram 数据报
#拿到一个地址,启动程序的时候,告诉电脑,你给我这个程序分配8001端口.
ip_port = ('192.168.15.113',8001)
#绑定IP地址和端口
udp_server.bind(ip_port) print('准备接收消息了...')
#接收消息,from_client_msg来自客户端的消息,client_addr客户端的地址('192.168.15.113', 8001)
from_client_msg,client_addr = udp_server.recvfrom(1024) #阻塞住了
#发送消息
udp_server.sendto(b'gunduzi',client_addr)
#关闭udp的socket对象
udp_server.close()

 客户端

import socket
udp_client = socket.socket(type=socket.SOCK_DGRAM)
server_ip_port = ('192.168.15.113',8001) udp_client.sendto(b'hello',server_ip_port)      sendto(森头) from_server_msg,server_addr = udp_client.recvfrom(1024)  recvfrom(蕊c无服ruang木)
print(from_server_msg)
print(server_addr)   udp_client.close()

  

面向对象多继承(c3算法)、网络基础和编写网络相关的程序的更多相关文章

  1. 面向对象多继承(C3算法)/网络编程

    https://www.cnblogs.com/aylin/p/5572104.html 一.面向对象多继承(c3算法) a.有多个父类先找左,再找右,如下示例: class A(object): p ...

  2. python 面向对象(六)MRO C3算法 super

    ########################总结################ 面向对象回顾 类:对某一个事物的描述,对一些属性和方法的归类 class 类名: var=123#类变量 def ...

  3. python中多继承C3算法研究

    在python的面向对象继承问题中,单继承简单易懂,全部接受传承类的属性,并可添加自带属性, 但是,在多继承情况下,会遇到多个被继承者的顺序问题,以及多次继承后查找前几次继承者需求属性时,可能不易发现 ...

  4. python学习 day20 (3月27日)----(单继承多继承c3算法)

    继承: 提高代码的重用性,减少了代码的冗余 这两个写法是一样的 Wa('青蛙').walk() #青蛙 can walk wa = Wa('青蛙') wa.walk() #青蛙 can walk 1. ...

  5. 多继承c3算法

    一.mro mro即 method resolution order (方法解释顺序),主要用于在多继承时判断属性的路径(来自于哪个类). print(类.mro)得到属性路径按继承顺序 在pytho ...

  6. Python多继承C3算法

    Python3 多继承的MRO算法选择.MRO(Method Resolution Order):方法解析顺序. Python3 只保留了C3算法! C3算法解析: 1.C3算法解析 C3算法:MRO ...

  7. python新式类继承------C3算法

    一.引入 mro即method resolution order,主要用于在多继承时判断调的属性的路径(来自于哪个类).之前查看了很多资料,说mro是基于深度优先搜索算法的.但不完全正确在Python ...

  8. python----多继承C3算法

    https://blog.csdn.net/fmblzf/article/details/52512145

  9. 迈向高阶:优秀Android程序员必知必会的网络基础

    1.前言 网络通信一直是Android项目里比较重要的一个模块,Android开源项目上出现过很多优秀的网络框架,从一开始只是一些对HttpClient和HttpUrlConnection简易封装使用 ...

随机推荐

  1. LSTM长短期记忆神经网络模型简介

    LSTM网络也是一种时间递归神经网络,解决RNN的长期依赖关系. RNN模型在训练时会遇到梯度消失或者爆炸的问题,训练时计算和反向传播,梯度倾向于在每一时刻递增或递减,梯度发散到无穷大或者0..... ...

  2. 2018.11.06 洛谷P1099 树网的核(最短路+枚举)

    传送门 之前看李煜东的书一直感觉是道神题. 然后发现这题数据范围只有300?300?300? 直接上floydfloydfloyd然后暴力就完了啊. 代码: #include<bits/stdc ...

  3. 2018.11.02 NOIP模拟 距离(斜率优化dp)

    传送门 分四个方向分别讨论. 每次枚举当前行iii,然后对于第二维jjj用斜率优化dpdpdp. f[i][j]=(j−k)2+mindisk2f[i][j]=(j-k)^2+mindis_k^2f[ ...

  4. 证明 U and V={0}时 dim(U+V)=dim(U)+dim(V)

    U And V={0} 证明 dim(U+V)=dim(U)+dim(V)设{u1,u2,...,uk} 是U的基,{v1,v2...,vr}是V的基,dim(U)=k ,dim(V)=r dim(U ...

  5. Vue.js 教程

    http://www.runoob.com/vue2/vue-routing.html

  6. java常用设计模式六:适配器模式

    一.定义 适配器模式把一个类的接口变换成客户端所期待的另一种接口,从而使原本因接口不匹配而无法在一起工作的两个类能够在一起工作.比如以下的场景: 用手机充电为例,有一个手机的插孔是TypeC口,现在只 ...

  7. activemq部署

    系统环境 IP salt-master-1:192.168.0.156 salt-master-2:192.168.0.157 node-test-1:192.168.0.158 node-test- ...

  8. eclipse中tomcat启动设置参数

      今天新接触一个项目,使用java+flex做的单机项目,由于模块太多,打成war后就有300M左右了.所以,启动的时候,比较慢,超过了e eclipse中默认的45s,当我进行修改启动事件后,有一 ...

  9. 后台开发 - DPDK引发的图谱

    关系图谱(点击看完整大图): 部分名词: 名词 全写 解释 备注 DPDK Data Plane Development Kit 数据平面开发套件或叫数据平面开发工具集 Intel开源的快速数据包处理 ...

  10. 《深入浅出MFC》系列之运行时类型识别(RTTI)

    /********************************************************************************** 发布日期:2017-11-13  ...