顺序点
看下面兩條語句:
int i = 3;
int k=(++i)+(++i)+(++i);
??????? 執行后k的值是多少?不同的編譯器有不同的結果,可能是16(gcc),也可能是18(vc)。為什么會這樣呢?
??????? 在C++標準中有一個很重要的概念:sequence points(順序點)。原文定義如下:
At certain specified points in the execution sequence called sequence points, all side effects of previous evaluations shall be complete and no side effects of subsequent evaluations shall have taken place.
??????? 大致意思是說:在執行順序中某些指定的點叫做順序點。這個點上,之前所有的賦值所產生的副作用都已發生完成,并且在其后的賦值不能在該點產生任何副作用。
??????? 那么什么是副作用?C++標準指出:訪問一個由可變的左值(volatile lvalue)指派的對象(basic.lval),修改一個對象,調用庫I/O函數,或者調用函數等所有這些能夠改變執行環境的狀態的操作都是副作用。
??????? 聽起來感覺有些繞口而且不容易理解。那么來看看都有哪些點是順序點也許會幫助我們更好的理解。
??????? 那么在回過頭來看這條語句:
int k=(++i)+(++i)+(++i);
??????? 由于此處順序點就是分號,因此這條語句應該只修改一次i的值。對于多次的i自增值運算,由于標準并沒有明確定義,因此各個編譯器處理這種情況的方法也不同。這就出現了本文開頭的結果。
int i = 3;
int k=(++i)+(++i)+(++i);
??????? 執行后k的值是多少?不同的編譯器有不同的結果,可能是16(gcc),也可能是18(vc)。為什么會這樣呢?
??????? 在C++標準中有一個很重要的概念:sequence points(順序點)。原文定義如下:
At certain specified points in the execution sequence called sequence points, all side effects of previous evaluations shall be complete and no side effects of subsequent evaluations shall have taken place.
??????? 大致意思是說:在執行順序中某些指定的點叫做順序點。這個點上,之前所有的賦值所產生的副作用都已發生完成,并且在其后的賦值不能在該點產生任何副作用。
??????? 那么什么是副作用?C++標準指出:訪問一個由可變的左值(volatile lvalue)指派的對象(basic.lval),修改一個對象,調用庫I/O函數,或者調用函數等所有這些能夠改變執行環境的狀態的操作都是副作用。
??????? 聽起來感覺有些繞口而且不容易理解。那么來看看都有哪些點是順序點也許會幫助我們更好的理解。
- 分號;
- 未重載的逗號運算符的左操作數賦值之后(即“,”處);
- 未重載的”||”運算符的左操作數賦值之后(即“||”處);
- 未重載的“&&”運算符的左操作數賦值之后(即"&&"處);
- 三元運算符“? : ”的左操作數賦值之后(即“?”處);
- 在函數所有參數賦值之后但在函數第一條語句執行之前;
- 在函數返回值已拷貝給調用者之后但在該函數之外的代碼執行之前;
- 每個基類和成員初始化之后。
??????? 那么在回過頭來看這條語句:
int k=(++i)+(++i)+(++i);
??????? 由于此處順序點就是分號,因此這條語句應該只修改一次i的值。對于多次的i自增值運算,由于標準并沒有明確定義,因此各個編譯器處理這種情況的方法也不同。這就出現了本文開頭的結果。
總結
- 上一篇: 4月7号软件资讯更新合集....
- 下一篇: 【技术管理】谈谈管理风格