列表中元素位置的索引用的是L.index 本文實例講述了Python去除列表中重覆元素的方法。分享給大家供大家參考。具體如下: 比較容易記憶的是用內置的set l1 = ['b','c','d','b','c','a','a'] l2 = list(set(l1)) print (l2) 還有一種據 ...
最近做一個C++開源項目發現一個奇怪問題,通過clang編譯鏈接執行程式每到有一個就崩潰了,gcc下則沒有此問題。
後來通過調試,發現原因是bool返回的方法是沒有return語句!問題是為啥還能通過編譯呢?
列子如下:
#include <iostream> class Test { public: bool yes(); }; bool Test::yes() { std::cout << "yes" << std::endl; // return false; }; int main() { Test *t = new Test; bool r = t->yes(); std::cout << "yes->" << r << std::endl; return 0; }
用g++編譯得到警告但是通過了,並且執行得到正確預期(但是值為啥是64?沒有找到原因!)。
1 gaojie@root-host:~$ g++ bool.cpp 2 bool.cpp: In member function ‘bool Test::yes()’: 3 bool.cpp:11:1: warning: no return statement in function returning non-void [-Wreturn-type] 4 11 | }; 5 | ^ 6 gaojie@root-host:~$ ./a.out 7 yes 8 yes->64
用clang++編譯同樣類似警告也通過了,但執行出現異常指令。
gaojie@root-host:~$ clang++ bool.cpp bool.cpp:12:1: warning: non-void function does not return a value [-Wreturn-type] }; ^ 1 warning generated. gaojie@root-host:~$ ./a.out yes 非法指令 (核心已轉儲)
本著好奇的心理,就想知其原因為啥會有不一樣的結果呢?就想通過彙編語法查詢差異。
通過 https://godbolt.org/得到如下:
g++彙編指令如下:
clang++彙編指令如下:
通過yes方法發現差異了,
gcc彙編有return指令可以正常返回。
而clang就ud2指令結束了,查閱相關資料得到,UD2是一種讓CPU產生invalid opcode exception的軟體指令. 內核發現CPU出現這個異常, 會立即停止運行.
問題原因找到了就是gcc和llvm對編譯申明返回值方法而沒有返回語句的處理結果是不一樣的,g++保證通過而clang則認為無法處理(給了異常指令)退出程式。