Semaphore:Semaphores are often used to restrict the number of threads than can access some (physical or logical) resource. import java.util.LinkedList; import java.util.List; import java.util.Random; import java.util.concurrent.Semaphore; class Buffe
(1)锁:进程之间数据不共享,但是共享同一套文件系统,所以访问同一个文件,或同一个打印终端,是没有问题的,而共享带来的是竞争,竞争带来的结果就是错乱,如何控制,就是加锁处理. 虽然使用加锁的形式实现了顺序的执行,但是程序又重新变成串行了,这样确实会浪费了时间,却保证了数据的安全. (Lock) import json from multiprocessing import Process,Lock ###### 锁 ###### import time import random def get
守护进程: 注意事项: 1.必须在p.start()前 2.守护进程不能开子进程 3.如果主进程的运行时间快于子进程,那么就只有主进程的结果,没有守护进程的结果,因为守护进程没有进行完.反之会得到两个结果. from multiprocessing import Process import os,time def task(): print("%s is runing"%os.getpid()) time.sleep() print("%s is done"%os