[問題] template class 內 static 初始問題

作者: lovejomi (JOMI)   2018-06-22 17:03:37
https://wandbox.org/permlink/skxmougiYnaw1f1a
一開始遭遇到這個compile warning
warning: instantiation of variable 'Foo<int>::bar' required here, but no defin
ition is available [-Wundefined-var-template]
其實我不太知道他為什麼會warning
我確實有define在test.cpp這個translation unit
不懂的是 他感覺找不到定義 卻讓我pass, run time 也有拿到對的數值.
而g++不會有warning
1. 到這邊我還是不知道到底哪裡寫的不夠正確?
然而我試著解決這warning
於是我把 上面的
//b.
// extern template class Foo<int>;
打開
https://wandbox.org/permlink/j2ANWRBoeIZZJAHE
link error
undefined reference to `Foo<int>::Test()'
如果不呼叫 這個warning確實可以這樣解決
但我必須呼叫這function
2. 為什麼他這樣會說undefined? .h裡面明確有包含定義阿?
然而
//a.
// template class Foo<int>;
打開後
3. 我認為我已經明確讓他產生程式碼了.... warning還是存在
回歸1. 的問題 我到底少做了什麼讓clang這樣出warning
4. 對於template class內 有static function or data
最正確的寫法該怎麼寫.
網路上有查到
在test.h 直接寫
template<class T>
int Foo<T>::bar = 初始直;
test.cpp一樣寫
template<>
int Foo<int>::bar = 123;
但我實際上在專案遇到一個況狀是
我某個cpp 寫Foo<int>::bar 拿到的卻是.h給的初始直(我認為是他初始化順序優先於te
st.cpp)
所以目前毫無辦法處理這warning
5. 這似乎沒辦法用static是internal linkage 來解釋...讓我整個無法通透理解
請教各位有什麼方法處理這問題
謝謝
作者: sarafciel (Cattuz)   2018-06-22 18:21:00
你對bar做模板特化 並不會幫你生整個class所以test.cpp要補Test()的特化; 你的extern才抓的到3跟4我不確定 感覺是undefined behavior 要查一下XD
作者: AstralBrain   2018-06-23 00:19:00
作者: lovejomi (JOMI)   2018-06-23 02:02:00
https://wandbox.org/permlink/GxVSjiLa8QEcM0t2是不是這樣寫最正確?這樣感覺這static變數變成externallinkage了?
作者: AstralBrain   2018-06-23 02:07:00
static member本來就是external linkage吧static variable和static member是不一樣的(雖然他們都叫static..)
作者: lovejomi (JOMI)   2018-06-23 14:48:00
謝謝,只是這個warning 我在編譯出binary後如果沒改程式碼再編一次就沒有warning了,為什麼呢
作者: AstralBrain   2018-06-23 23:08:00
因為沒有真的compile到? (亂猜的XD)
作者: Killercat (殺人貓™)   2018-06-24 16:03:00
incremental building 你re-compile或cleanup就有了
作者: lovejomi (JOMI)   2018-06-24 22:50:00
但這warning到底會不會對程式本身有可能有錯誤的風險呀?不理他感覺也沒怎樣
作者: Killercat (殺人貓™)   2018-06-25 10:59:00
他無法判斷會不會 比方說有個warning是not all control paths return a value 這個就是會讓你過 但是你是有可能有runtime issuey但是有些則是完全是murmur 這要自己判斷一下

Links booklink

Contact Us: admin [ a t ] ucptt.com