短路現(xiàn)象1
比如有以下表達式
a && b && c
只有a為真(非0)才需要判斷b的值;只有a和b都為真,才需要判斷c的值。
舉例
求最終a、b、c、d的值。
main(){ int a,b,c,d; a = 0; b = 1; c = 2; d = a++ && b++ && --c; printf("a=%d b=%d c=%d d=%d\n",a,b,c,d);}
因為a++是先判斷a的值再自加,而a初始值為0, 所以(a++)為假,由短路現(xiàn)象可知&&后面式子b++和--c就都不會執(zhí)行;對于賦值語句,是先將a的值賦值給d,然后再自加,所以d的值為0,a最終為1。
執(zhí)行結果:
短路現(xiàn)象2
比如有以下表達式
a || b || c
只要a為真(非0)就不必判斷b和c;只有a為假,才需要判斷b的值;只有a和b都為假,才有必要判斷c的值。
舉例
求最終a、b、c、d的值;
main(){ int a,b,c,d; a = 0; b = 1; c = 2; d = a++ || b++ || --c; printf("a=%d b=%d c=%d d=%d\n",a,b,c,d);}
因為a++是先判斷a的值再自加,而a初始值為0, 所以(a++)為假,由短路現(xiàn)象可知,還需要繼續(xù)判斷 || 后面的表達式b++,b++要先判斷b的值,b為1,所以b++為真,由短路現(xiàn)象可知,后面的式子--c就不在執(zhí)行;對于賦值語句,不再是將a的值賦值給d,而是將b先賦值給d然后a和b再自加,所以d的值為1,a最終為1,b最終為2。
執(zhí)行結果: