操作符详解

1.操作数的分类
2.二进制和进制转换

首先我们从十进制讲起,关于十进制有两点:

——十进制中满10进1

——十进制的数字每一位都是0-9的数字组成

其实二进制也是一样的

——2进制中满2进1

——2进制的数字每一位都是0-1的数字组成。

比如:1101就是二进制数字。那我们如何将二进制转换成十进制呢?

以1101为例:

那十进制转二进制呢?通常使用除二取余倒计法

2进制转8进制

8进制的数字每⼀位是0~7的,0~7的数字,各⾃写成2进制,最多有3个2进制位就⾜够了,⽐如7的⼆ 进制是111,所以在2进制转8进制数的时候,从2进制序列中右边低位开始向左每3个2进制位会换算⼀ 个8进制位,剩余不够3个2进制位的直接换算。

如:2进制的01101011,换成8进制:0153,0开头的数字,会被当做8进制。

2进制转16进制

16进制的数字每⼀位是0~9,a~f 的,0~9,a ~f 的数字,各⾃写成2进制,最多有4个2进制位就⾜够了, ⽐如f的⼆进制是1111,所以在2进制转16进制数的时候,从2进制序列中右边低位开始向左每4个2进 制位会换算⼀个16进制位,剩余不够4个⼆进制位的直接换算。

如:2进制的01101011,换成16进制:0x6b,16进制表⽰的时候前⾯加0x

3.原码,反码和补码

整数的2进制表示方式有三种即原码,反码,补码

有符号的整数的三种表示方式均有符号位和数值位两部分,2进制中序列最高的1位是被当做符号位,剩余的都是数值位。

符号位用0表示正,用1表示负

正整数的原,反,补码都相同。

负整数的原,反,补码都不相同。

原码:直接将数值按照正负数的形式翻译成二进制得到的就是原码。

反码:将原码的符号位不变,其他位依次按位取反就可以得到反码。

补码:反码+1就得到补码。

补码得到原码也是可以使用取反加1的操作

对于整型来说:数据存放在内存中其实存放的是补码

4.移位操作符

<<左移操作符

>>右移操作符

注:移位操作符的操作数只能是整数

左移操作符

移位规则:左边抛弃 ,右边补0

右移操作符

移位规则:首先右移分为两种:

1、逻辑右移:左边填充0,右边丢弃

2.算术右移:左边用该值的符号位填充,右边丢弃

可以看出我使用的VS2022是用的逻辑右移,其实大部分的编译器都是用的算术右移

算术右移就是:

注意:对于移位运算符,不要移动负数位,这个是标准未定义的。

5.位操作符

位操作符有:

他们的操作数必须是整数

与的计算规则是:有0出0,全1出1

或的计算规则是:有1出1,全0出0;

异或的计算规则是:相同出0,相异出1;

一个有意思的问题:

不能创建临时变量(第三个变量),实现两个整数的交换

我们就可以这样来实现:

从而我们就引出了异或操作符的特点:a^a = 0,a^0 = a

练习:编写代码实现:求一个整数存储在内存中的二进制中1的个数

#include<stdio.h>

int main()
{
  int n = -10;
//10000000 00000000 00000000 00001010原码
//11111111 11111111 11111111 11110101反码
// 
//11111111 11111111 11111111 11110110补码
//00000000 00000000 00000000 00000001
int count = 0;
int i = 0;
for (i = 0; i < 32; i++)
{
	if (n & (1 << i))
	{
		count++;
	}
}

printf("%d", count);
     
     return 0;   
}
6.逗号表达式

逗号表达式就是逗号隔开的多个表达式。

逗号表达式从左到右算,结果只取决于最后一个表达式。

例:

7.下标访问[ ],函数调用( )

下标引用操作符

操作数:一个数组名+一个索引值

函数调用操作符

接受一个或者多个操作数:第一个操作数是函数名,剩余的操作数就是传递给函数的参数。

()就是函数调用符,函数名和参数就是操作数

8.结构成员的访问操作符。

结构是一些值的集合,这些值称为成员变量。结构的每个成员可以是不同类型的变量,如:标量,数组,指针,甚至是其他结构体。

结构体的声明

比如描述一个学生:

当然我们也可以为他们初始化

结构体成员的直接访问是通过点操作符(.)来访问的。点操作符接受两个操作数;结构体变量(.)成员名

有时候我们得到的不是⼀个结构体变量,⽽是得到了⼀个指向结构体的指针,所以我们就用箭头符号来访问。使用方法:结构体指针->成员名

9.操作符的属性

C语⾔的操作符有2个重要的属性:优先级、结合性,这两个属性决定了表达式求值的计算顺序。

优先级:

优先级指的是,如果⼀个表达式包含多个运算符,哪个运算符应该优先执⾏。各种运算符的优先级是 不⼀样的。

结合性:

如果两个运算符优先级相同,优先级没办法确定先计算哪个了,这时候就看结合性了,则根据运算符 是左结合,还是右结合,决定执⾏顺序。⼤部分运算符是左结合(从左到右执⾏),少数运算符是右 结合(从右到左执⾏),⽐如赋值运算符( = )。

参考:https://zh.cppreference.com/w/c/language/operator_precedence

10.表达式求值

整形提升:

C语⾔中整型算术运算总是⾄少以缺省整型类型的精度来进⾏的。 为了获得这个精度,表达式中的字符和短整型操作数在使⽤之前被转换为普通整型,这种转换称为整 型提升。

b和c的值被提升为普通整型,然后再执⾏加法运算。

 加法运算完成之后,结果将被截断,然后再存储于a中。

如何进行整型提升呢?

1. 有符号整数提升是按照变量的数据类型的符号位来提升的

2.2. ⽆符号整数提升,⾼位补0

算术转换

如果某个操作符的各个操作数属于不同的类型,那么除⾮其中⼀个操作数的转换为另⼀个操作数的类 型,否则操作就⽆法进⾏。下⾯的层次体系称为寻常算术转换。

如果某个操作数的类型在上⾯这个列表中排名靠后,那么⾸先要转换为另外⼀个操作数的类型后执⾏ 运算。

感谢浏览

本篇博客代码:test_8_19.c · MonDays/C. - 码云 - 开源中国 (gitee.com)

  • 13
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
社会发展日新月异,用计算机应用实现数据管理功能已经算是很完善的了,但是随着移动互联网的到来,处理信息不再受制于地理位置的限制,处理信息及时高效,备受人们的喜爱。所以各大互联网厂商都瞄准移动互联网这个潮流进行各大布局,经过多年的大浪淘沙,各种移动操作系统的不断面世,而目前市场占有率最高的就是微信小程序,本次开发一套基于微信小程序的生签到系统,有管理员,教师,学生三个角色。管理员功能有个人中心,学生管理,教师管理,签到管理,学生签到管理,班课信息管理,加入班课管理,请假信息管理,审批信息管理,销假信息管理,系统管理。教师和学生都可以在微信端注册和登录,教师可以管理签到信息,管理班课信息,审批请假信息,查看学生签到,查看加入班级,查看审批信息和销假信息。学生可以查看教师发布的学生签到信息,可以自己选择加入班课信息,添加请假信息,查看审批信息,进行销假操作。基于微信小程序的生签到系统服务端用Java开发的网站后台,接收并且处理微信小程序端传入的json数据,数据库用到了MySQL数据库作为数据的存储。这样就让用户用着方便快捷,都通过同一个后台进行业务处理,而后台又可以根据并发量做好部署,用硬件和软件进行协作,满足于数据的交互式处理,让用户的数据存储更安全,得到数据更方便。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值