前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >c语言中的移位运算符能用于浮点型吗_c语言移位运算符与运算用法

c语言中的移位运算符能用于浮点型吗_c语言移位运算符与运算用法

作者头像
全栈程序员站长
发布于 2022-11-01 01:37:58
发布于 2022-11-01 01:37:58
1.5K00
代码可运行
举报
运行总次数:0
代码可运行

大家好,又见面了,我是你们的朋友全栈君。

移位运算符在程序设计中,是位操作运算符的一种。移位运算符可以在二进制的基础上对数字进行平移。 c语言中提供了两种移位运算符: 左移运算符:<< 右移运算符:>>

左移运算符(<<)
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
int main(void)
{ 
   
	int a = 4;
	//把a的二进制位向左移动1位
	int b = a << 1;
	printf("b = %d", b);
	return 0;
}

Jetbrains全家桶1年46,售后保障稳定

在32位操作系统中,int类型占4个字节,1个字节有8bit,所以变量a在内存中占32个比特位。 将4赋值给变量a,a中存放的是4的二进制形式。

将a向左移动一位

最高位的0丢弃,末位补0

可以看到a左移一位后的结果是1000,转换成10进制就是8,所以打印b的结果就是8。

右移运算符(>>)
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
int main(void)
{ 
   
	int a = 10;
	//把a的二进制位向右移动1位
	int b = a >> 1;
	printf("b = %d", b);
	return 0;
}

把10赋值给变量a,将10表示成二进制形式

将10向右移动一位,最低位的0丢弃

最高位补0

最后的结果转换成10进制就是5

我们可以看到最后打印b的结果确实是5。

这里需要注意的是,右移分为算数右移和逻辑右移 算数右移: 右边丢弃,左边补原符号位 逻辑右移: 右边丢弃,左边补0 内存中存放二进制序列的时候,最高位是0表示正数,最高位是1表示负数。 因为10是正数,所以无论是算数右移还是逻辑右移,最高位都是补0。那么这里的右移运算到底是算数右移还是逻辑右移呢? 整数的二进制表示形式有三种:原码、反码、补码 原码:直接根据数值写出的二进制序列 反码:原码的符号位不变,其他位按位取反 补码:反码加1 计算机内存数值存储方式是补码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
int main(void)
{ 
   
	int a = -1;
	//把a的二进制位向右移动1位
	int b = a >> 1;
	printf("b = %d", b);
	return 0;
}

以-1为例 -1的原码:

-1的反码:

-1的补码:

因为计算机中存储的是补码,将-1右移1位,最低位的1舍弃

先来看b的打印结果

b的值为-1,说明最高位补的是1,此时进行的是算数右移。 需要注意的是,虽然a进行了右移操作,但是a的值是不发生改变的,我们可以将a也打印出来

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
int main(void)
{ 
   
	int a = 10;
	//把a的二进制位向右移动1位
	int b = a >> 1;
	printf("a = %d\n", a);
	printf("b = %d", b);
	return 0;
}

a的结果仍然是10。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
int a = 10;
int b = a + 1;

和上面的代码是一样的,在进行移位运算的时候,移位对象的值并不会发生改变

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/203604.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月23日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
c语言中位运算符的用法_c语言中位运算符的优先级
程序中的所有数在计算机内存中都是以二进制的形式储存的。位运算说穿了,就是直接对整数在内存中的二进制位进行操作。运位算包括位逻辑运算和移位运算,位逻辑运算能够方便地设置或屏蔽内存中某个字节的一位或几位,也可以对两个数按位相加等;移位运算可以对内存中某个二进制数左移或右移几位等。
全栈程序员站长
2022/11/10
8160
Java移位运算符
移位运算符就是在二进制的基础上对数字进行平移。按照平移的方向和填充数字的规则分为三种:<<(左移)、>>(带符号右移)和>>>(无符号右移)。   在移位运算时,byte、short和char类型移位后的结果会变成int类型,对于byte、short、char和int进行移位时,规定实际移动的次数是移动次数和32的余数,也就是移位33次和移位1次得到的结果相同。移动long型的数值时,规定实际移动的次数是移动次数和64的余数,也就是移动66次和移动2次得到的结果相同。 三种移位运算符的移动规则和使用如下所示: <<运算规则:按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零。 语法格式:   需要移位的数字 << 移位的次数   例如: 3 << 2,则是将数字3左移2位 计算过程:   3 << 2   首先把3转换为二进制数字0000 0000 0000 0000 0000 0000 0000 0011,然后把该数字高位(左侧)的两个零移出,其他的数字都朝左平移2位,最后在低位(右侧)的两个空位补零。则得到的最终结果是0000 0000 0000 0000 0000 0000 0000 1100,则转换为十进制是12.数学意义:   在数字没有溢出的前提下,对于正数和负数,左移一位都相当于乘以2的1次方,左移n位就相当于乘以2的n次方。 >>运算规则:按二进制形式把所有的数字向右移动对应巍峨位数,低位移出(舍弃),高位的空位补符号位,即正数补零,负数补1. 语法格式:   需要移位的数字 >> 移位的次数   例如11 >> 2,则是将数字11右移2位 计算过程:11的二进制形式为:0000 0000 0000 0000 0000 0000 0000 1011,然后把低位的最后两个数字移出,因为该数字是正数,所以在高位补零。则得到的最终结果是0000 0000 0000 0000 0000 0000 0000 0010.转换为十进制是3.数学意义:右移一位相当于除2,右移n位相当于除以2的n次方。 >>>运算规则:按二进制形式把所有的数字向右移动对应巍峨位数,低位移出(舍弃),高位的空位补零。对于正数来说和带符号右移相同,对于负数来说不同。   其他结构和>>相似。   小结   二进制运算符,包括位运算符和移位运算符,使程序员可以在二进制基础上操作数字,可以更有效的进行运算,并且可以以二进制的形式存储和转换数据,是实现网络协议解析以及加密等算法的基础。 实例操作:   public class URShift {   public static void main(String[] args) {   int i = -1;   i >>>= 10;   //System.out.println(i);   mTest();   }   public static void mTest(){   //左移   int i = 12; //二进制为:0000000000000000000000000001100   i <<= 2; //i左移2位,把高位的两位数字(左侧开始)抛弃,低位的空位补0,二进制码就为0000000000000000000000000110000   System.out.println(i); //二进制110000值为48;   System.out.println("<br>");   //右移   i >>=2; //i右移2为,把低位的两个数字(右侧开始)抛弃,高位整数补0,负数补1,二进制码就为0000000000000000000000000001100   System.out.println(i); //二进制码为1100值为12   System.out.println("<br>");   //右移example   int j = 11;//二进制码为00000000000000000000000000001011   j >>= 2; //右移两位,抛弃最后两位,整数补0,二进制码为:00000000000000000000000000000010   System.out.println(j); //二进制码为10值为2   System.out.println("<br>");   byte k = -2; //转为int,二进制码为:0000000000000000000000000000010   k >>= 2; //右移2位,抛弃最后2位,负数补1,二进制吗为:11000000000000000000000000000   System.out.println(j); //二进制吗为11值为2   }   }   在Thinking in Java第三章中的一段话:   移位运算符面向的运算对象也是   二进制
大道七哥
2019/09/10
1.5K0
【修正】深入理解C#位运算:掌握位运算符的妙用
C#位运算是一种强大的工具,可以在处理二进制数据和位操作时发挥重要作用。通过使用位运算符,我们可以对整数进行位级别的操作,如位与、位或、位异或和位取反等。位运算可以用于优化性能、压缩数据、实现位掩码和位标志等。了解和掌握C#位运算的基本原理和常见应用场景,将使我们能够更高效地处理二进制数据,并在某些情况下提高代码的性能和可读性。通过深入理解C#位运算,我们可以在编程中发挥更大的创造力和灵活性。
沙漠尽头的狼
2023/11/13
4320
【修正】深入理解C#位运算:掌握位运算符的妙用
位运算符&移位运算符
按位操作符用来操作整数基本数据类型中的单个比特(bit),就是二进制,按位操作符会对两个参数中对应的位(bit)执行布尔运算,最终生成一个结果。下面我们来看一下都有哪些位运算符。
roobtyan
2019/02/21
1.7K0
位运算符&移位运算符
Java编程(位运算符)
二进制运算符   由于计算机内部的数据都以二进制的形式存在,所以在Java语言中提供了直接操作二进制的运算符,这就是下面要讲解的位运算符和移位运算符。   使用二进制的运算符,可以直接在二进制的基础上对数字进行操作,执行的效率比一般的数学运算符高的多,该类运算符大量适用于网络编程、硬件编程等领域。   二进制运算符在数学上的意义比较有限。   在Java代码中,直接书写和输出的数值默认是十进制,Java代码中无法直接书写二进制数值,但是可以书写八进制和十六进制数字,八进制以数字0开头,例如016,十六进制以
cloudskyme
2018/03/20
1.3K0
【面试题精讲】Java移位运算符
在 Java 中,移位运算符用于对二进制数进行位移操作。它们可以将一个数的所有位向左或向右移动指定的位数。
程序员朱永胜
2023/09/28
4440
c语言中位运算符_位运算符的用法
C语言的运算符是一个很有意思的东西,运用起来可以解决很多麻烦的事,但是想要灵活应用也有一定的难度,总结一下c语言运算符的用法和一些常用技巧.
全栈程序员站长
2022/11/09
8990
C 语言中负数移位运算讲解
C 语言中负数移位运算讲解 “<<”、“>>”为移位运算符。 “<<”为左移位运算符,即数据字节中的每个二进制位同时 向左移位。如“x<<n”表示 x 中的每个二进制位同时向左移动 n 位。 “>>”为右移位运算 符,即数据字节中的每个二进制位同时向右移位。如“x>>n”表示 x 中的每个二进制位同时 向右移动 n 位。 下图演示了一个 2 字节变量左移 3 位的过程: 十进制数-555 的二进制表: 1 0 0 0 0 0 1 0 0 0 1 0 1 0 1 1 先转换成二进制补码表: 1 1 1 1 1 1 0 1 1 1 0 1 0 1 0 0 最左端位保持不变 补码加“1”后状态 再将补码加“1”: 1 1 1 1 1 1 0 1 1 1 0 1 0 1 0 1 下一步向左移 3 位: 1 1 1 0 1 1 1 0 1 0 1 0 1 0 0 0 左端“离开”3 位丢弃 右端“移入”3 位用“0”补齐 最左端一位保持不变 再转换成二进制补码表: 1 0 0 1 0 0 0 1 0 1 0 1 0 1 1 1 补码再加“1”: 到此步结束。 1 0 0 1 0 0 0 1 0 1 0 1 1 0 0 0 补码加“1”后状态 结果转换成十进制数为“- 4440”。 总结:负数左移时,任何情况下“移入”位将用“0”补齐。 “>>”右移位运算可分为两种情况:一种是移入“0”的叫逻辑右移;一种是移入“1”的叫 算术右移。 负数右移用到的是算术右移。 下图演示了一个 2 字节变量右移 3 位的过程: 十进制数-555 的二进制表: 1 0 0 0 0 0 1 0 0 0 1 0 1 0 1 1 先转换成二进制补码表: 1 1 1 1 1 1 0 1 1 1 0 1 0 1 0 0 最左端位保持不变 补码加“1”后状态 再将补码加“1”: 1 1 1 1 1 1 0 1 1 1 0 1 0 1 0 1 下一步向右移 3 位: 1 1 1 1 1 1 1 1 1 0 1 1 1 0 1 0 左端“移入”3 位用“1”补齐 右端“离开”3 位丢弃 最左端一位保持不变 再转换成二进制补码表: 1 0 0 0 0 0 0 0 0 1 0 0 0 1 0 1 补码再加“1”: 到此步结束。 1 0 0 0 0 0 0 0 0 1 0 0 0 1 1 0 补码加“1”后状态 结果转换成十进制数为“- 70”。 总结:负数右移时,任何情况下“移入”位将用“1”补齐。 注:二进制表最左端的二进制位表示符号位,“+”用“0”表示,“-”用“1”表示。
全栈程序员站长
2022/09/14
2.5K0
【Java探索之旅】运算符解密 位运算,移位运算
java 中数据存储的最小单位是字节,而数据操作的最小单位是比特位. 字节是最小的存储单位,每个字节是由8个二进制比特位组成的,多个字节组合在一起可以表示各种不同的数据。
屿小夏
2024/03/18
1530
【Java探索之旅】运算符解密 位运算,移位运算
深入理解C#位运算:掌握位运算符的妙用
C#位运算是一种强大的工具,可以在处理二进制数据和位操作时发挥重要作用。通过使用位运算符,我们可以对整数进行位级别的操作,如位与、位或、位异或和位取反等。位运算可以用于优化性能、压缩数据、实现位掩码和位标志等。了解和掌握C#位运算的基本原理和常见应用场景,将使我们能够更高效地处理二进制数据,并在某些情况下提高代码的性能和可读性。通过深入理解C#位运算,我们可以在编程中发挥更大的创造力和灵活性。
沙漠尽头的狼
2023/11/07
8480
深入理解C#位运算:掌握位运算符的妙用
详解Python中的位运算符规则、原理与用法
在Python中,位运算符包括位与(&)、位或(|)、位求反(~)、位异或(^)、左移位(<<)和右移位(>>)。 1. 运算方法与规则 位运算符只能适用于整数,其总体运算规则为:首先把整数转换为二进制表示形式,按最低位对齐,短的高位补0,然后进行位运算,最后把得到的二进制转换为十进制数。 位与运算符运算规则:0&0=0&1=1&0=0,1&1=1 位或运算符运算规则:0|1=1|0=1|1=1,0|0=0 位求反运算符运算规则:~0=1,~1=0,对于整数x有~x=-(x+1) 位异或运算符运算规则:
Python小屋屋主
2018/04/17
3.3K0
C语言位运算符详解「建议收藏」
C语言既具有高级语言的特点,又具有低级语言的特性,如支持位运算就是其具体体现。这是因为,C语言最初是为取代汇编语言设计系统软件而设计的,因此C语言必须支持位运算等汇编操作。位运算就是对字节或字内的二进制数位进行测试、抽取、设置或移位等操作。其操作对象不能是float、double、long double等其他数据类型,只能是char和int类型。 C语言提供如下表格的六种位运算符,其中,只有按位取反运算符为单目运算符,其他运算符都是双目运算符。
全栈程序员站长
2022/11/10
3.4K0
C语言位运算符详解「建议收藏」
C语言位操作 | 按位运算符
C语言中可以单独操控变量中的位,例如:通常向硬件设备发送一两个字节来操控这些设备,每个位(bit)都有特定的含义,另外,与文件相关的操作信息经常被存储,通过特定的位表明特定的项。许多的压缩和加密操作都是直接除理单独的位。
CtrlX
2023/03/21
1.4K0
操作符详解(这么详细的操作符介绍你确定不看一看?)【C语言】【附试题详解】
操作符的分类:算数操作符、移位操作符、位操作符、赋值操作符、单目操作符、关系操作符、逻辑操作符、条件操作符、逗号表达式、(下标引用、函数调用和结构成员)。
see.
2024/06/04
1020
操作符详解(这么详细的操作符介绍你确定不看一看?)【C语言】【附试题详解】
Java移位运算符 << >> >>>
首先,移位运算符根据名字可知是使用二进制进行运算的。在Integer.java中,我们可以看到有两个静态常量,MIN_VALUE 和 MAX_VALUE,这两个常量控制了Integer的最小值和最大值,如下:
Johnson木木
2019/10/24
6190
Java 中的移位运算符(Shift Operator)
针对移位(Shift Operator)操作符是最基本的操作符之一,几乎每种编程语言都包含这一操作符。
HoneyMoose
2023/09/04
1.6K0
Java 中的移位运算符(Shift Operator)
位运算
之前我们在进制里面讲到了机器数、原码反码和补码以及负二进制为什么要用三种形式来表现。
用户7272142
2023/10/11
2160
位运算
位运算符的操作机制
        位操作是程序操作中对位模式按位或二进制数的一元和二元操作。 在许多古老的微处理器上, 位运算比加减运算略快, 通常位运算比乘除法运算要快很多。 在现代架构中, 情况并非如此:位运算的运算速度通常与加法运算相同(仍然快于乘法运算).
渴望飞翔的猪
2022/07/17
5030
Java中的位运算
在阅读原码的过程中会看到大量的>>, <<, ^, &, |等运算操作符,我们必须先明白这些运算符的意思才能继续读原码。当然,这些都属于基础知识,基本都学过,这里也就属于复习一下。
科技新语
2024/12/31
670
Java中的位运算
关于原码,反码,补码,及位操作符的概念
在计算机中数据是通过二进制的方式存储的,所以就必然会有关于他们之间的存储方式和计算方法。
用户11070251
2024/04/11
1700
关于原码,反码,补码,及位操作符的概念
相关推荐
c语言中位运算符的用法_c语言中位运算符的优先级
更多 >
领券
社区富文本编辑器全新改版!诚邀体验~
全新交互,全新视觉,新增快捷键、悬浮工具栏、高亮块等功能并同时优化现有功能,全面提升创作效率和体验
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文