多线程
来源菜鸟教程
多线程运行有如下优点:
1、使用线程可以把占据长时间的程序中的任务放到后台去处理。
2、在一些等待的任务实现上如用户输入、文件读写和网络收发数据等,线程就比较有用了。在这种情况下我们可以释放一些珍贵的资源如内存占用等等。此时的程序的运行速度可能加快
3、线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。
线程可以被抢占(中断)。
在其他线程正在运行时,线程可以暂时搁置(也称为睡眠) – 这就是线程的退让。
源码:
# -*- coding: utf-8 -*-
# @Time : 19-2-26 下午6:03
# @Author : Merlin
# @Email : shiehmerlin@gmail.com
# @File : __init__.py.py
# @Software: PyCharm
import threading,fcntl
import time
import os
def print_num(num):
while True: #随便写的一个判断
path = (os.getcwd())
f = open(path + '/TestIO.txt', "a+")
time.sleep(1)
f.write(str(num))
fcntl.flock(f.fileno(),fcntl.LOCK_EX)
#这就是线程锁(fcntl属于unix专有)
f.flush()
print(num)
return True
t1 = threading.Thread(target=print_num,args=(1,))
t2 = threading.Thread(target=print_num,args=(3,))
t1.start() #线程1
t2.start() #线程2
print(t1.getName()) #进程1
print(t2.getName()) #线程2
有关于fcntl模块:
flock() : flock(f, operation)
operation : 包括:
fcntl.LOCK_UN 解锁
fcntl.LOCK_EX 排他锁
fcntl.LOCK_SH 共享锁
fcntl.LOCK_NB 非阻塞锁
LOCK_SH 共享锁:所有进程没有写访问权限,即使是加锁进程也没有。所有进程有读访问权限。
LOCK_EX 排他锁:除加锁进程外其他进程没有对已加锁文件读写访问权限。
LOCK_NB 非阻塞锁:
如果指定此参数,函数不能获得文件锁就立即返回,否则,函数会等待获得文件锁。
LOCK_NB可以同LOCK_SH或LOCK_NB进行按位或(|)运算操作。 fcnt.flock(f,fcntl.LOCK_EX|fcntl.LOCK_NB)