Python多线程笔记

2017-08-31  本文已影响50人  Adiwy

线程状态

线程共存在五中基本状态,如下所示(转载):

线程的创建

Python提供两个模块进行多线程的操作,分别是thread和threading,前者是比较低级的模块,用于更底层的操作,一般应用级别的开发不常应用。后者则封装了更多高级的接口,提供run方法和start调用。

# -*- coding: utf-8 -*-
import threading
import time

exitFlag = 0


class myThread(threading.Thread):  # 继承父类threading.Thread
    def __init__(self, threadID, counter):
        threading.Thread.__init__(self)
        self.threadID = threadID
        self.counter = counter

    def run(self):  # 把要执行的代码写到run函数里面 线程在创建后会直接运行run函数
        print "Starting " + self.name
        print_time(self.name, self.counter, 5)
        print "Exiting " + self.name


def print_time(threadName, delay, counter):
    while counter:
        # print exitFlag
        if exitFlag:
            threading.Thread.exit()
        time.sleep(delay)
        print "%s: %s" % (threadName, time.ctime(time.time()))
        counter -= 1


# 创建新线程
thread1 = myThread(1,1)
thread2 = myThread(2,2)
thread3 = myThread(3,3)

# 开启线程
thread1.start()
thread2.start()
thread3.start()

print "Exiting Main Thread"


输出结果如下所示:

Starting Thread-1
Starting Thread-2
Starting Thread-3Exiting Main Thread

Thread-1: Thu Aug 31 14:39:47 2017
Thread-1: Thu Aug 31 14:39:48 2017Thread-2: Thu Aug 31 14:39:48 2017

Thread-3: Thu Aug 31 14:39:49 2017Thread-1: Thu Aug 31 14:39:49 2017

Thread-1: Thu Aug 31 14:39:50 2017Thread-2: Thu Aug 31 14:39:50 2017

Thread-1: Thu Aug 31 14:39:51 2017
Exiting Thread-1
Thread-3: Thu Aug 31 14:39:52 2017
Thread-2: Thu Aug 31 14:39:52 2017
Thread-2: Thu Aug 31 14:39:54 2017
Thread-3: Thu Aug 31 14:39:55 2017
Thread-2: Thu Aug 31 14:39:56 2017
Exiting Thread-2
Thread-3: Thu Aug 31 14:39:58 2017
Thread-3: Thu Aug 31 14:40:01 2017
Exiting Thread-3

主线程结束打印“Exiting Main Thread”,每个线程的顺序都是有时间先后的,但是各个线程并不是按照顺序执行,交错执行。

上一篇 下一篇

猜你喜欢

热点阅读