用java中的位运算符如何将一个整数110从右端开始的4~7位变为0.

用java中的位运算符如何将一个整数110从右端开始的4~7位变为0.,第1张

运算符 含义 示例

~ 按位非(NOT) b = ~a

&按位与(AND) c = a & b

| 按位或(OR) c = a | b

^ 按位异或(XOR) c = a ^ b

>>右移 b = a >> 2

>>>右移,左边空出的位以0填充 b = a >>> 2

<<左移 b = a << 1

当然同样有 &=,|=,^=,>>=,>>>=,<<=。

有关这些 *** 作的细节可以参看

位运算

前面介绍的各种运算都是以字节作为最基本位进行的。 但在很多系统程序中常要求在位(bit)一级进行运算或处理。C语言提供了位运算的功能, 这使得C语言也能像汇编语言一样用来编写系统程序。

一、位运算符C语言提供了六种位运算符:

& 按位与

| 按位或

^ 按位异或

~ 取反

<< 左移

>> 右移

1. 按位与运算 按位与运算符"&"是双目运算符。其功能是参与运算的两数各对应的二进位相与。只有对应的两个二进位均为1时,结果位才为1 ,否则为0。参与运算的数以补码方式出现。

例如:9&5可写算式如下: 00001001 (9的二进制补码)&00000101 (5的二进制补码) 00000001 (1的二进制补码)可见9&5=1。

按位与运算通常用来对某些位清0或保留某些位。例如把a 的高八位清 0 , 保留低八位, 可作 a&255 运算 ( 255 的二进制数为0000000011111111)。

main(){

int a=9,b=5,c

c=a&b

printf("a=%d\nb=%d\nc=%d\n",a,b,c)

}

2. 按位或运算 按位或运算符“|”是双目运算符。其功能是参与运算的两数各对应的二进位相或。只要对应的二个二进位有一个为1时,结果位就为1。参与运算的两个数均以补码出现。

例如:9|5可写算式如下: 00001001|00000101

00001101 (十进制为13)可见9|5=13

main(){

int a=9,b=5,c

c=a|b

printf("a=%d\nb=%d\nc=%d\n",a,b,c)

}

3. 按位异或运算 按位异或运算符“^”是双目运算符。其功能是参与运算的两数各对应的二进位相异或,当两对应的二进位相异时,结果为1。参与运算数仍以补码出现,例如 9^5可写成算式如下: 00001001^00000101 00001100 (十进制为12)

main(){

int a=9

a=a^15

printf("a=%d\n",a)

}

4. 求反运算 求反运算符~为单目运算符,具有右结合性。 其功能是对参与运算的数的各二进位按位求反。例如~9的运算为: ~(0000000000001001)结果为:1111111111110110

5. 左移运算 左移运算符“<<”是双目运算符。其功能把“<< ”左边的运算数的各二进位全部左移若干位,由“<<”右边的数指定移动的位数,

高位丢弃,低位补0。例如: a<<4 指把a的各二进位向左移动4位。如a=00000011(十进制3),左移4位后为00110000(十进制48)。6. 右移运算 右移运算符“>>”是双目运算符。其功能是把“>> ”左边的运算数的各二进位全部右移若干位,“>>”右边的数指定移动的位数。

例如:设 a=15,a>>2 表示把000001111右移为00000011(十进制3)。 应该说明的是,对于有符号数,在右移时,符号位将随同移动。当为正数时, 最高位补0,而为负数时,符号位为1,最高位是补0或是补1 取决于编译系统的规定。Turbo C和很多系统规定为补1。

第一种:1个LED发光,循环右移。

第二种:2个LED发光,循环右移。

第三种:3个LED发光,循环右移。

第四种:4个LED发光,循环右移。

再改成左移,就又有四种。

这就有八种了。

一边移动,一边闪烁;

再改变一下速度;

这能有多少种了?

0变1其它位不变,位或一个该位为1其它位为0的数可得

1变0其它位不变,位与一个该位为0其它位为1的数可得

得到等N位为1其它位为0的数,可用1左移N位即得

得到等N位为0其它位为1的数,用前数位反一下即得

演示程序:

#include<stdio.h>

char*int2bin(int ,char* )

int main()

{

int x0,x1,n,flag

char x0b[33]={0}

char x1b[33]={0}

while(1)

{

x0 = x1 = n = flag = -1

printf("输入原始数值 *** 作位(0-31) 和 *** 作方式(1置/0清)\n")

scanf("%d %d %d", &x0, &n, &flag)

if( n<0 || n>31 || flag!=0&&flag!=1 ) break//无效输入将退出

if(flag==1)//置1

{

x1 = x0 | (1<<n)//n位置1

}

else//清0

{

x1 = x0 &~(1<<n)//n位清0

}

printf("处理前十进制:%-10d 二进制:%s\n", x0,int2bin(x0,x0b))

printf("处理后十进制:%-10d 二进制:%s\n\n",x1,int2bin(x1,x1b))

fflush(stdin)

}

return 0

}

char*int2bin(int x,char*out)

{

for(int i=0i<32i++)

out[i] = (x&(1<<(31-i))) ? '1' : '0'

out[32] = '\0'

return out

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11539155.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-16
下一篇 2023-05-16

发表评论

登录后才能评论

评论列表(0条)

保存