![](/img/trans.png)
[英]what is a good way to run experiments for the memory usage of an algorithm in C++?
[英]What is a good and optimized way to run shell command in a pthread?
基本上,我想使用gzip在pthread線程中壓縮文件。 在Google上出現的第一個解決方案是調用system()。
stackoverflow社區建議什么?
我應該在pthread中使用system()嗎?
還是我自己只是在pthread中執行並執行? 但是由於pthread是線程,是否建議在pthread線程中進行fork()和exec()?
還是比上面更好的方法?
從另一個線程中的system
調用開始,僅在需要時才增加復雜性。
僅當system
由於某些原因不夠用時(例如,您要將子進程的stdin
和stdout
都重定向到父進程中,或者想要壓縮),執行fork
/ exec
或使用zip
庫的額外復雜性才值得付出努力。內存中的文件,無需編寫新文件即可通過網絡發送該文件)。
您不應該為此使用system
,但不要因為它昂貴。 (對於任何值得壓縮的文件,調用后台gzip壓縮的任何技術的開銷相對於執行壓縮本身的成本而言都是微不足道的。)不應使用system
的原因是, system
調用shell,這意味着您必須擔心引用參數。 如果改用fork
和execvp
,則不必擔心引用任何內容。
與混合fork
和wait
線程相關的問題是真實的,但它們很容易解決。 如果您的操作系統具有posix_spawn
,它將為您解決其中的一些問題。 我通常不推薦posix_spawn
因為使用它的代碼通常比使用fork
代碼更難維護,但是對於此應用程序來說應該可以。 我無法提供綜合指南來混合fork
並wait
線程進入此答案框。
您應該考慮的替代方法是使用zlib在等待gzip
進程的線程中壓縮數據。 這避免了混合的問題, fork
,並wait
與線程,但它增加了一個庫依賴於你的程序,這可能不一樣便利依賴於外部gzip
可執行文件。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.