當前位置:首頁 > 芯聞號 > 充電吧
[導讀]在 Win32 API 中,創(chuàng)建線程的基本函數(shù)是 CreateThread,而 _beginthread(ex) 是C++ 運行庫的函數(shù)。為什么要有兩個呢?因為C++ 運行庫里面有一些函數(shù)使用了全局量

在 Win32 API 中,創(chuàng)建線程的基本函數(shù)是 CreateThread,而 _beginthread(ex) 是C++ 運行庫的函數(shù)。為什么要有兩個呢?因為C++ 運行庫里面有一些函數(shù)使用了全局量,如果使用 CreateThread 的情況下使用這些C++ 運行庫的函數(shù),就會出現(xiàn)不安全的問題。而 _beginthreadex 為這些全局變量做了處理,使得每個線程都有一份獨立的“全局”量。

所以,如果你的編程只調(diào)用 Win32 API/SDK ,就放心用 CreateThread;如果要用到C++ 運行時間庫,那么就要使用 _beginthreadex ,并且需要在編譯環(huán)境中選擇 Use?MultiThread Lib/DLL。

C++ 運行期庫有兩個創(chuàng)建線程的函數(shù),另一個是 _beginthread, 它們兩者的區(qū)別請自己去看MSDN:

通常他們的解釋都是這容易造成內(nèi)存泄漏。這個解釋本身是沒有錯的,但是解釋得不夠完全和詳 細。以至于造成很多新手盲目的信任了那句話,在那里都是用_beginthreadex函數(shù),或者是裝作沒有看到使用CreateThread函數(shù)。曾經(jīng) 有一段時間我也對這個問題很是困惑,不知道到底用那個才是對的。因為我不止一次在很多權(quán)威性的代碼中看到對CreateThread函數(shù)的直接調(diào)用。難道 是權(quán)威錯了?? 抱著懷疑的態(tài)度查找了大量的資料和書籍,終于搞明白了這個問題的關鍵所在,在此做個說明,算是對那句話的一個完善。

?

關于_beginthreadex和CreateThread的區(qū)別我就不做說明了,這個很 容易找到的。我們只要知道一個問題:_beginthreadex是一個C運行時庫的函數(shù),CreateThread是一個系統(tǒng)API函 數(shù),_beginthreadex內(nèi)部調(diào)用了CreateThread。只所以所有的書都強調(diào)內(nèi)存泄漏的問題是因為_beginthreadex函數(shù)在創(chuàng) 建線程的時候分配了一個堆結(jié)構(gòu)并和線程本身關聯(lián)起來,我們把這個結(jié)構(gòu)叫做tiddata結(jié)構(gòu),是通過線程本地存儲器TLS于線程本身關聯(lián)起來。我們傳入的 線程入口函數(shù)就保存在這個結(jié)構(gòu)中。tiddata的作用除了保存線程函數(shù)入口地址之外,還有一個重要的作用就是:C運行時庫中有些函數(shù)需要通過這個結(jié)構(gòu)來 保存和獲取一些數(shù)據(jù),比如說errno之類的線程全局變量。這點才是最重要的。

當一個線程調(diào)用一個要求tiddata結(jié)構(gòu)的運行時庫函數(shù)的時候,將發(fā)生下面的情況:

運行時庫函數(shù)試圖TlsGetv alue獲取線程數(shù)據(jù)塊的地址,如果沒有獲取到,函數(shù)就會 現(xiàn)場分配一個 tiddata結(jié)構(gòu),并且和線程相關聯(lián),于是問題出現(xiàn)了,如果不通過_endthreadex函數(shù)來終結(jié)線程的話,這個結(jié)構(gòu)將不會被撤銷,內(nèi)存泄漏就會出 現(xiàn)了。但通常情況下,我們都不推薦使用_endthreadex函數(shù)來結(jié)束線程,因為里面包含了ExitThread調(diào)用。

?

找到了內(nèi)存泄漏的具體原因,我們可以這樣說:只要在創(chuàng)建的線程里面不使用一些要求tiddata結(jié)構(gòu)的運行時庫函數(shù),我們的內(nèi)存時安全的。所以,前面說的那句話應該這樣說才完善:

“絕對不要調(diào)用系統(tǒng)自帶的CreateThread函數(shù)創(chuàng)建新的線程,而應該使用_beginthreadex,除非你在線程中絕不使用需要tiddata結(jié)構(gòu)的運行時庫函數(shù)”

?

這個需要tiddata結(jié)構(gòu)的函數(shù)有點麻煩了,在侯捷的《win32多線程程序設計》一書中這樣說到:

”如果在除主線程之外的任何線程中進行一下操作,你就應該使用多線程版本的C runtime library,并使用_beginthreadex和_endthreadex:

1 使用malloc()和free(),或是new和delete

2 使用stdio.h或io.h里面聲明的任何函數(shù)

3 使用浮點變量或浮點運算函數(shù)

4 調(diào)用任何一個使用了靜態(tài)緩沖區(qū)的runtime函數(shù),比如:asctime(),strtok()或rand()。


本站聲明: 本文章由作者或相關機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術(shù)
關閉
關閉