a=60 b=13 # 10进制转换成二进制字符串 a_bin=bin(a).replace("0b","") b_bin=bin(b).replace("0b","") print(a_bin) #00111100 print(b_bin) #00001101 # 按位与运算符:参与运算的两个值,如果两个相应位都为1,则该位的结果为1,否则为0 print(a&b)#结果为12 #00111100 #00001101 # 结果00001100 print(int("00001100",base=2)) #结果为12,和a&b相同 # 按位或运算符:只要对应的二个二进位有一个为1时,结果位就为1 print(a|b)#结果为61 #00111100 #00001101 # 结果00111101 print(int("00111101",base=2)) #结果为61,和a|b相同 # 按位异或运算符:当两对应的二进位相异时,结果为1 print(a^b)#结果为49 #00111100 #00001101 # 结果00110001 print(int("00110001",base=2)) #结果为49,和a^b相同 # 按位取反运算符:对数据的每个二进制位取反,即把1变为0,把0变为1 。~x 类似于 -x-1 print(~b)#结果为-14 #00001101 # 结果11110010 print(int("11110010",base=2)) #结果为242,和~b怎么不相同 # 由于在计算机系统中,数值一律用补码来表示和存储。 # 原因在于,使用补码,可以将符号位和数值域统一处理;同时,加法和减法也可以统一处理。 # 另外,求负整数的补码,将其对应正数二进制原码表示所有位取反(包括符号位,0变1,1变0)后加1 # (0)0011 1101,正数补码 # (1)1100 0010,负数补码 # 负数原码到补码的转换过程: # (1)数值部分先减一:11110001 # (2)数值部分取反:00001110 print(-int("00001110",base=2)) #结果为-14,和~b相同 # 左移动运算符:运算数的各二进位全部左移若干位,由 << 右边的数字指定了移动的位数,高位丢弃,低位补0 print(b<<2)#结果为52 #00001101 # 结果00110100 print(int("00110100",base=2)) #结果为52,和b<<2相同 # 右移动运算符:把">>"左边的运算数的各二进位全部右移若干位,>> 右边的数字指定了移动的位数 print(b>>2)#结果为3 #00001101 # 结果00000011 print(int("00000011",base=2)) #结果为3,和b>>2相同
原文:https://www.cnblogs.com/angelyan/p/12255832.html