看板 C_and_CPP 關於我們 聯絡資訊
一開始是看到這篇2013的文章 https://eli.thegreenplace.net/2013/12/05/ the-cost-of-dynamic-virtual-calls-vs-static-crtp-dispatch-in-c/ 短: https://reurl.cc/M75jGK 裡面只用一個CRTP impl 所以compiler可以直接inline 但是我實際用到virtual是像這樣 集中一堆ABC然後全呼叫一遍: vector<ABC*> bases; for(auto& it : bases) it->virtual_func(); 改成CRTP的寫法大概像這樣: https://godbolt.org/z/LygFKT 我的想像是 visit時不是應該也要先看實際型別是甚麼 再呼叫相對應函數嗎 這跟vtable的行為很像吧 為什麼量測時間 CRTP還是比virtual快了5~7倍? (i5 7400 + vs2019) 我的程度看組語或是看variant header都很痛苦 所以來洗耳恭聽大大的教訓 感恩 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 60.248.183.174 (臺灣) ※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1577939284.A.9A6.html
Lipraxde: Vvistor 裡的那個 for loop 被優化掉了,155 行的沒有 01/02 21:04
Lipraxde: ant/ <- 我覺得介紹的不錯 01/02 21:07
loveme00835: variant 做的事情就是用 type code 判斷然後再轉型, 01/02 23:09
loveme00835: 而轉型後實際上呼叫的函式是在編譯時期就選好的, 你 01/02 23:09
loveme00835: 可以自己用 union + type code 實作看看 01/02 23:09
LPH66: CRTP 的「基類」並不是單一個類, 而是每個子類都有一個基類 01/03 04:51
LPH66: 也因此雖然看起來同一段程式碼被很多不同子類呼叫 01/03 04:51
LPH66: 但因為基類是模版的關係, 每個基類是分開的 01/03 04:52
LPH66: 這個基類在呼叫子類方法時會確定知道自己負責什麼子類 01/03 04:52
LPH66: (藉由 CRTP 繼承時給的模版參數, 所以也是編譯期就確定的) 01/03 04:53
LPH66: 因此可以省去執行所有判斷子類的操作 (如 vtable 等) 01/03 04:53
LPH66: 甚至因為子類型態確定, 呼叫當下的所需要的繼承相關操作 01/03 04:56
LPH66: 僅僅只有為求得子類實體的 downcast 而已 01/03 04:56
LPH66: 這個 downcast 也因為是 static_cast 基本上沒有判斷操作 01/03 04:59
LPH66: 簡單說就是, 藉由模版把子類型態判斷變成編譯器的模版選擇 01/03 05:01
saladim: 請問個蠢問題...為什麼tick() function沒有name hiding的 01/07 01:47
saladim: 問題阿? 謝謝~ 01/07 01:47
saladim: 有時會被要求compiler warning要全修... 01/07 01:54