• <output id="aynwq"><form id="aynwq"><code id="aynwq"></code></form></output>

    <mark id="aynwq"><option id="aynwq"></option></mark>
  • <mark id="aynwq"><option id="aynwq"></option></mark><label id="aynwq"><dl id="aynwq"></dl></label>
  • 學習啦 > 學習電腦 > 電腦硬件知識 > CPU知識 > 如何提高多線程程序的

    如何提高多線程程序的

    時間: 捷鋒774 分享

    如何提高多線程程序的

      正如大家所知道的那樣,多核多cpu越來越普遍了,而且編寫多線程程序也是件很簡單的事情。那么,如何提高多線程的CPU的一些使用率,下面是學習啦小編帶來的關于如何提高多線程程序的cpu利用率的內容,歡迎閱讀!

      如何提高多線程程序的:

      首先,我來講一下多處理的一些知識。如下圖所示,

      多處理器系統也只有一個待運行的線程隊列,內存中也只有一個操作系統拷貝,而且也只有一個內存系統,但是會有多個cpu同時運行不同的線程。一個cpu運行一個線程,那么上圖中的系統最多能在同一時間運行2個線程。其實,多處理系統需要掌握的知識不是這些,而是緩存一致性。

      現在來解釋下什么是緩存一致性。由于,還是只有一個內存系統。所有cpu都要和這個內存系統通信,但是只有一條總線,那么這無疑會造成總線緊張,限制整體的速度了。那么,你多個cpu也沒多少意義了。解決這個問題的辦法還是利用cpu的緩存機制,學過組成原理的同學都知道,cpu的緩存命中率還是很高的,有90%以上吧。那么,我繼續利用緩存機制還是可以降低總線的頻繁使用的。但是,每個cpu都有自己的緩存。如果有2個cpu的緩存存儲的是同一內存數據的內容,其中一個cpu的緩存更新了,另外一個cpu的緩存也必須更新,這就是所謂的緩存一致性。編程多線程程序的一個很重要的一點就是避免因為緩存一致性引起的緩存更新風暴。

      現在我舉一個緩存更新風暴的例子。

      如圖所示的類定義,

      鎖lockHttp和lockSsl中間只有8個字節,而絕大部分系統上一個緩存行是128個字節,那么這2個鎖很可能就處在同一個緩存行上面。那么,最壞的情況會發生什么事情了。假設處理器P1在運行一個處理http請求的線程T1,處理器P2在運行一個處理ssl請求的線程T2,那么當T1獲得鎖lockHttp的時候,鎖的內容就會改變,為了保持緩存一致性,就會更新P2的緩存。那么,T2要獲得鎖lockssl的時候,發現緩存已經失效了,就必須從內存中重新加載緩存之類。總之,這會將緩存命中率降低到90%以下,引起性能的嚴重降低。而且發生這種事情的原因是因為我們不了解硬件的體系結構。

      多cpu不能成倍提高速度的原因是任務的某些部分是必須串行處理的。比如,矩陣乘法可以分為三個部分,初始化矩陣,相乘,返回結果。這三部分第二部分可以用多線程來處理,第一部分和第三部分則是不可以的。而且第二部分必須在第一部分完成之后,第三部分必須在第一部分完成之后。那么,無論你添加多少個處理器,最快的時間都至少是第一部分和第二部分的時間之和。這個事實好像叫做Amdahl法則。

      如果使用多線程,那么就必須考慮線程同步,而線程同步又是導致速度降低的關鍵。所以下面就講述一些方法來加快多線程程序的吞吐速度。

      方法一,把一個任務分解為多個可以子任務。

      因為總有些子任務是可以并發的,多個子任務并發執行了很可能就能夠避免cpu需要io操作的完成了,而且能夠提高系統的吞吐量。

      方法二,緩存多線程的共享數據。

      當你已經在使用多線程了,很多時候必須使用共享數據。如果,數據是只讀的,那么可以在第一次獲取后保存起來,以后就可以重復使用了。但是,第一次的獲取還是無法避免的需要線程同步操作的。

      方法三,如果線程數目有限,就不要共享數據。

      做法是為每一個線程實例化一個單獨的數據,其實就是為每一個線程分配一塊數據使用。這樣沒有線程同步操作了,速度可以盡可能的提示。

      方法四,如果沒辦法確定線程數目到底有多少,那么使用部分共享吧。

      部分共享其實就是使用多個資源池代替一個資源池,資源池的數目得更加經驗來確定。如下圖所示,

      最后在提一個叫做Thundering Herd的問題,該問題維基百科有定義。大意是,當多個線程在等待一個資源的時候,如果事件等待到了,操作系統是喚醒所有等待的線程讓它們自己去競爭資源了還是選擇一個線程把資源給它。當然喚醒所有的線程肯定開銷要大,而且所有沒有搶到資源的線程還得重新進入等待狀態,這無疑造成很多沒必要的操作,浪費了沒必要的線程上下文切換??傊?,會不會存在Thundering Herd還是跟不同的操作系統有關的。萬一存在Thundering Herd了,多線程可能就沒那么好辦了。

      到現在我們知道了為什么多cpu并不能成倍提高程序的速度了。首先因為有些任務無法并行,其次即使是并行cpu之間還是有很多牽制的。

    看了如何提高多線程程序的文章內容的人還看:

    1.java多線程內存模型

    2.Linux下如何實現shell多線程編程

    3.CPU超線程技術是什么

    4.Java學習方法有哪些

    5.CPU專業名詞詳解

    6.哪些IBM可以適用于linux

    7.i3、i5、i7處理器詳細介紹

    8.CMOS開機密碼怎么清除

    608771 主站蜘蛛池模板: a毛片免费在线观看| 久久精品国产亚洲av瑜伽| 高清永久免费观看| 日韩AV无码精品一二三区| 国产人妖在线观看一区二区| 中文字幕免费观看| 男人天堂网2017| 国产精品多p对白交换绿帽| 久久精品视频一区| 美女扒开超粉嫩的尿口视频 | 激情freesexhd糟蹋videos| 国产精品视频一区二区三区四| 九色视频在线观看| 美女大黄三级视频在线观看 | 老子影院午夜伦手机不四虎| 女人自慰AA大片| 亚洲国产成人99精品激情在线 | 最近中文字幕mv免费视频| 国产xxxx做受视频| 99久久亚洲综合精品成人网| 最近日本中文字幕免费完整| 啊灬啊灬啊灬深灬快用力| 99re5在线精品视频热线| 日韩高清在线免费看| 劲爆欧美第1页婷婷| 4399理论片午午伦夜理片| 日本激情一区二区三区| 先锋影音av资源网| 日本按摩xxxxx高清| 成人五级毛片免费播放| 亚洲成人免费网址| 色妺妺在线视频| 国产边摸边吃奶叫床视频| 久久久久亚洲av无码去区首| 濑亚美莉在线视频一区| 国产妇女馒头高清泬20p多| maya玛雅□一亚洲电影| 最新版天堂资源8网| 免费人妻无码不卡中文字幕系 | mm1313亚洲国产精品美女| 日韩精品无码一本二本三本|