一、三目运算符
三目运算符( a ? b : c)可以作为逻辑运算的载体
规则:当 a 的值为真时,返回 b 的值;否则返回 c 的值
下面看一段代码:
#includeint main() { int a = 1; int b = 2; int c = 0; c = a < b ? a : b; (a < b ? a : b) = 3; printf("%d\n", a); printf("%d\n", b); printf("%d\n", c); return 0; }
编译时会发现报错:
这是因为三目运算符返回的是值,而不是变量,所以报错。
看看下面做法,将地址作为三目运算符的返回,就可以:
#includeint main() { int a = 1; int b = 2; int c = 0; c = a < b ? a : b; *(a < b ? &a : &b) = 3; printf("%d\n", a); printf("%d\n", b); printf("%d\n", c); return 0; }
下面为输出结果:
三目运算符( a ? b : c)的返回类型
- 通过隐式类型转换规则返回 b 和 c 中的较高类型
- 当 b 和 c 不能隐式转换到同一类型时将编译出错
下面看一段代码,看看三目运算符的返回类型:
#includeint main() { char c = 0; short s = 0; int i = 0; double d = 0; char* p = "str"; printf( "%d\n", sizeof(c ? c : s) ); printf( "%d\n", sizeof(i ? i : d) ); //printf( "%d\n", sizeof(d ? d : p) ); return 0; }
下面为输出结果:
char 和 short 在一起,返回 int 类型,占 4 个字节。
关于 char 和 short 返回 int 类型,我的理解如下:
如果一个运算符两边的运算数类型不同,先要将其转换为相同的类型,即较低类型转换为较高类型,然后再参加运算,转换规则如下图所示。
double ←── float 高
↑
long
↑
unsigned
↑
int ←── char,short 低
二、逗号表达式
- 逗号表达式是C语言中的“粘贴剂”
- 逗号表达式用于将多个子表达式连接为一个表达式
- 逗号表达式的值为最后一个子表达式的值
- 逗号表达式中的前 N-1 个子表达式可以没有返回值
- 逗号表达式按照从左向右的顺序计算每个子表达式的值
如下:
下面看一个逗号表达式的示例:
#includevoid hello() { printf("Hello!\n"); } int main() { int a[3][3] = { (0, 1, 2), (3, 4, 5), (6, 7, 8) }; int i = 0; int j = 0; while( i < 5 ) printf("i = %d\n", i), hello(), i++; for(i=0; i<3; i++) { for(j=0; j<3; j++) { printf("a[%d][%d] = %d\n", i, j, a[i][j]); } } return 0; }
下面为输出结果:
为什么打印出来的 a 数组和我们预想的不一样呢,这是因为
int a[3][3] = {
(0, 1, 2), (3, 4, 5), (6, 7, 8)
};
里面的逗号构成了逗号表达式,逗号表达式的值为最后一个子表达式的值,相当于
int a[3][3] = {
2,
5,
8
};
而且,二维数组的初始化也不是那样,而是
int a[3][3] = {
{0, 1, 2},
{3, 4, 5},
{6, 7, 8}
};
这点一定要注意,不要弄错!!!
下面再来看一个一行代码实现 strlen :
#include#include int strlen(const char* s) { return assert(s), (*s ? strlen(s + 1) + 1 : 0); } int main() { printf("len = %d\n", strlen("Autumn")); printf("len = %d\n", strlen(NULL)); return 0; }
下面为输出结果:
三、小结
- 三目运算符返回变量的值,而不是变量本身
- 三目运算符通过隐式类型转换规则确认返回值类型
- 逗号表达式按照从左向右的顺序计算每个子表达式的值
- 逗号表达式的值为最后一个子表达式的值
到此这篇关于C语言简明讲解三目运算符和逗号表达式的使用的文章就介绍到这了,更多相关C语言 三目运算符内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!