python中的按位取反运算

Python018

python中的按位取反运算,第1张

按位取反运算符:~运算结果:~x=-(x+1) 例如:~9为-10 ~(-9)为8 这不是按位取反吗?怎么结果是这样? 看下面。转二进制:0 1001 计算补码:0 1001 要知道它所表达的数是多少,需要转换为原码 _____ 转为原码:按位取反:1 1001 末位加一:1 1010 符号位为1是负数,即-10 转二进制:1 1001 计算补码:1 0111 要知道它所表达的数是多少,需要转换为原码____ 转为原码:正数的补码和原码相同,仍为:0 1000,即8

python 3的整型以16bit递增。

0xf0 =0b 0000 0000 1111 0000

~0xf0之后得到1111 1111 0000 1111

[1][111 1111 0000 1111]

确定是负数,有负数等于绝对值反码加一。求补码形式。

绝对值减1得:111 1111 0000 1110

反码得:000 0000 1111 0001

得-0xf1即-241(你那的~a[0]得-241)

要求得到[0,256),限定一下范围即可。

>>> (~a[0])&0xff

15

‘and’、‘or’和‘not’的优先级是not>and>or

首先,‘and’、‘or’和‘not’的优先级是not>and>or。

and :x and y 返回的结果是决定表达式结果的值。如果 x 为真,则 y 决定结果,返回 y ;如果 x 为假,x 决定了结果为假,返回 x。

or :x or y  跟 and 一样都是返回决定表达式结果的值。

not : 返回表达式结果的“相反的值”。如果表达式结果为真,则返回false;如果表达式结果为假,则返回true。

其次,逻辑操作符and 和or 也称作短路操作符(short-circuitlogic)或者惰性求值(lazy evaluation):它们的参数从左向右解析,一旦结果可以确定就停止。

例如,如果A 和C 为真而B 为假, A and B and C 不会解析C,作用于一个普通的非逻辑值时,短路操作符的返回值通常是最后一个变量。因此,逻辑运算符的理解也与C语言中不同。举个例子:

在以上例子中,按照C语言对的思维,3 and 4即3与4为3,但是由于是短路操作符,结果为4,是因为and运算符必须所有的运算数都是true才会把所有的运算数都解析,并且返回最后一个变量,即为4;改变一下顺序4 and 3 ,结果也不一样,即为3.

而或逻辑(or),即只要有一个是true,即停止解析运算数,返回最近为true的变量,即 3 or 4,值为3;改变顺序4 or 3 即为4.