import threading import time #继承形式的多线程,适合于程序比较复杂的情况 class MyThread(threading.Thread): #t.start()会调用run函数,所以必须有个run方法 #线程类内的其他方法除非run函数内部调用他们,否则不会被调用 def run(self): for i in range(3): time.sleep(1) msg="I'm "+self.name+' @ '+str(i) #name属性保存当前线程的…
1 #coding=utf-8 2 #网络编程 3 4 #客户端建立socket套接字 5 #引入socket模块 6 import socket 7 #实例化一个套接字,2个参数分别是: IPV4.TCP 协议 8 s=socket.socket(socket.AF_INET, socket.SOCK_STREAM) 9 #建立连接,2个参数是: 网址.端口 10 s.connect(('www.baidu.com',80)) 11 #向服务器发送请求,传递的参数是:1.请求方式 2.地址 3…
Python多线程支持全局变量的共享操作,但是它存在很多问题,先来看以下程序,该程序理论上执行完毕后全局变量g_num的值应该是2000000,但是在实际运行中,结果不足理论值 import threading import time #定义一个全局变量 g_num=0 def test1(num): global g_num for i in range(num): g_num+=1 print("----in test1 g_num=%d----"%g_num) def test2…
变量作用域: 一般在函数体外定义的变量成为全局变量,在函数内部定义的变量称为局部变量.全局变量所有作用域都可用,局部变量只能在本函数可用,变量的使用顺序是,局部变量 > 全局变量, 也就是说:优先使用局部变量,那么问题来了, 如果想在函数内使用全局变量,或改变全局变量的值, 应该怎么做呢? global关键字: 为了解决函数内使用全局变量的问题,python增加了global关键字, 利用它的特性,可以指定变量的作用域.global关键字的作用:声明变量var是全局的 注意: 参考链接:…
死锁:指两个或两个以上的线程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程. 此程序的两个线程会因为互相等待对方的互斥锁而陷入等待,最后由于主线程执行完毕而结束了各个子线程,从而程序结束. import threading import time class MyThread1(threading.Thread): def run(self): #对mutexA上锁…
#该程序使用命令行执行,IDE执行会有其他线程附加 import threading import time #初始化一个线程 #t=threading.Thread(target=func) #func为函数名 #创建启动线程 #t.start() #获取当前进程的所有线程 #threading.enumerate() #当前线程个数 #len(threading.enumerate()) def test1(): for i in range(5): print('-----test1---…
#单线程程序 import time def sing(): """唱歌5秒钟""" for i in range(5): print("-----正在唱:千里之外-----") time.sleep(1) def dance(): """跳舞5秒钟""" for i in range(5): print("-----正在跳舞-----") tim…
在学习socket之前,我们先复习下相关的网络知识. OSI七层模型:应用层,表示层,会话层,传输层,网络层,数据链路层,物理层.OSI七层模型是由国际标准化组织ISO定义的网络的基本结构,不仅包括一些概念和结构,还包括一系列的协议. TCP/IP四层模型:既然有OSI七层模型,为什么我们还要定义一个TCP/IP的四层模型呢,那是因为OSI七层模型对应面过于宽泛,很多概念实现不了,也没必要实现,因此,实际生产中广泛应用的是TCP/IP四层结构,他们的对应关系如下表: TCP/IP OSI 应用层…
Python 网络编程 上一篇博客介绍了socket的基本概念以及实现了简单的TCP和UDP的客户端.服务器程序,本篇博客主要对socket编程进行更深入的讲解 一.简化版ssh实现 这是一个极其简单的仿ssh的socket程序,实现的功能为客户端发送命令,服务端接收到客户端的命令,然后在服务器上通过subrocess模块执行命令,如果命令执行有误,输出内容为空,则返回"command error"的语句给客户端,否则将命令执行的结果返回给客户端 服务端 1 2 3 4 5 6 7 8…
一.基于TCP协议的socket套接字编程 1.套接字工作流程 先从服务器端说起.服务器端先初始化Socket,然后与端口绑定(bind),对端口进行监听(listen),调用accept阻塞,等待客户端连接.在这时如果有个客户端初始化一个Socket,然后连接服务器(connect),如果连接成功,这时客户端与服务器端的连接就建立了.客户端发送数据请求,服务器端接收请求并处理请求,然后把回应数据发送给客户端,客户端读取数据,最后关闭连接,一次交互结束,使用以下Python代码实现: impor…