3 回答

TA貢獻1842條經驗 獲得超13個贊
GCC附帶了一個編譯器運行時庫(libgcc),用于(除其他外)它以其支持的語言為多線程相關功能提供了低級的OS抽象。最相關的示例是libstdc ++的C ++ 11 <thread>
,<mutex>
和<future>
,當使用內部Win32線程模型構建GCC時,它們沒有完整的實現。MinGW-w64提供了一個winpthreads(在Win32多線程API之上的pthreads實現),GCC可以將其鏈接以啟用所有高級功能。
我必須強調,這個選項并不禁止你寫你想要的任何代碼(它絕對NO什么API,你可以在你的代碼中調用影響)。它僅反映GCC的運行時庫(libgcc / libstdc ++ / ...)使用的功能。@James引用的警告與GCC的內部線程模型無關,而與Microsoft的CRT實現無關。
總結一下:
posix
:啟用C ++ 11 / C11多線程功能。使libgcc依賴libwinpthreads,以便即使您不直接調用pthreads API,也將分發winpthreads DLL。與您的應用程序一起分發一個DLL沒有錯。win32
:沒有C ++ 11多線程功能。
都不會影響任何調用Win32 API或pthreads API的用戶代碼。您可以同時使用兩者。

TA貢獻1853條經驗 獲得超6個贊
GCC運行時的某些部分(尤其是異常處理)取決于所使用的線程模型。因此,如果您使用的是由POSIX線程構建的運行時版本,但決定使用Win32 API在自己的代碼中創建線程,則可能會遇到問題。
即使您使用運行時的Win32線程版本,您也可能不應該直接調用Win32 API。引用MinGW常見問題解答:
由于MinGW使用Windows附帶的標準Microsoft C運行時庫,因此應小心并使用正確的函數來生成新線程。特別是,該CreateThread函數將無法為C運行時庫正確設置堆棧。您應該改用_beginthreadex(幾乎)與完全兼容的CreateThread。
- 3 回答
- 0 關注
- 6406 瀏覽
添加回答
舉報