pthread_exit与返回

pthread_exit与返回,第1张

pthread_exit与返回

下面的最小测试用例展示了您描述的行为:

#include <pthread.h>#include <unistd.h>void *app1(void *x){    sleep(1);    pthread_exit(0);}int main(){    pthread_t t1;    pthread_create(&t1, NULL, app1, NULL);    pthread_join(t1, NULL);    return 0;}

valgrind --leak-check=full --show-reachable=yes
显示了从调用的函数分配的5个块,这些块
pthread_exit()
未释放,但在进程退出时仍可访问。如果将
pthread_exit(0);
替换为
return0;
,则不会分配5个块。

但是,如果测试创建和联接大量线程,则会发现退出时使用的未释放内存量 不会
增加。这以及它仍然可以访问的事实,表明您只是看到glibc实现的怪异之处。几个glibc函数

malloc()
在第一次调用时分配内存,它们在剩余的进程生命周期中一直分配。glibc无需在进程退出时释放该内存,因为它知道该进程无论如何都将被拆除-
这只会浪费CPU周期。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5009832.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-14
下一篇 2022-11-14

发表评论

登录后才能评论

评论列表(0条)

保存