C_and_CPP 板


LINE

開發平台(Platform): (Ex: Win10, Linux, ...) Linux 編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出) GCC 問題(Question): 上面那篇我有問估算vector在empalce_back(int)花的時間時, 發現疑似有page fault的情形, 但問題來了,我用/usr/bin/time -v ./a.out 去檢測,結果如下: Major (requiring I/O) page faults: 0 Minor (reclaiming a frame) page faults: 343 看起來沒有發生硬性的page fault,而且我測試的機器記憶體有32GB, 這樣會遇到page fault也讓我有點驚訝, 另外我後來有加mlock,就可以避免在1024倍數次loop時時間變大到us的問題, 但我這時再用/usr/bin/time -v ./a.out 去檢測,結果跟沒有加mlock差不多, 這樣真的有改善page fault嗎? 讓我有點懷疑。 有沒有神人可以指點一二,感恩。 程式碼(Code):(請善用置底文網頁, 記得排版,禁止使用圖檔) #include <iostream> #include <vector> #include <sys/mman.h> uint64_t get_tscp() { uint64_t a, d; __asm__ volatile("rdtscp" : "=a"(a), "=d"(d)); return (d << 32) | a; } int main(int argc, char *argv[]) { std::vector<int> v; int size = 4096; v.reserve(size); mlock(&v[0], sizeof(int)*size); for (int i = 0; i < size; ++i) { auto t1 = get_tscp(); v.emplace_back(i); auto t2 = get_tscp(); // std::cout << (t2 - t1) / 2.6 << std::endl; } return 0; } -- 生死去來,棚頭傀儡,一線斷時,落落磊磊。 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 111.248.111.87 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1642107483.A.B08.html
1F:推 shibin: 好奇一問,mlock()有成功嗎 01/14 13:02
2F:→ Lipraxde: 你想要什麼硬性的 page fault...? 01/14 13:23
3F:推 sarafciel: 15us的話應該是minor page fault,可以試試看perf 01/14 13:24
4F:→ Lipraxde: 程式在向 OS 要 memory 時,實際上 OS 是先預留位置, 01/14 13:35
5F:→ Lipraxde: 直到實際去存取要到的位置時 (觸發了 page fault 後) 01/14 13:35
6F:→ Lipraxde: 才會真的去更新 page table,屬於 recoverable 的 01/14 13:35
7F:→ Lipraxde: 想避免的話也許用 mmap + MAP_POPULATE? 01/14 13:44
8F:推 jaid: madvise? 01/14 16:06
9F:→ laughingman: 抱歉可能描述不清楚讓大家誤會了,mlock()有成功, 01/14 18:19
10F:→ laughingman: 所以我想說在使用mlock()時跑/usr/bin/time -v應該 01/14 18:20
11F:→ laughingman: 看不到minor page fault,可是仍然顯示有一樣多的 01/14 18:22
12F:→ laughingman: (甚至更多)的minor page fault,這樣無法解釋mlock() 01/14 18:24
13F:→ laughingman: 真的有解決原有的page fault問題。 01/14 18:25
14F:推 dces4212: 語言runtime在載入.so時也會有page fault 或許可以試試 01/15 03:29
15F:→ dces4212: 在你感興趣的程式碼前後用getrusage來觀察page fault次 01/15 03:29
16F:→ dces4212: 數比較精準 01/15 03:29
17F:推 LiloHuang: 總是會有 page fault 只是發生時間早晚問題 01/15 14:30
18F:→ LiloHuang: 從mmap 拿到的 address 再跑 madvise + MADV_HUGEPAGE 01/15 14:35
19F:→ LiloHuang: 使用 huge page (e.g. 2M) 應該就能減少次數了 01/15 14:36
20F:→ LiloHuang: std::vector default allocator 也不一定是 mmap 來的 01/15 14:38
21F:→ LiloHuang: 建議自己用 mmap 寫個 custom allocator 01/15 14:39
22F:→ laughingman: 謝謝各位大神的建議,我再研究看看,有結果再跟大家 01/16 06:43
23F:→ laughingman: 分享,感恩。 01/16 06:43







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Boy-Girl站內搜尋

TOP