Javascript 按位取反运算符 (~)
2014-02-04 00:00
801 查看
result = ~ 【数字】
所有一元运算符(如 ~ 运算符)都按照下面的规则来计算表达式的值:
1、 如果应用于未定义的表达式或 null 表达式,则会引发一个运行时错误。 2、 将对象转换为字符串。 3、 如果可能,将字符串转换为数字。 否则,将引发运行时错误。 4、 布尔值被视为数字(如果为 false,则为 0;如果为 true,则为 1)。
运算符将应用于结果数字。
~ 运算符查看表达式的二进制表示形式的值,并执行位非运算。
表达式中的任何一位为 1,则结果中的该位变为 0。 表达式中的任何一位为 0,则结果中的该位变为 1。
下面的示例阐释了位非 (~) 运算符的用法,其中包含二进制表示十进制负数的,如果不熟悉这个请先看懂《十进制负数转换为二进制、八进制、十六进制》。
var temp = ~5; /* 5 二进制 101,补满 32位 00000000000000000000000000000101 按位取反 11111111111111111111111111111010 由于32位开头第一个是1,所以这是一个负数,将二进制转换成负数,需要先反码 00000000000000000000000000000101 之后,再+1 00000000000000000000000000000110 转换成十进制为6,加上符号变成负数 -6 */ alert(temp); // 弹出【-6】
相关文章推荐
- Javascript 按位取反运算符 (~)
- Javascript 按位取反运算符 (~)
- JavaScript 运算符和表达式
- javascript中不常见的运算符
- JavaScript中instanceof运算符的用法总结
- javascript中不常见的运算符
- javascript in运算符
- JavaScript-运算符
- JavaScript中的delete运算符
- JavaScript高级程序设计(第3版)学习笔记4 js运算符和操作符
- javascript-02-------表达式、运算符
- JavaScript运算符
- JavaScript知识点总结(四)之逻辑OR运算符详解
- JavaScript的运算符
- JavaScript之运算符
- JavaScript instanceof 运算符深入剖析
- Javascript-Operational-Character(运算符)
- 总结---JavaScript运算符
- JavaScript中instanceof与typeof运算符的用法及区别详细解析
- Javascript中的特别运算符