三元运算符,也称为条件运算符,是唯一具有三个操作数的运算符,有时称为三元运算符。三元运算符的组合是右组合;逗号表达式,是C语言中的逗号运算符,优先级最低。它连接两个或多个公式,并从左到右逐个计算表达式。整个表达式的值就是最后一个表达式的值。
目录
I、三元运算符II、逗号表达式III、摘要
一、三目运算符
三元运算符(a?B: c)可以作为逻辑运算的载体
规则:当A的值为真时,返回B的值;否则,返回c的值。
请看下面的代码:
#包含stdio.h
int main()
{
int a=1;
int b=2;
int c=0;
c=a b?甲:乙;
(a b?a:b)=3;
printf('%d\n ',a);
printf('%d\n ',b);
printf('%d\n ',c);
返回0;
}
编译时,您会发现一个错误:
这是因为三元运算符返回一个值,而不是一个变量,所以会报告一个错误。
看下面的练习,将地址作为三元运算符返回,就可以:
#包含stdio.h
int main()
{
int a=1;
int b=2;
int c=0;
c=a b?甲:乙;
*(a b?a:b)=3;
printf('%d\n ',a);
printf('%d\n ',b);
printf('%d\n ',c);
返回0;
}
以下是输出结果:
三元运算符(a?b:c)的返回类型
通过隐式类型转换规则返回B和C中较高的类型。当B和C不能隐式转换为同一类型时,将发生编译错误。
查看以下代码,了解三元运算符的返回类型:
#包含stdio.h
int main()
{
char c=0;
短s=0;
int I=0;
双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));
返回0;
}
以下是输出结果:
用charshort,返回int类型,核算char 4字节。
关于char和short返回int类型,我的理解如下:
如果一个运算符两边的操作数类型不同,就要转换成相同的类型,也就是把较低的类型转换成较高的类型,然后参与运算。转换规则如下图所示。
Double 浮动高度
长的
无符号的
Int char,short low
二、逗号表达式
逗号表达式是C语言中的“贴纸”。逗号表达式用于将多个子表达式连接成一个表达式。逗号表达式的值是最后一个子表达式的值。逗号表达式中的前N-1个子表达式不能有返回值。逗号表达式从左到右计算每个子表达式的值。
如下所示:
请看下面的逗号表达式示例:
#包含stdio.h
void hello()
{
printf(‘你好!\ 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),
你好(),
我;
for(I=0;i3;我)
{
for(j=0;J3;j)
{
printf('a[%d][%d]=%d\n ',I,j,a[I][j]);
}
}
返回0;
}
以下是输出结果:
为什么打印出来的数组A和我们预期的不一样?这是因为
int a[3][3]={
(0, 1, 2), (3, 4, 5), (6, 7, 8)
};
里面的逗号构成一个逗号表达式,逗号表达式的值是最后一个子表达式的值,相当于
int a[3][3]={
2,
5,
八
};
而且,二维数组的初始化不是这样的,而是
int a[3][3]={
{0, 1, 2},
{3, 4, 5},
{6, 7, 8}
};
这一点一定要注意,不要搞错了!
让我们来看看实现strlen的一行代码:
#包含stdio.h
#include assert.h
int strlen(const char* s)
{
返回断言。strlen(S1)1:0);
}
int main()
{
printf('len=%d\n ',strlen(' Autumn ');
printf('len=%d\n ',strlen(NULL));
返回0;
}
以下是输出结果:
三、小结
三元运算符返回变量的值,而不是变量本身。三元运算符通过隐式类型转换规则确认返回值的类型。逗号表达式从左到右计算每个子表达式的值。逗号表达式的值是最后一个子表达式的值。
关于C语言对三元运算符和逗号表达式用法的简明解释,本文到此为止。有关C语言中三元运算符的更多信息,请搜索我们以前的文章或继续浏览下面的相关文章。希望大家以后能多多支持我们!
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。