簡體   English   中英

使用C ++將多線程文件復制到其他硬盤驅動器

[英]Multithread file copy to different hard drive using c++

我需要開發一個應用程序,該應用程序可以使用一個線程來讀取源文件,而另一個線程來編寫它們,其復制速度比OS復制快。 源文件和目標文件位於不同的硬盤驅動器中。

我的問題是如何將源讀取線程的結果傳遞到目標寫入線程而又不導致某些競爭條件,並且仍然保持復制過程的最高性能,以實現比OS復制更快的復制過程。

使用有界隊列。
您可以使用任何隊列( TBB ,std :: deque, cirtular緩沖區等)。 如果不是線程安全的和/或阻塞的,則在其周圍進行同步並使用條件變量進行通知。 您不需要隊列中的技巧,因為將指向一大塊數據的指針傳遞到隊列中的速度比I / O快得多,但是如果您真的想過度優化,請檢查干擾器在此進行介紹)。

致審閱者:請注意,問題是有關在不同的硬盤驅動器之間進行復制,因此多線程副本將對其有利。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM