C說話中邏輯運算符與前提運算符的進修教程。本站提示廣大學習愛好者:(C說話中邏輯運算符與前提運算符的進修教程)文章只能為提供參考,不一定能成為您想要的結果。以下是C說話中邏輯運算符與前提運算符的進修教程正文
邏輯運算符
邏輯運算符,用於對包括關系運算符的表達式停止組合,構成新的表達式;成果也是只要真或假兩種情形,成果值用 BOOL 類型變量存儲。
* & (類型) sizeof
否認,按位否認,增量,減量,正負號,直接,取地址,類型轉換,求年夜小
&= ^= |= <<= >>=
各類賦值表達式1 邏輯運算符 表達式2
邏輯與:a >= b && a > 5 只要當運算符雙方為真的時刻這個表達式為真,一個表達式為假的時刻,表達式的成果就為假。
int a = 5; int b = 6; if(a >= b && a > 5) { printf("表達式為真\n"); } else { printf("表達式為假\n"); } int a = 5; int b = 6; if(a >= b && a > 5) { printf("表達式為真\n"); } else { printf("表達式為假\n"); }
年夜家可以試著轉變 a 和 b 的值看一下成果。
邏輯或:a >= b || a > 5 只需個中一個成果為真,這個表達式就為真。
int a = 6; int b = 7; if(a >= b || a > 5) { printf("表達式為真\n"); } else { printf("表達式為假\n"); } int a = 6; int b = 7; if(a >= b || a > 5) { printf("表達式為真\n"); } else { printf("表達式為假\n"); }
a >= b 為假,然則 a > 5 為真,所以會打印:表達式為真。
邏輯非:!a,假如 a 為真,那末 !a 為假,假如 a 為假,那末 !a 為真。
BOOL flag = YES; printf("!flag = %d\n", !flag); printf("flag = %d\n", flag); BOOL flag = YES; printf("!flag = %d\n", !flag); printf("flag = %d\n", flag);
第一行打印輸入:!flag = 0
第二行打印輸入:flag = 1
邏輯運算符的短路
邏輯與的短路:&& 左邊為假,右邊不介入運算。
例如:
int a = 6; int b = 0; if(a >= 10 && b = 5) { printf("表達式的值為真\n"); } printf("b = %d\n", b); int a = 6; int b = 0; if(a >= 10 && b = 5) { printf("表達式的值為真\n"); } printf("b = %d\n", b);
這裡 b 的輸入成果為:0,由於在表達式 a >= 10 && b = 5 中,a >= 6 為真,所以右邊的 b = 5 不介入運算,所以 b 還等於本來的 0。
邏輯或的短路:|| 左邊為真,右邊不介入運算。
例如:
int a = 6; int b = 0; if(a >= 6 || b = 5) { printf("表達式的值為真\n"); } printf("b = %d\n", b); int a = 6; int b = 0; if(a >= 6 || b = 5) { printf("表達式的值為真\n"); } printf("b = %d\n", b);
這裡 b 的輸入成果為:0,由於在表達式 a >= 6 || b = 5 中,a >= 6 為真,所以右邊的 b = 5 不介入運算,所以 b 還等於本來的 0。
前提運算符
符號是這個 ?: 一個問號和一個冒號,英文字符。C 說話中獨一的一個三目運算符。
由前提運算符構成前提表達式的普通情勢為:
前提表達式? 表達式1:表達式2
假如前提表達式為真,全部表達式的值為表達式1的值;
假如前提表達式為假,全部表達式的值為表達式2的值。
求三個數的最年夜值,應用前提運算符就是如許寫:
int a = 5; int b = 6; int c = 9; int max = a > b ? a : b; max = max > c ? max : c; //也能夠如許寫,加倍簡略 //int max = a > b ? (a > c ? a : c) : (b > c ? b : c); int a = 5; int b = 6; int c = 9; int max = a > b ? a : b; max = max > c ? max : c; //也能夠如許寫,加倍簡略 //int max = a > b ? (a > c ? a : c) : (b > c ? b : c);