运算符-------位运算符基本用法及面试题(6------3)

本文详细解析了左移(<<)、右移(>>)和无符号右移(>>>)位运算符的使用方法,通过实例展示了如何利用这些运算符进行快速的乘除运算,特别强调了位运算在效率上的优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.  >>        >>>       <<的用法:

           <<:左移    左边最高位丢弃,右边补齐0
           >>:右移    最高位是0,左边补齐0;最高为是1,左边补齐1
           >>>:无符号右移 无论最高位是0还是1,左边补齐0

2.求下列结果.

左移,向左移动几位就是乘以2的几次幂

System.out.println(12 << 1);       
System.out.println(12 << 2);       

System.out.println(12 << 1);		//24
System.out.println(12 << 2);		//48

转换为二进制:

            00000000 00000000 00000000 00001100		12的补码
	 (0)0000000 00000000 00000000 000011000		24的补码
	(00)000000 00000000 00000000 0000110000		48的补码

右移,向右移动几位就是除以2的几次幂

System.out.println(12 >> 1);
System.out.println(12 >> 2);

System.out.println(12 >> 1);     //6
System.out.println(12 >> 2);     //3


转换为二进制:

00000000 00000000 00000000 00001100		12的补码
000000000 00000000 00000000 0000110(0)	         6
0000000000 00000000 00000000 000011(00)          3

3.最有效率的算出2 * 8的结果

System.out.println(2 << 3);

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值