zoukankan      html  css  js  c++  java
  • 在线程函数第一行调用 pthread_detach(pthread_self()) 返回值是22 不是 0

    近来发现 在线程函数第一行调用 pthread_detach(pthread_self()) 返回值是22 不是 0

    后来在网上找到以下话语

    linux线程执行和windows不同,pthread有两种状态joinable状态和unjoinable状态,
    如果线程是joinable状态,当线程函数自己返回退出时或pthread_exit时都不会释放线程所占用堆栈和线程描述符(总计8K多)。只有当你调用了pthread_join之后这些资源才会被释放。
    若是unjoinable状态的线程,这些资源在线程函数退出时或pthread_exit时自动会被释放。

    unjoinable属性可以在pthread_create时指定,或在线程创建后在线程中pthread_detach自己,如:pthread_detach(pthread_self()),将状态改为unjoinable状态,确保资源的释放。或者将线程置为joinable,然后适时调用pthread_join.

    在程序运行中检查/proc/ <pid> /maps文件   ,若看到大概8K左右的很多虚拟内存碎片,基本上可以确认是线程资源泄漏造成的300个线程后pthread_create失败。

     

    不知是否因为自己,先对要创建的线程做了以下属性设定,

    pthread_attr_init(&attr);

    pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);

     

    然后又在线程函数中使用

    pthread_detach(pthread_self());

     

     

    两段代码作用有冲突

     

  • 相关阅读:
    SQL Server 中WITH (NOLOCK)浅析
    C#中Monitor对象与Lock关键字的区别分析
    lock,Monitor,Mutex的区别
    如何在windows7中使用“专用字符编辑器”中的字
    ppapi,npapi
    配置OpenLDAP,Java操作LDAP,DBC-LDAP进访问
    List of Mozilla-Based Applications
    TLS协议分析
    编译Chrome详细步骤
    黑客惯用软件
  • 原文地址:https://www.cnblogs.com/cy163/p/1285801.html
Copyright © 2011-2022 走看看