我正在为Linux(带有PThreads)和windows(带有内置的WinThreads)创建一个C库,它可以附加到任何程序,并且需要在线程退出时调用一个函数,类似于atexit的工作方式流程.
我知道pthreads的pthread_cleanup_push和pthread_cleanup_pop,但是这些对我来说不起作用,因为它们是添加另一个词法范围的宏,而我想在第一次调用我的库时声明这个函数,然后允许程序本身运行它需要自己的代码.我在windows中没有发现任何类似的东西.
请注意,这并不意味着我希望在线程停止时提醒外部线程,或者甚至我可以更改线程退出的方式,因为这是由程序本身控制的,我的库只是附加,为了骑.
所以问题是:在这种情况下,最好的方法是,当我无法控制线程的创建或销毁方式时,在windows或linux中,当线程关闭时,我有一个我编写的函数. ?
例如在主程序中:
voID* threadFunc(voID* arg){ printf("Hello World!\n"); return NulL;}int main(int argc,char** argv){ int numThreads = 1; pID_t* pIDs = NulL; pIDs = (pID_t*) calloc(sizeof(pID_t),numThreads); pthread_create(&ntID,NulL,threadFunc,&nVal); pthreads[0] = ntID; pthread_join(pthreads[0],NulL); return 0;}
在图书馆:
voID callMeOnExit(){ printf("Exiting Thread!\n");}
我想要在线程返回NulL时调用callMeOnExit;在这种情况下,以及当主线程到达返回0时;包装pthread_exit适用于其他情况,可能是一个解决方案,但如果可能的话,我想要一个更好的解决方案.
如果有人对我如何能够做到这一点有任何想法,那就太好了!
最佳答案所以在经过一些代码审查之后,我们能够在linux中找到一种更优雅的方式来实现这一点,这与windows对Fibers(如Neeraj所指出的)以及我在开始研究时所期望的内容相匹配.这个问题.关键是pthread_key_create作为第二个参数接收一个指向析构函数的指针,当初始化此TLS数据的任何线程死亡时,该指针被调用.我已经在每个线程的其他地方使用TLS,但是一个简单的TLS存储将为您提供此功能以确保它被调用. 总结
以上是内存溢出为你收集整理的c – 在线程退出PThreads或Windows时调用函数全部内容,希望文章能够帮你解决c – 在线程退出PThreads或Windows时调用函数所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)