Python学习日志002-多进程、多线程、协程-02

Python学习日志002-多进程、多线程、协程-02

#!/Users/11834/.conda/envs/Pytorch_GPU/python.exe
# -*- coding: UTF-8 -*-
'''=================================================
@Project -> File    :Residue_processing -> python-003.py
@IDE    :PyCharm
@Author :Xue-Qiang Fan
@Date   :2020/3/22 11:22
@Describe   :多进程,多线程,协程
=================================================='''
#进程通信
from multiprocessing import Queue
from multiprocessing import Process
from time import sleep
q = Queue(5)
q.put('A')
q.put('B')
q.put('C')
q.put('D')
q.put('E')
print(q.qsize())
if not q.full():
    q.put('F',timeout=3)  #put满了,则只能等待,除非有’空地‘
else:
    print('队列满了')
print(q.get())

def download(q):
    images = ['girl.jpg', 'boy.jpg', 'man.jpg']
    for image in images:
        print('正在下载', image)
        sleep(0.5)
        q.put(image)
    pass
def getfile(q):
    while True:
        file = q.get()
        print('{}保存成功!'.format(file))



if __name__ == '__main__':
    q = Queue(5)
    p1 = Process(target=download, args=(q,))
    p2 = Process(target=getfile,args=(q,))

    p1.start()
    p1.join()
    p2.start()
    p2.join()
'''
线程:线程是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。
一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。
在Unix也被称为轻量进程(lightweight processes),但轻量进程更多指内核线程(kernel thread),

'''
import threading

def download(n):
    images = ['girl.jpg', 'boy.jpg', 'man.jpg']
    for image in images:
        print('正在下载', image)
        sleep(n)

    pass
def getfile(q):
    while True:
        file = q.get()
        print('{}保存成功!'.format(file))
if __name__ == '__main__':
   t = threading.Thread(target=download, args=(1,))
   t1 = threading.Thread(target=download, args=(2,))
   t.start()
   t1.start()
'''
线程同步:一个一个完成
'''
import threading
import random
import time

lock = threading.Lock()

list1 = [0]*10
def task1():
    #获取线程锁如果已经上锁,则等待锁释放
    lock.acquire()  #阻塞
    for i in range(len(list1)):
        list1[i] = 1
        time.sleep(0.5)
    lock.release()
def task2():
    lock.acquire()  #阻塞
    for i in range(len(list1)):
        print('----', list1[i])
        time.sleep(0.5)
    lock.release()
if __name__ == '__main__':
    t1 = threading.Thread(target=task1)
    t2 = threading.Thread(target=task2)
    t2.start()
    t1.start()

#协程:微线程   生成器完成
#什么时候用:耗时用









  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值