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中明确规定了运算符的优先顺序,并以此来决定执行各种操作的顺序。(→与数学中加减乘除的执行顺序一样)

相关文章
|
17小时前
|
Java 编译器 C语言
【JavaSE】运算符详解及与C语言中的区别
【JavaSE】运算符详解及与C语言中的区别
54 0
|
17小时前
|
存储 编译器 C语言
初识C语言——详细入门(系统性学习day4)
初识C语言——详细入门(系统性学习day4)
|
17小时前
|
存储 程序员 C语言
C语言强制类型转换运算符
C语言强制类型转换运算符
13 1
|
17小时前
|
C语言
如何在C 语言中使用运算符sizeof
如何在C 语言中使用运算符sizeof
12 0
|
17小时前
|
算法 安全 C语言
C语言中的位操作运算符有什么作用
C语言中的位操作运算符有什么作用
19 0
|
17小时前
|
编译器 程序员 开发工具
c语言从入门到实战——在系统学习C语言之前所需要了解的知识
C语言是一种通用的、过程式的计算机编程语言,支持结构化编程、词汇变量作用域和递归等功能,其设计提供了低级别的存取权限,并且要求程序员管理所有的内存细节。C语言的基本构成包括数据类型(如整型、浮点型、字符型等)、运算符(如算术运算符、关系运算符、逻辑运算符等)、控制结构(如顺序结构、选择结构、循环结构等)以及函数等。此外,C语言还提供了指针的概念,这是其他许多编程语言所不具备的。指针是一个变量,其值为另一个变量的地址,通过指针可以间接访问和操作内存中的数据。C语言也支持数组、结构体、联合体等复合数据类型,以及文件操作、动态内存分配等高级功能。
54 0
|
17小时前
|
人工智能 测试技术 C语言
C语言学习
C语言学习
13 1
|
17小时前
|
程序员 C语言
【C语言】C语言运算符优先级详解
【C语言】C语言运算符优先级详解
|
17小时前
|
C语言
C语言5🔥:复合赋值,递增递减运算符,局部变量与全局变量
C语言5🔥:复合赋值,递增递减运算符,局部变量与全局变量
27 0
|
17小时前
|
C语言
C语言4🔥:运算符,运算符的基本用法
C语言4🔥:运算符,运算符的基本用法
34 0

热门文章

最新文章