C语言——运算符(学习分享)(一)

简介: C语言——运算符(学习分享)(一)
+关注继续查看

一、运算符


C语言中用运算符表示算数运算,跟数学中的运算大致相同,只不过由于C数据类型的限制有了些许的调整,下面介绍一下基本运算符以及其他运算符(C没有指数运算符,但是C的标准数学库提供了pow()函数用于指数运算。例如pow(2,3)表示返回2的3次幂(即为8))


二、基本运算符


2.1赋值运算符:=

2.1.1赋值

C语言中“=”不是“等于”、“相等”的意思,它是一个赋值运算符。

比如下面的赋值表达式语句:

digit = 2022;

意思是把2022这个数赋值给变量digit。等号(=)左侧是一个变量名,右侧是赋给这个变量的值。读作“把值2022赋给变量digit”,而不是“digit等于2022”。


上面这个例子看上去读作什么没有多少区别,但是看下面这个例子:


i = i + 1;//另一种写法:i += 1

在数学上这个表达式完全行不通,但是在C赋值表达式语句中,这非常合理。如何解释呢?

→先找出变量i的值,把这个值+1,再把新值赋给变量i,此时变量i存储的值就从比原来大1了


2.1.2左值和右值(简单讲)

C中这样的语句是无效的↓

2022 = digit
C语言中,=左侧必须是一个可修改的左值(变量名或指针),这样才可以引用一个存储位置
右值是指能赋值给左值的量,但是它本身不是左值


在这个例子中,digit是变量;而2022是字面常量,本身就是一个确定的值,错的显而易见


2.2加法、减法运算符:+ -

+-的运算对象可以是常量,也可以是变量

加(减)法运算符+(-):跟数学中的加(减)法一样,“+”(“-”)表示其两侧是值相加(减)

比如↓

printf("%d",2+8);//打印的是10,不是表达式2+8
int a = 1;
int b = 20;
int n = a + b;
printf("%d",n);//打印的值是21
//在这里a,b,n都是可修改的左值,而表达式a + b是一个右值


减法同理,这里就不多赘述了~

+和-运算符都是二元运算符(二元:即运算符需要两个运算对象)


2.3符号运算符(+和 -)

减号(-)还可以改变or标明一个值的符号

num = -5;
num2 = -num1  //最后num2的值是5


“-”在这样的用法中是一元运算符,只需要一个运算对象

PS:

num_s = +6//没必要这样写,但是编译器也不会报错

2.4乘法、除法运算符:* /

乘法

*表示乘法。乘法运算符跟数学中的乘法一样,“*”表示其两侧是值相乘


除法

C中用/表示除法。/左侧的值是被除数,右侧的则是除数

与数学中除法不同,由于C中数据类型的不同,除法可分为整数除法和浮点数(即小数)除法。

例1:

int a = 6;
int b = 2;
printf("%d",a/b); //非常常规,打印结果为3


例2:

int num1 = 9;
int num2 = 2;
printf("%d",num1/num2);  //打印结果是4
//因为这里num1和num2都是int类型(整型) 
//整数是没有小数部分的数
//因此在C中,整数除法结果如果有小数,那么小数部分会被丢弃(不是四舍五入),只保留整数部分
//(这个过程叫做“截断”)


例三:

double n = 20.6;
double m = 3;
printf("%lf",n/m);//double对应%lf
//打印结果是6.866667
//C中输出double类型或float类型时默认输出6位小数(不足六位用0补齐,超过六位按四舍五入截断)


这里补充一点,虽然默认输出6位小数,但如果要指定输出n位小数,那么可以用%.nlf的格式(对于float类型则是%.nf)。其中n为数字。

例如,想要只输出3位小数:

printf("%.3lf\n", n/m);
//输出结果就变成了6.867


例四:

整数和浮点数混和运算的结果是浮点数

double k = 6.9;
int j = 3;
printf("%d",sizeof(k/j) );
//打印结果为8,即double类型的字节长度
//sizeof运算符在下面的3.1中会讲
printf("%lf",k/j);
//打印结果为2.300000


2.5优先级

执行各种操作的顺序很重要

思考一下,下面这个表达式的结果是什么呢

sum = 2.0 + 16*(9/6)

要知道,先运算2.0 + 16再*(9/6),跟先算16*(9/6)再+2结果是不一样的。

因此C中明确规定了运算符的优先顺序,并以此来决定执行各种操作的顺序。(→与数学中加减乘除的执行顺序一样)

相关文章
|
28天前
|
编译器 C语言
09 C语言 - 运算符
09 C语言 - 运算符
6 0
|
2月前
|
编译器 C语言
C语言进阶教程(#运算符和##运算符)
C语言进阶教程(#运算符和##运算符)
21 0
|
2月前
|
编译器 C语言
操作符的属性,C语言中运算符的优先性和结合性,常见的问题表达式
操作符的属性,C语言中运算符的优先性和结合性,常见的问题表达式
|
3月前
|
存储 C语言
C语言入门(2)——数据类型、运算符、类型转换、控制语句
char short int long flout(默认保存小数点后6位,并且可以四舍五入) double 输出int类型的值%d 输出字符用%c 输出long用%ld 输出float用%f 输出double用%lf
80 0
|
4月前
|
存储 C语言
C语言之运算符的详解
C语言之运算符的详解
33 0
|
5月前
|
存储 数据处理 C语言
C语言实验二 数据类型、运算符和表达式
C语言实验二 数据类型、运算符和表达式
60 0
|
6月前
|
C语言
C语言之运算符用法(补充前面运算符中的不足)
C语言之运算符用法(补充前面运算符中的不足)
|
6月前
|
C语言
|
6月前
|
C语言
C语言——运算符(学习分享)(二)
C语言——运算符(学习分享)(二)
64 0
|
6月前
|
存储 编译器 C语言
关于c语言等于运算符的一点思考
关于c语言等于运算符的一点思考
53 0
相关产品
云迁移中心
推荐文章
更多