




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
importresultimportresultre.sub('\d+''1''a12345bbbb67c890d0e'print(result)#resultre.sub('\d+?''1''a12345bbbb67c890d0e'print(result)#1编写一个简单的人机(测试ABxxC用户输入“123”(完成简单的加法运算defpattern1defpattern1result=re.match(pattern1,inputStr)ifresult:returnpattern2result=re.match(pattern2,inputStr)ifresult:strresult.group(1)returnstrpattern3'(\d+)加(\d+)result=re.match(pattern3,inputStr)ifresult:value1=int(result.group(1))value2=value3value3value1value2str='等于%d'%value3returnstrreturnwhileinputStrinput('请输入:')result=robot(inputStr)(C语言程序、Java语言程序、python语言程序多进程。2比如:总共有2个进程,每个进程各启动2个线程(线程 、线程、线程、线程)。快但是在写程序的时候需要注意:1个Python程序原则上是一个进程,在这个进启动了1个电脑上启动了多个QQQQ一个进程启动后,至少会有一个线程运行中。这个线程称为主线程。在一些app应用程序UIUI操作都需要实时的响应,O(2n)O(n!)O(n2)O(nlogn)O(n)O(logn)pythonimportname=threading.current_thread().getName()importname=threading.current_thread().getName()说明目前是在主线运行defdefnamethreading.current_thread().getName()print('run,name)t.start()classclassdefname=threading.current_thread().getName()print('MyThreadrunname)importimportdefname=foriinrange(100):print(name,':',i)foriint=threading.Thread(target=run)numnum0defglobalforiinrange(num+=1defdefglobalforiinrange(num+=1t1=threading.Thread(target=t2=threading.Thread(target=num+=1num=临时变量(tmp)。这个不是一个原子操作。有可能在中间被打乱。1num+11tmp12num+11,保存到临时变量tmp2中。1num=tmpnum=112都执行了+1执子线程子线程子线程子线程获取获取子线程子线程子线程获取
获取
从出生到sleepsleep调度run创 启 运importthreadingimporttimeclassMyThread(threading.Thread):defrun(self):namethreading.current_thread().getName()print('睡眠前运行中的线程:',name)print('睡眠后运行中的线程:'t1=MyThread()t2=MyThread()t3=MyThread()importthreadingimporttimeimportthreadingimporttimenum0defglobalnum, while flagTrueflag=foriinrange( num+=1flag=defglobalnum, while flagTrueflag=foriinrange( num+=1flag=t1=threading.Thread(target=run1)t2=threading.Thread(target=run2)Python中用到的锁,称为互斥锁(mutex)mutexmutex=mutex.acquire([blocking],加锁mutex.acquire([blocking],blocking描述上锁的时候是否阻塞。True为阻塞(默认值),False为不阻塞。timeout表示超时时间。blockingTrue的时候,timeoutimportimportnum0mutexthreading.Lock()defglobalmutex.acquire()blockingforiinrange( num+=1mutex.release()#defglobalmutex.acquire()blockingforiinrange( num+=1mutex.release()#t1=threading.Thread(target=run1)t2=threading.Thread(target=run2)importimportnum0mutexthreading.Lock()defglobalforiinrange(num+=1blocking#defglobalforiin mutex.acquire()blockingnum+=1mutex.release()#t1=threading.Thread(target=run1)t2=threading.Thread(target=400300importthreadingimportthreadingimporttimenum500defpos(money,name):globalnum#尝试扣款ifnum>=money:print('%snum-=moneyprint('消费%dmoney)print('余额为%d't1=threading.Thread(target=pos,args=(400,'pos1'))t2=threading.Thread(target=pos,args=(300,'pos2'))importimportthreadingimporttimelist1=[3,list2=[7,mutex1threading.Lock()mutex2threading.Locklist1[0]defgloballist1,value1=list1[0]time.sleep(0.1)#故意延时value2=list2[0]result=value1+value2defgloballist1,list2mutex2.acquire()list2value2=list2[1]time.sleep(0.1)#故意延时mutex1.acquire()list1value1=list1[1]result=value1+value2mutex1.release()list1mutex2.release()list2t1=threading.Thread(target=fun1)t2=threading.Thread(target=fun2)importimportthreadingimporttimelist1=[3,4]list2=[7,mutex1threading.Lock()mutex2threading.Lock()list1[0]defgloballist1,ifmutex1.acquire(timeout=1list1value1=list1[0]time.sleep(0.1)value2=list2[0]result=value1+value2defgloballist1,if
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- T/ZHHX 002-2024三角梅盆花生产技术规程与质量等级
- 2025西华大学辅导员考试试题及答案
- 2025辽东学院辅导员考试试题及答案
- 2025皖西学院辅导员考试试题及答案
- 电商运营方案设计
- 商业门面租赁合同标准版
- 卫生常识课:构建健康生活之美
- 手卫生督查实施要点
- 社区卫生服务社区管理讲座
- 小儿惊厥急救手册
- 导截流验收报告汇编
- 大班科学《神奇的中草药》课件
- 信用修复申请书
- 全过程造价控制流程全图
- 温州7.23动车事故调查报告介绍课件
- RAL 劳尔色卡电子版
- 造价咨询质量控制保证措施及服务质量
- 跳棋教学(课堂PPT)
- 火车过桥问题四年级(课堂PPT)
- MSA偏倚分析报告样本
- 中国颅脑创伤颅内压监测专家共识
评论
0/150
提交评论