#python解决并发问题(用多线程)(JAVA基于对象的多线程)
#1.使一段代码具有多线程的能力 ---(开启多线程)
#2.Runnable --run() --start()
#python更直接,更简单,功能弱
#Python有两种实现多线程的方式(一种走底层,一种走对象)
#python每个线程都有他自己的一组cpu寄存器(直接占用了cpu)
#python线程分为两种:1.内核线程--直接由操作系统的内核来创建和销毁
# 2.用户线程--程序员写的不需要内核直接操作的线程
# _thread
# _threading模块
#run()主线程里执行
#start()开启多线程
import _thread
import time
def demo(name):
i=0
while i<4:
time.sleep(1) #在这里让他睡1秒
i+=1
print(name,'上了:',i,'个小时的网')
#demo()
_thread.start_new_thread(demo,('wangxiaokun',))
_thread.start_new_thread(demo,('lihuayu',))
while 1:
pass #1为真, pass让程序一直执行
2.线程礼让
import threading
import time
class Ceshi(threading.Thread):
name = ''
def __init__(self,name):
threading.Thread.__init__(self)
self.name=name
def run(self):
i = 0
while i < 4:
time.sleep(1) # 在这里让他睡1秒
i += 1
print(self.name, '上了:', i, '个小时的网')
dx1=Ceshi("wangxiaokun")
dx2=Ceshi("wanghaha")
#代码具有并发能力 但是并不调用他
dx1.run()
dx2.run()
#调用处理
dx1.start()
dx2.start()
#1.线程礼让 join
dx1.join()
dx2.join()
3.线程同步
#线程调度问题
#1.线程礼让 join
#2.线程同步(多线程中的有些文件,代码不能被同时操作)
#加入数据库有十万条数据,你要查的时候select需要三分钟,但是在这
#三分钟内不能保证有人会对数据库进行修改 ,修改的时候只修改10条数据,
#肯定用不了三分钟,也就是说,正在查的时候有人已经对某条数据进行了修改,
#开始查 --->开始改---->改完了--->查完了(这时候查出来的结果,有些已经被修改掉了,会出现脏数据)
import threading
import time
class Ceshi(threading.Thread):
name = ''
def __init__(self,name):
threading.Thread.__init__(self)
self.name=name
def run(self):
#上锁
suo.acquire()
shangwang(self.name)
#释放锁
suo.release()
#现在要让代码不能并发执行,一个人先执行,即使另一个人请求到了,也让他现在外面等着
def shangwang(name):
i = 0
while i < 4:
time.sleep(1) # 在这里让他睡1秒
i += 1
print(name, '上了:', i, '个小时的网')
suo=threading.Lock()
dx1=Ceshi("wangxiaokun")
dx2=Ceshi("wanghaha")
#调用处理
dx1.start()
dx2.start()
#1.线程礼让 join
dx1.join()
dx2.join()