【C语言基础】:操作符详解(一)

文章目录

    • 操作符详解
      • 1. 操作符的分类
      • 2. 二进制和进制转换
        • 2.1 什么是二进制、八进制、十进制、十六进制
          • 2.1.1 二进制和进制转换
          • 2.1.2 二进制转十进制
          • 2.2.3 二进制转八进制
          • 2.2.4 二进制转十六进制
      • 3. 源码、反码、补码
      • 4. 移位操作符
        • 4.1 左移操作符
        • 4.2 右移操作符
      • 5. 位操作符:&、|、^、~
        • 5.1 按位与 &
        • 5.2 按位或 |
        • 5.3 按位异或 ^
        • 5.5 按位取反 ~

操作符详解

1. 操作符的分类

C语言中,操作符分为算术操作符赋值操作符逻辑操作符条件操作符单目操作符等等。

. 算术操作符:+ 、- 、* 、 %
. 移位操作符: << >>
. 位操作符: &、|、^
. 赋值操作符: = 、+= 、 -= 、 = 、 /= 、%= 、<<= 、>>= 、&= 、|= 、^=
. 单目操作符: ! 、++、–、&、、+、-、~ 、sizeof(类型)
. 关系操作符: > 、>= 、< 、<= 、 == 、 !=
. 逻辑操作符: && 、||
. 条件操作符: ? :
. 逗号表达式: ,
. 下标引用: []
. 函数调用: ()

2. 二进制和进制转换

2.1 什么是二进制、八进制、十进制、十六进制

在这里插入图片描述

2.1.1 二进制和进制转换

通俗来讲二进制、八 进制、 十进制、 十六进制是数值的不同表示形式而已。
比如:数值15的各种进制的表示形式:

152进制表现形式: 1111
158进制表现形式: 17
1510进制表现形式: 15
1516进制表现形式: F
//16进制的数值之前写:0x
//8进制的数值之前写:0
#include<stdio.h>
int main()
{
	printf("%d\n", 153);
	printf("%d\n", 0153);
	printf("%d\n", 0x153);
	return 0;
}

在这里插入图片描述

2.1.2 二进制转十进制

十进制的123表示的值是一百二十三 ,十进制的每一位是有权重的 ,十进制的数字从右向左是个位、十位、百位… ,分别每一位的权重是 100 , 101 , 102 …
在这里插入图片描述
二进制和十进制是类似的 ,只不过二进制的每—位的权重
在这里插入图片描述
十进制转二进制数字
在这里插入图片描述
进行转化的方法就是:这个数字%2,得到的余数写在一边,直到最后被除数为0时,再将数字从下往上抄上,这个数字即为十进制数字的二进制数
所以120转成二进制就是1111000

2.2.3 二进制转八进制

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

如:二进制的 01101011,换成八进制:0153,0开头的数字,会被当做八进制。
在这里插入图片描述

2.2.4 二进制转十六进制

十六进制的数字每一位是0 ~ 9,a ~ f 的,0~9,a ~ f的数字,各自写成二进制,最多有4个二进制位就足够了,比如 f 的二进制是1111,所以在二进制转十六进制数的时候,从二进制序列中右边低位开始向左每4个二进制位会换算一个十六进制位,剩余不够4个二进制位的直接换算。

如:二进制的01101011,换成十六进制:0x6b ,十六进制表示的时候前面加0x
在这里插入图片描述

3. 源码、反码、补码

整数的二进制表示方法有三种 ,即原码、反码和补码
有符号整数的三种表示方法均有符号位数值位两部分,二进制序列中,最高位的1位是被当做符号位,剩余的都是数值位。
符号位都是用0表示“正” ,用1表示“负”。

负整数的原码、反码、补码表示方法各不相同
原码:直接将数值按照正负数的形式翻译成二进制得到的就是原码。
反码:将原码的符号位不变,其他位依次按位取反就可以得到反码。
补码:反码+1就得到补码。
注意正数的原码、反码、补码相同
补码得到原码也是可以使用:取反,+1的操作。

对于整形来说:数据存放内存中其实存放的是补码
计算机中进行计算是使用补码,%d打印是用原码

这是因为在计算机系统中,数值一律用补码来表示和存储。原因在于,使用补码,可以将符号位和数值域统一 处理; 同时,加法和减法也可以统一处理(CPU只有加法器)此外,补码与原码相互转换,其运算过程是相同的,不需要额外的硬件电路。

#include<stdio.h>
int main()
{
	int a = 10;
	// a是整型,即a占4个字节(32bite)位
	// 00000000000000000000000000001010 -> a的原码
	// 00000000000000000000000000001010 -> a的反码
	// 00000000000000000000000000001010 -> a的补码
	int b = -10;
	// 10000000000000000000000000001010 -> b的原码
	// 11111111111111111111111111110101 -> b的反码
	// 11111111111111111111111111110110 -> b的补码
	return 0;
}

在这里插入图片描述

4. 移位操作符

左移操作符:<<
右移操作符:>>
:移位操作符的操作数只能是整数

4.1 左移操作符

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

#include<stdio.h>
int main()
{
	int a = 10;
	int b = a << 1;
	printf("b = %d\n", b);
	printf("a = %d\n", a);
	return 0;
}

在这里插入图片描述
在这里插入图片描述

可以看到左移一位有乘以2的效果。

4.2 右移操作符

移位规则:首先右移运算分两种:

  1. 逻辑右移:左边用0填充,右边丢弃
  2. 算术右移:左边用原该值的符号位填充,右边丢弃
    在这里插入图片描述

逻辑右移比较简单粗暴,直接在左边添0,显然,这会使得负数右移后变成正数。

在这里插入图片描述
算数右移与逻辑右移不同,它是在左边补原该值的符号位进行填充,不会出现负数右移变正数的情况。

#include<stdio.h>
int main()
{
	int a = -1;
	int b = a >> 1;
	printf("b = %d\n", b);
	printf("a = %d\n", a);
	return 0;
}

在这里插入图片描述
注意:右移是算数右移还是逻辑右移标准中没有规定,这是取决于编译器的。

5. 位操作符:&、|、^、~

位操作符有:

&       //按位与
|       //按位或
^       //按位异或
~       //按位取反

这里的位表示二进制位。
:他们的操作数必须是整数。

5.1 按位与 &

在 C 语言中,按位与运算符用符号 & 表示。
按位与的规则是:两个操作数对应的的二进制位中都为1时,结果为1,否则为0。

这里我们直接上代码

#include<stdio.h>
int main()
{
	int a = 10;
	int b = -7;
	int c = a & b;
	printf("%d\n", c);
	return 0;
}

在这里插入图片描述
在这里插入图片描述

5.2 按位或 |

在 C 语言中,按位或运算符用符号 | 表示。
按位或的规则是:两个操作数对应的的二进制位中任何一个对应的位为1,那么结果中的该位就为 1;只有当两个操作数的对应位都为 0 时,结果中的该位才为 0。

#include<stdio.h>
int main()
{
	int a = 10;
	int b = -7;
	int c = a | b;
	printf("%d\n", c);
	return 0;
}

在这里插入图片描述
在这里插入图片描述

5.3 按位异或 ^

在 C 语言中,按位异或运算符使用符号 ^ 表示。
按位异或的规则是:两个操作数中的对应位相同(都为 0 或都为 1),则结果中的该位为 0;如果两个操作数中的对应位不同(一个为 0,一个为 1),则结果中的该位为 1。

#include<stdio.h>
int main()
{
	int a = 10;
	int b = -7;
	int c = a ^ b;
	printf("%d\n", c);
	return 0;
}

在这里插入图片描述
在这里插入图片描述

5.5 按位取反 ~

在 C 语言中,按位取反运算符使用符号 ~ 表示。
按位取反规则是:当对一个操作数进行按位取反运算时,其二进制表示中的每个位都会被反转(0 变成 1,1 变成 0)。

#include<stdio.h>
int main()
{
	int a = 10;
	int b = ~a;
	printf("%d\n", b);
	return 0;
}

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/408854.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

IT廉连看——C语言——函数

IT廉连看——C语言——函数 一、函数是什么&#xff1f; 数学中我们常见到函数的概念。但是你了解C语言中的函数吗&#xff1f; 维基百科中对函数的定义&#xff1a;子程序 在计算机科学中&#xff0c;子程序&#xff08;英语&#xff1a;Subroutine, procedure, function, …

【Java】java异常处理机制(实验五)

目录 一、实验目的 二、实验内容 三、实验小结 一、实验目的 1、理解java的异常处理机制 2、掌握try catch结构和thow和thows关键字的用法 二、实验内容 1、编写一个程序&#xff0c;输入某个班某门课程成绩&#xff0c;统计及格人数、不及格人数及课程平均分。设计一个异…

H12-821_59

59.R1、R2、R3、R4运行IS-IS,它们接口的DIS Priority如图所示,假如设备同时启动,则()被选举为D1S.(请填写设备名称、例如R1) 答案&#xff1a;R4 注释&#xff1a; IS-IS中DIS的选举支持抢占。 假设题目说R4最后启动&#xff0c;问谁被选举为DIS&#xff0c;答案仍然是R4。

【嵌入式实践】【芝麻】【设计篇-1】从0到1给电动车添加指纹锁:项目设计思路

0. 前言 该项目是基于stm32F103和指纹模块做了一个通过指纹锁控制电动车的小工具。支持添加指纹、删除指纹&#xff0c;电动车进入P档等待时计时&#xff0c;计时超过5min则自动锁车&#xff0c;计时过程中按刹车可中断P档状态&#xff0c;同时中断锁车计时。改项目我称之为“芝…

NVIDIA Workbench 安装使用图文教程

NVIDIA Workbench 安装使用教程 文章目录 NVIDIA Workbench 安装使用教程1.安装1.1 下载软件1.2 安装软件 2.使用NVIDIA Workbench2.1 创建一个新项目 3.额外提示3.1 当我们没有停止直接关闭或者直接重启电脑后, 再打开我们已经创立的项目的时候可能会出现创建失败等错误信息.3…

Java核心-核心类与API(3)

话接上回&#xff0c;继续核心类与API的学习&#xff0c;这次介绍一下枚举类以及与系统、交互有关的类&#xff0c;需要了解并能使用即可。 一、枚举类 1、概述 枚举也称穷举&#xff0c;简单理解就是把所有可能一一列举出来&#xff08;穷尽所有可能&#xff09;。枚举是一…

申请攻读博士学位研究生相关模板资料(包括专家推荐信、学术简历、研究计划及范文、回复导师邮件)

申请攻读博士学位研究生相关模板资料&#xff08;包括专家推荐信、学术简历、研究计划及范文、回复导师邮件&#xff09; 博士是对攻读博士学位的研究生的称呼&#xff0c;同样也可用来称呼已获得博士学位的人员。 主要通过拥有博士点的普通高等学校和拥有博士研究生培养资格…

[SUCTF 2019]EasySQL1 题目分析与详解

一、题目介绍 1、题目来源&#xff1a; BUUCTF网站&#xff0c;网址&#xff1a;https://buuoj.cn/challenges 2、题目描述&#xff1a; 通过以上信息&#xff0c;拿到flag。 二、解题思路 首先打开靶机&#xff0c;尝试输入1查看回显&#xff0c;回显如图所示&#xff1a;…

图像读取裁剪与人脸识别

图像读取 Image read ⇒ \Rightarrow ⇒ torchvision.datasets from torchvision import datasets dataset datasets.ImageFolder(data_dir, transformtransforms.Resize((512, 512)))Return value illustration dataset[0][0]是PIL.Image objects&#xff0c;这利用IPyth…

数据结构-列表LinkedList

一,链表的简单的认识. 数组,栈,队列是线性数据结构,但都算不上是动态数据结构,底层都是依托静态数组,但是链表是确实真正意义上的动态数组. 为什么要学习链表? 1,链表时最简单的动态数据结构 2,掌握链表有助于学习更复杂的数据结构,例如,二叉树,trie. 3,学习链表有助于更深入…

LeetCode 1038.从二叉搜索树到更大和树

给定一个二叉搜索树 root (BST)&#xff0c;请将它的每个节点的值替换成树中大于或者等于该节点值的所有节点值之和。 提醒一下&#xff0c; 二叉搜索树 满足下列约束条件&#xff1a; 节点的左子树仅包含键 小于 节点键的节点。 节点的右子树仅包含键 大于 节点键的节点。 左…

js逆向-2

#md5加密&#xff0c;某宝案例演示。 #免责声明:本文仅供学习使用&#xff0c;请勿用于其他违法行为(╥ω╥)

软件性能测试和功能测试有何联系和区别?第三方软件检测机构简析

软件性能测试和功能测试是软件开发过程中非常重要的两个环节。从根本上说&#xff0c;它们都是为了保证软件质量和可靠性&#xff0c;但它们的目标和方法却有所不同。 软件性能测试是评估软件在特定负载下的性能表现&#xff0c;包括响应时间、吞吐量、并发能力等指标。它通过…

MySQL 学习记录 2

原文&#xff1a;https://blog.iyatt.com/?p13818 13 存储引擎 查看一下前面创建的一张表的创建语句&#xff0c;当时并没有显式指定引擎&#xff0c;MySQL 自动指定的 InnoDB&#xff0c;即默认引擎是这个。 创建表的时候要显式指定引擎可以参考这个语句 查看当前 MySQL …

如何正确使用Postman变量?又该如何灵活设置变量?

引言 Postman变量可以帮助你快速生成测试数据、模拟不同的场景和环境。 但是&#xff0c;如何正确使用Postman变量&#xff1f;又该如何灵活设置变量&#xff1f;这些问题不用担心&#xff0c;接着往下看吧&#xff01; 理解变量 为什么要使用变量&#xff1f; 如果在多个…

探索Java11新世界:JDK 11新特性详解

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …

设计模式篇---观察者模式

文章目录 概念结构实例总结 概念 观察者模式&#xff1a;定义对象之间的一种一对多的依赖关系&#xff0c;使得每当一个对象状态发生改变时&#xff0c;其他相关依赖对象都得到通知并被自动更新。 观察者模式是使用频率较高的一个模式&#xff0c;它建立了对象与对象之间的依赖…

一文读懂列表解析、字典解析、集合解析

一、所谓解析/解析式&#xff0c;也称为推导/推导式&#xff0c;对应英语单词为comprehension&#xff0c;是Python的一种独有特性。解析就是从一个数据序列构建另一个新的数据序列的结构体&#xff0c;其本质是使用一个可迭代对象&#xff0c;按一定规则通过表达式、函数等运算…

Git的基本操作和原理

目录 写在前面的话 为什么要有Git&#xff08;git初识&#xff09;&#xff1f; Git安装(Centos为例) Git基本操作 创建Git本地仓库 Git配置 认识工作区、暂存区、版本库 概念认识 添加文件 查看.git文件 修改文件 版本回退 撤销修改 情况一&#xff1a;…

[数据集][目标检测]游泳者溺水数据集VOC+YOLO格式2类别895张

数据集制作单位&#xff1a;未来自主研究中心(FIRC) 数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;895 标注数量(xml文件个数)&#xff1a…