zoukankan      html  css  js  c++  java
  • python位运算符详细介绍

    一、介绍位运算符

    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相同
  • 相关阅读:
    android apk瘦身之 图片压缩 tinypng
    java 1.7 新io 实践 NIO2
    Still unable to dial persistent://blog.csdn.net:80 after 3 attempts
    dex2oat 加载多次
    android stadio open recent 在同一窗口打开
    &运算符的应用
    MethodTrace 生成的trace文件为空
    MethodTrace 生成的trace文件为空
    error: unknown host service 的详细解决办法
    error: unknown host service 的详细解决办法
  • 原文地址:https://www.cnblogs.com/angelyan/p/12255832.html
Copyright © 2011-2022 走看看