python线程执行完后释放内存,为什么python线程会消耗这么多内存?

Why does python thread consumes so much memory?

I measured that spawning one thread consumes 8 megs of memory, almost as big as a whole new python process!

OS: Ubuntu 10.10

Edit: due to popular demand I'll give some extraneous examples, here it is:

from os import getpid

from time import sleep

from threading import Thread

def nap():

print 'sleeping child'

sleep(999999999)

print getpid()

child_thread = Thread(target=nap)

sleep(999999999)

On my box, pmap pid will give 9424K

Now, let's run the child thread:

from os import getpid

from time import sleep

from threading import Thread

def nap():

print 'sleeping child'

sleep(999999999)

print getpid()

child_thread = Thread(target=nap)

child_thread.start() #

sleep(999999999)

Now pmap pid will give 17620K

So, the cost for the extra thread is 17620K - 9424K = 8196K

ie. 87% of running a whole new separate process!

Now isn't that just, wrong?

解决方案

This is not Python-specific, and has to do with the separate stack that gets allocated by the OS for every thread. The default maximum stack size on your OS happens to be 8MB.

Note that the 8MB is simply a chunk of address space that gets set aside, with very little memory committed to it initially. Additional memory gets committed to the stack when required, up to the 8MB limit.

The limit can be tweaked using ulimit -s, but in this instance I see no reason to do this.

As an aside, pmap shows address space usage. It isn't a good way to gauge memory usage. The two concepts are quite distinct, if related.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值