python类的构造方法
1. python中类的构造方法中需要定义和初始化变量吗
要不要定义取决于有没有在其他地方用到这些变量,要写成def _int_(self,name,ID,score1,score2,score3,sum)的情况是你想要在定义类的时候同时初始化这些变量就这么写,如果想让这些变量用默认值初始化就可以不用这么写
2. Python多进程系列之Pipe类
多进程还有一种数据传递方式叫做管道,和Queue相类似。Pipe可以在进程之间创建一条管道,并返回元组(con1,con2)。其中,con1,con2表示管道两端的连接对象。这里要注意,必须在产生Process对象之前产生管道。
1.基本介绍1.1 构造方法Pipe([plex]):默认管道是全双工的。若将plex的值设置为False,则con1只能用于接收,con2只能用于发送。
1.2 实例方法send(obj):通过连接发送对象obj
recv():接收con2.send(obj)所发送的对象。如果没有消息可接收,recv方法会一直阻塞。如果接收的一端已经关闭连接,则抛出EOFError
close():关闭连接。如果con1被垃圾回收,将自动调用此方法。
fileno():返回连接使用的整数文件描述符
poll([timeout]):如果连接上的数据可用,返回True。timeout为指定等待的最长时限,若timeout缺省,方法立即返回结果,不再等待。若timeout值为None,则操作将无限制等待数据到来。
send_bytes(buffer[,offset[,size]]):通过连接发送字节数据缓冲区,buffer是支持缓冲区接口的任意对象,offset是缓冲区中的字节偏移量,size是要发生的字节数。结果以单条消息的形式发出,然后使用recv_bytes()进行接收。
recv_bytes([maxlength]):接收send_bytes()方法发送的一条完整的字节消息。maxlength指定了要接收的最大字节数。如果进来的消息超过了该值,引发IOError异常,并且在连接上无法进一步读取。如果接收的一端已经关闭连接,不存在数据,则引发EOFError
recv_bytes_into(buffer[,offset]):接收一条完整的字节消息,并把它保存在buffer对象中,该对象支持可写入的缓冲区接口。offset指定缓冲区中放置消息处的字节位移。返回值是接收到的字节数。如果消息长度大于可用的缓冲区空间,将引发BufferTooShort异常。
2.使用实例frommultiprocessingimportPipe,Processimporttimedeff(subconn):time.sleep(1)subconn.send("吃了吗")print("一方接收到的消息",subconn.recv())subconn.colse()if__name__=='__main__':parent_con,child_con=Pipe()p=Process(target=f,args=(child_con,))p.start()print("另一方接收到的消息",parent_con.recv())parent_con.send("发送的消息")result:
另一方接收到的消息吃了吗一方接收到的消息发送的消息