免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1750 | 回复: 6
打印 上一主题 下一主题

【python核心编程】线程和锁的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-08-15 16:45 |只看该作者 |倒序浏览
本帖最后由 壮乡小顽主 于 2012-08-15 16:50 编辑

python核心编程书上的脚本如下:

import thread
from time import ctime, sleep

loops = [4, 2]

def loop(nloop, nsec, lock):
    print 'start loop', nloop, 'at:', ctime()
    sleep(nsec)
    print 'loop', nloop, 'done at:', ctime()
    lock.release()


def main():
    print 'starting at:', ctime()
    locks = []
    nloops = range(len(loops))

   
    for i in nloops:
        lock = thread.allocate_lock()
        lock.acquire()
        locks.append(lock)
   
    for i in nloops:
        thread.start_new_thread(loop, (i, loops, locks))

    print 'to here 2'
    for i in nloops:
        while locks.locked():pass
   

    print 'all DONE at:', ctime()

if __name__ == '__main__':
    main()

在python2.6上运行后报错,见截图。通过打印确定问题出在thread.start_new_thread(loop, (i, loops, locks)),麻烦高手解释一下为什么,十分感谢!脚本里的[]出不来,请看截图。

论坛徽章:
0
2 [报告]
发表于 2012-08-15 17:04 |只看该作者
为么,我这贴了你的程序上去可以运行啊

论坛徽章:
0
3 [报告]
发表于 2012-08-15 17:09 |只看该作者
啊?难道我的环境有问题?神奇~回复 2# majiayang2012


   

论坛徽章:
0
4 [报告]
发表于 2012-08-15 17:11 |只看该作者
错误上是你的环境问题吧,我这可以运行

administrator@ubuntu:~$ python test.py
starting at: Wed Aug 15 17:10:44 2012
to here 2
start loop 1 at: Wed Aug 15 17:10:44 2012
start loop 0 at: Wed Aug 15 17:10:44 2012
loop 1 done at: Wed Aug 15 17:10:46 2012
loop 0 done at: Wed Aug 15 17:10:48 2012
all DONE at: Wed Aug 15 17:10:48 2012

论坛徽章:
0
5 [报告]
发表于 2012-08-15 17:17 |只看该作者
谢谢帮助回复 4# majiayang2012


   

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
6 [报告]
发表于 2012-08-15 20:26 |只看该作者
什么破书, 错误百出.
  1. # -*- coding:gb2312 -*-

  2. import thread
  3. from time import ctime, sleep

  4. loops = [4, 2]

  5. def loop(nloop, nsec, lock):
  6.     print 'start loop', nloop, 'at:', ctime()
  7.     sleep(nsec)
  8.     print 'loop', nloop, 'done at:', ctime()
  9.     lock.release()


  10. def main():
  11.     print 'starting at:', ctime()
  12.     locks = []
  13.     nloops = range(len(loops))

  14.    
  15.     for i in nloops:
  16.         lock = thread.allocate_lock()
  17.         lock.acquire()
  18.         locks.append(lock)
  19.    
  20.     for i in nloops:
  21.         thread.start_new_thread(loop, (i, 5, locks[i]))

  22.     print 'to here 2'
  23.     for i in nloops:
  24.         while locks[i].locked():
  25.             pass

  26.     print 'all DONE at:', ctime()

  27. if __name__ == '__main__':
  28.     main()
复制代码

论坛徽章:
13
双鱼座
日期:2013-10-23 09:30:05数据库技术版块每日发帖之星
日期:2016-04-20 06:20:00程序设计版块每日发帖之星
日期:2016-03-09 06:20:002015亚冠之塔什干火车头
日期:2015-11-02 10:07:452015亚冠之德黑兰石油
日期:2015-08-30 10:07:07数据库技术版块每日发帖之星
日期:2015-08-28 06:20:00数据库技术版块每日发帖之星
日期:2015-08-05 06:20:002015年迎新春徽章
日期:2015-03-04 09:57:09辰龙
日期:2014-12-03 14:45:52酉鸡
日期:2014-07-23 09:46:23亥猪
日期:2014-03-13 08:46:22金牛座
日期:2014-02-11 09:36:21
7 [报告]
发表于 2012-08-16 08:49 |只看该作者
上面的在胡扯啊,还神马破书,有能耐你去写一本破书
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP