亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
12下一頁
最近訪問板塊 發(fā)新帖
查看: 5266 | 回復: 14
打印 上一主題 下一主題

[CPU及多核] 在多核計算機上,線程和進程調(diào)度的問題 [復制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2013-12-21 22:43 |只看該作者 |倒序瀏覽
     在一臺4核的計算機上,我做了兩個測試程序A,B,在A上面創(chuàng)建4個線程,B上面創(chuàng)建4個進程,每個進程和線程中執(zhí)行一樣的函數(shù),做循環(huán)的i++操作。用top觀察運行情況,在運行A的過程中cpu使用率接近400%,運行B的過程中創(chuàng)建的4個進程的CPU使用率都接近100%。在進程的運行過程中,只能有一個上下文環(huán)境,在一個事件點上就只能運行一個進程(是不是這里我理解錯了),怎么能夠使4個進程都并行的運行起來呢?如果沒有并行的運行,那么4個進程的CPU怎么都是100%呢?

論壇徽章:
2
天蝎座
日期:2014-07-23 21:17:122015年辭舊歲徽章
日期:2015-03-03 16:54:15
2 [報告]
發(fā)表于 2013-12-22 09:10 來自手機 |只看該作者
我想你的B應該是沒有綁核操作,所以內(nèi)核給負載均衡了吧?梢源_認下主線程被綁到哪個核。

論壇徽章:
0
3 [報告]
發(fā)表于 2013-12-22 10:30 |只看該作者
回復 2# polejo


   我現(xiàn)在理解的是一個時刻只能運行一個進程而不是像線程一樣四個線程能同時運行?內(nèi)核里面有自動的進程和cpu的映射,每個進程能得到獨立的cpu,但是會有獨立的上下文環(huán)境嗎?

論壇徽章:
0
4 [報告]
發(fā)表于 2013-12-22 12:08 |只看該作者
用戶態(tài)進程和線程在內(nèi)核看來都是一個task_struct,沒有特殊的設置,調(diào)度都是一樣的。
另外,top的CPU占用率不準

論壇徽章:
1
水瓶座
日期:2013-09-28 21:40:25
5 [報告]
發(fā)表于 2013-12-22 21:15 |只看該作者
回復 1# jhl19880722


   
對于實驗現(xiàn)象,我的理解:
  • A和B的操作內(nèi)核層面來看都差不多:四個任務在四個核上面做i++操作,唯一的不同時,B對應的4個進程不共享地址空間,即四個任務的i對應不同的內(nèi)存地址;而A對應的4個線程共享地址空間,也就是說4個線程共享變量i;
  • 因為top命令是按照進程來統(tǒng)計占用率的,所以A的四個進程各占100%,而B一個進程獨占400%;

  
對于你的疑問,我的解答:
  • "在進程的運行過程中,只能有一個上下文環(huán)境",這句話你理解的有問題。這句話中的“進程”如果替換成內(nèi)核理解的“任務task”就沒有問題了。事實上進程A的四個線程實際上就是運行在四個核上的不同任務,而每一個線程對應的任務都有自己的一個上下文環(huán)境,只不過四個上下文有些相同的東東罷了。
  • 核心問題是,上下文到底指什么?操作系統(tǒng)和硬件密切相關(guān),上下文概念與CPU密切相關(guān)。上下文說白了就是CPU的狀態(tài)。系統(tǒng)要實現(xiàn)多任務在單CPU的輪轉(zhuǎn)執(zhí)行,就要不斷的保存和恢復CPU的狀態(tài),這就叫上下文切換。

論壇徽章:
0
6 [報告]
發(fā)表于 2013-12-22 21:49 |只看該作者
回復 5# bensenq
謝謝。一直以為在多核的環(huán)境下只有多線程才能同時多個線程進行并發(fā)執(zhí)行,進程每次只能執(zhí)行一個,多進程不能充分利用多核的性能。

   

論壇徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辭舊歲徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亞洲杯之卡塔爾
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08處女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技術(shù)圖書徽章
日期:2014-03-25 09:00:29
7 [報告]
發(fā)表于 2013-12-23 08:44 |只看該作者
jhl19880722 發(fā)表于 2013-12-21 22:43
在一臺4核的計算機上,我做了兩個測試程序A,B,在A上面創(chuàng)建4個線程,B上面創(chuàng)建4個進程,每個進程和線程 ...

線程和進程的調(diào)度方式是一樣的,你看到的top 400%,應該是因為top命令的Irix和線程模式吧,top執(zhí)行后按H和I,就可以看到區(qū)別了。
另外,每個進程都有獨立的上下文,4個進程可同時在4個核上執(zhí)行(當然,還取決于是否有臨界資源)

論壇徽章:
6
金牛座
日期:2013-10-08 10:19:10技術(shù)圖書徽章
日期:2013-10-14 16:24:09CU十二周年紀念徽章
日期:2013-10-24 15:41:34獅子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亞洲杯之阿聯(lián)酋
日期:2015-05-09 14:36:15
8 [報告]
發(fā)表于 2013-12-23 11:06 |只看該作者
回復 1# jhl19880722
內(nèi)核在做調(diào)度的時候不區(qū)分線程和進程。top -H

   

論壇徽章:
2
CU十二周年紀念徽章
日期:2013-10-24 15:41:34處女座
日期:2013-12-27 22:22:41
9 [報告]
發(fā)表于 2013-12-25 00:57 |只看該作者
回復 8# 瀚海書香

線程間有一定相關(guān)度,可能會使調(diào)度器認為它們最好運行在同一CPU上,比如為了提高cache命中率。

論壇徽章:
16
2015亞冠之吉達阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉雞
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52雙魚座
日期:2014-02-22 13:07:56午馬
日期:2014-02-14 11:08:18雙魚座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
10 [報告]
發(fā)表于 2013-12-25 07:35 |只看該作者
回復 9# tempname2

貌似不區(qū)分的。


   
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP