python中多线程的意外行为

时间:2012-06-12 11:48:35

标签: python unix python-multithreading

我是python的新手,并试图理解python中多线程的概念。 根据我在Unix多线程编程中的知识,如果main函数正在终止,main函数创建的线程也将被终止,而不管它们在线程中做的工作(如果我们没有使用任何pthread_join()函数)。

但是在使用python中的多线程时,我没有看到这个功能。即使我的主线程完成其工作,我的线程仍然成功运行。 所以我想知道,Python和Unix中的线程表现不同......或者我错过了一些东西。请帮助理解python中的这个线程功能。这是我在python中使用的代码。

#! /usr/bin/python
import logging
import random
import threading
import time

logging.basicConfig(level=logging.DEBUG,
                format='(%(threadName)-10s) %(message)s',
               )

class Counter(object):

def __init__(self, start=0):
    self.lock = threading.Lock()
    self.value = start

def increment(self):
    logging.debug('Waiting for lock')

    # Getting the Lock
    self.lock.acquire()
    try:
        logging.debug('Acquired lock')
        self.value = self.value + 1
    finally:
       # Releasing the Lock 
        self.lock.release()



def worker(c):
    for i in range(2):
        pause = 4 
        logging.debug('Sleeping for %0.02f', pause)
        time.sleep(pause)
        c.increment()
    logging.debug('Done')



if  __name__ == '__main__':
    counter = Counter()
    for i in range(2):
        t = threading.Thread(target=worker, args=(counter,))
        t.start()

    logging.debug('Counter: %d', counter.value)

3 个答案:

答案 0 :(得分:1)

You have to make the threads daemon threads

for i in range(2):
    t = threading.Thread(target=worker, args=(counter,))
    t.setDaemon(True)
    t.start()

答案 1 :(得分:1)

检查文档中有关Thread.daemon的内容。 “当没有剩下活着的非守护程序线程时,整个Python程序就会退出。”

答案 2 :(得分:0)

不幸的是,python中的线程有点像linux线程。据我所知,根据GIL http://wiki.python.org/moin/GlobalInterpreterLock,只有一个线程同时运行(!)

另外......当mainThread被终止时,它将等待线程完成,除非它们被创建为setDaemon(True)无论如何你应该自己停止你的线程,例如try {主线程代码} finally: doSomethingToStopThreads()