1、三目运算符
a ? b : c //a为真,返回b;a为假,返回c
注:三目运算符不能作为左值使用,三目运算符最终返回的是一个值,而不是一个变量,如果作为左值使用,那就是两个常数相互赋值,明显错误。因此三目运算符只能作为右值使用。
#include <stdio.h>
int main()
{
int a = 1;
int b = 2;
int c = 0;
a < b ? a : b = 3; //error,三目运算符不能作为左值
c = a < b ? a : b;
//*(a < b ? &a : &b) = 3;
printf("a = %d\n", a); //1
printf("b = %d\n", b); //2
printf("c = %d\n", c); //1
return 0;
}
三目运算符的返回类型
— 通过隐式类型转换规则返回b和c中的较高类型
— 当b和c不能隐式转换到同一类型编译将出错
#include <stdio.h>
int main()
{
char c = 0;
short s = 0;
int i = 0;
double d = 0;
int* p = "str";
printf("%d\n", sizeof(c ? i : c)); //4
printf("%d\n", sizeof(i ? i : d)); //8
printf("%d\n", sizeof(d ? d : p)); //error
return 0;
}
2、逗号表达式
—— 逗号表达式用于将多个子表达式连接为一个表达式
—— 逗号表达式按照从左向右的顺序计算每一个子表达式的值
—— 逗号表达式前N-1个子表达式可以没有返回值
—— 逗号表达式的值为最后一个子表达式的值
exp1,exp2,exp3,exp4....expN
一行代码实现strlen的功能
#include <stdio.h>
#include <assert.h>
int strlen(const char* s)
{
return assert(NULL),*s ? strlen(s + 1) + 1 : 0; //递归
}
int main()
{
printf("len = %d\n", strlen("xiebs"));
printf("len = %d\n", strlen(NULL));
return 0;
}
s指向字符串的首地址,所以*s就是字符串的首字母,如果首字母不等于 \0,就进入strlen(s + 1)里面,相当于递归,s+1表示指针指向下一个元素(详情可以看第13课,单引号和双引号那章,刚好讲了字符串指针+1),后面的+1才算我们最后需要的值,等到s指向到 \0,再递归回来把所有的1相加,得到最终答案。这里还用到了assert为了防止空指针,所以用逗号表达式放在同一行。