javascript运算符——算术运算符

×

目录

[1]一元加 [2]一元减 [3]递增[4]递减[5]加法[6]减法[7]乘法[8]除法[9]求余

前面的话

  javascript中的算术操作主要通过算术运算符来实现,本文将介绍算术运算符的内容。算术运算符包括一元算术运算符和二元算术运算符两种

一元算术运算符

  一元算术运算符用于一个单独的操作数,并产生一个新值。在javascript中,一元运算符具有很高的优先级,而且都是右结合(right-associative)

  一元算术运算符包括一元加法(+)、一元减法(-)、递增(++)和递减(--)

一元加(+)

  一元加运算符以一个加号(+)表示,放在数值前面,对数值不会产生任何影响

var num = 25;
num = +num; //25

  在对非数值应用一元加运算符时,会调用Number()转型函数对这个值进行转换

var s1 = ‘01‘;
var s2 = ‘1.1‘;
var s3 = ‘z‘;
var b = false;
var f = 1.1;
var o = {
    valueOf:function(){
        return -1;
    }
};

s1 = +s1;//1
s2 = +s2;//1.1
s3 = +s3;//NaN
b = +b;//0
f = +f;//1.1
o = +o;//-1

一元减(-)

  一元减运算符主要用于表示负数

var num = 25;
num = -num;//-25

  当一元减运算符用于非数值时,会对该值使用Number()转型函数进行转换,再将得到的数值转换成负数

var s1 = ‘01‘;
var s2 = ‘1.1‘;
var s3 = ‘z‘;
var b = false;
var f = 1.1;
var o = {
    valueOf:function(){
        return -1;
    }
};

s1 = -s1;//-1
s2 = -s2;//-1.1
s3 = -s3;//NaN
b = -b;//0
f = -f;//-1.1
o = -o;//1

  [注意]一元加和一元减运算符主要用于基本的算术运算,也可以用于转换数据类型

递增(++)

  递增++运算符对其操作数进行增量(加1)操作,操作数是一个左值(lvalue)(变量、数组元素或对象属性)。运算符通过Number()转型函数将操作数转换为数字,然后给数字加1,并将加1后的数值重新赋值给变量、数字元素或者对象属性

var age = 29;
++age;
//相当于
var age = 29;
age = age +1;

  递增++运算符的返回值依赖于它相对于操作数的位置。当运算符在操作数之前,称为前增量(pre-increment)运算符,它对操作数进行增量计算,并返回计算后的值。当运算符在操作数之后,称为后增量(post-increment)运算符,它对操作数进行增量计算,但返回未做增量计算的(unincremented)值

  不管是前增量还是后增量,这个运算符通常用在for循环中,用于控制循环内的计数器

var i = 1, j = ++i;//i=2 j=2
var i = 1, j = i++;//i=2 j=1

  [注意]++x并不总是和x = x+1完全一样,++运算符从不进行字符串连接操作,它总是会将操作数转换为数字并增1

var x = ‘1‘;
++x;//2
var x = ‘1‘;
x = x + 1;//‘11‘

递减(--)

  递减--运算符的操作数也是一个左值,它通过Number()转型函数把操作数转换为数字,然后减1,并将计算后的值重新赋值给操作数

  和递增++运算符一样,递减--运算符的返回值依赖于它相对操作数的位置,当递减运算符在操作数之前,操作数减1并返回减1之后的值。当递减运算符在操作数之后,操作数减1并返回减1之前的值

var age = 29;
--age;
//相当于
var age = 29;
age = age - 1;

  前增量操作符与执行语句优先级相同,整个语句会从左向右求值

var num1 = 2;
var num2 = 20;
var num3 = --num1 + num2;//21
var num4 = num1 + num2;//21

  后增量操作符在包含它们的语句被求值之后才执行

var num1 = 2;
var num2 = 20;
var num3 = num1-- + num2;//22
var num4 = num1 + num2;//21

  在涉及++和--运算符时,如果将其用作后缀表达式,它和表达式应该同一行。否则,行尾将填补分号,同时++或--将作为下一行代码的前缀操作符并与之一起解析

x
--
y

  javascript将其解析为:

x;--y;

  而代码的本意是:

x--;y;

二元算术运算符

  二元算术运算符包括加法(+)、减法(-)、乘法(*)、除法(/)和求余(%)

加法(+)

  在多数程序设计语言中,加法通常是简单的数字运算符,但在ECMAScript中,加法运算有大量的特殊行为,不仅可以进行数值加法运算,也可以进行字符串连接

  加法运算遵循如下规则:

  【1】如果其中一个操作数是对象,则对象会转换为原始值:日期对象通过toString()方法执行转换,其他对象通过valueOf()方法执行转换。由于多数对象valueOf()方法无法返回一个原始值,于是会通过toString()方法来执行转换

  [注意]除了单数值数组会转换为数字外,其他原生对象都会通过toString()方法转换为字符串形式

  【2】在进行了对象到原始值的转换后,如果其中一个操作数是字符串的话,另一个操作数也会转换成字符串,进行字符串连接

  【3】否则,两个操作数都将转换成数字或NaN,进行加法操作

//单数值数组和valueOf()返回值为数值的自定义对象会转换为数值
console.log(1 + []);//1
var o = {
    valueOf: function(){
        return -1;
    }
}
console.log(1 + o);//0
//其他原生对象则转换为字符串
console.log(1 + {});//‘1[object Object]‘
console.log(1 + [1,2]);//‘11,2‘
console.log(1 + new Date());//‘1Thu Jun 16 2016 10:27:13 GMT+0800 (中国标准时间)‘
console.log(1 + /0/);//‘1/0/‘

  如果进行算术加法运算,undefined转换为NaN,null转换为0,false转换为0,true转换为1

console.log(undefined + undefined);//NaN
console.log(null + null);//0
console.log(false + false);//0
console.log(true + true);//2

  如果进行字符串连接,undefined转换为‘undefined‘,null转换为‘null‘,false转换为‘false‘,true转换为‘true‘

console.log(‘‘ + undefined);//‘undefined‘
console.log(‘‘ + null);//‘null‘
console.log(‘‘ + false);//‘false‘
console.log(‘‘ + true);//‘true‘

  因此,利用加号运算符的特性,可以利用‘‘+任意类型值转换为字符串

  在数字加法运算中,Infinity和带符号的0的处理较为特殊

Number.MAX_VALUE + Number.MAX_VALUE === Infinity;//true
Infinity + (-Infinity);//NaN
+0 + (-0) === +0;//true

减法(-)

  相对于加法,减法就简单的多,只涉及到数字的减法运算。使用Number()转型函数将非数值类型转换为数值或NaN

console.log(1 - {});//NaN
console.log(1 - [1,2]);//NaN
console.log(1 - /0/);//NaN
console.log(1 - []);//1

  加法有一个特殊之外,在于时间Date对象进行加法运算时使用toString()转换为字符串,而在其他数学运算,包括减法、乘法、除法、求余等运算中,都是使用Number()转换函数将时间Date对象使用valueOf()转换为数字

console.log(new Date() + 1);//‘Thu Jun 16 2016 11:11:49 GMT+0800 (中国标准时间)1‘
console.log(new Date() - 1);//1466046941641

  undefined转换为NaN,null转换为0,false转换为0,true转换为1

console.log(1 - undefined);//NaN
console.log(1 - null);//1
console.log(1 - false);//1
console.log(1 - true);//0

乘法(*)

  乘法操作符由一个星号(*)表示,用于计算两个数值的乘积,会通过Number()转型函数将非数值类型转换为数值或NaN

+ Infinity * 0;//NaN
- Infinity * 0;//NaN
Infinity * 非0数值;//Infinity或-Infinity
Infinity * Infinity;//Infinity

除法(/)

  除法操作符由一个斜线(/)表示,执行第一个操作数除以第二个操作数的运算,也会通过Number()转型函数将非数值类型转换为数值或NaN

Infinity / Infinity;//NaN
0 / 0;//NaN
非0数值 / 0;//Infinity或-Infinity
Infinity / 0;//Infinity
Infinity / 非0数值;//Infinity

求模(%)

  求模(余数)操作符是由一个百分号(%)表示,是第一个操作数除以第二个操作数的余数

//r是余数,n是被除数,d是除数,
//q是整数,在n/d为负时为负,在n/d为正时为正,它应该在不超过n和d的商的前提下尽可能大
r = n - (d * q)

  求模结果与第一个操作数的符号保持一致

console.log(5 % 2);//1
console.log(5 % -2);//1
console.log(-5 % 2);//-1
console.log(-5 % -2);//-1

  被除数是Infinity,或除数是0,则求模结果是NaN

Infinity % 0 = NaN
Infinity % Infinity = NaN
Infinity % 非0数值 = NaN
非0数值 % 0 = NaN

  在多数编程语言中,求模运算符只接受整数为操作数,而在ECMAScript中,还接受浮点操作数,但由于浮点数不是精确的值,无法得到完全准确的结果

console.log(6.5 % 2.1);//0.19999999999999973

参考资料

【1】ES5/表达式 https://www.w3.org/html/ig/zh/wiki/ES5/expressions
【2】阮一峰Javascript标准参考教程——基本语法之运算符 http://javascript.ruanyifeng.com/grammar/operator.html
【3】W3School-Javascript高级教程——ECMAScript运算符 http://www.w3school.com.cn/js/pro_js_operators_multiplicative.asp
【4】《javascript权威指南(第6版)》第4章 表达式和运算符
【5】《javascript高级程序设计(第3版)》第3章 基本概念
【6】《javascript语言精粹(修订版)》第2章 语法

时间: 2024-11-05 17:32:51

javascript运算符——算术运算符的相关文章

javascript中算术运算符规则

javascript中提供了几种算术运算符,+(加)  -(减)  *(乘)  /(除)  %(余),常规用法与数学上的一致:  但还规定一些特殊规则: 注:JavaScript中保存数值的方式,可以保存正零(+0)和负零(-0):正零与负零被认为相等. 乘性操作符(*): 如果结果太大或太小,那么生成的结果是 Infinity 或 -Infinity. 如果某个运算数是 NaN,结果为 NaN. Infinity 乘以 0,结果为 NaN Infinity 乘以 0 以外的任何数字,结果为 I

JavaScript的算术运算符

ECMAScript 定义了 5 个算术运算符,加.减.乘.除.求模(取余).如果在算术运算的值不是数值,那么后台会先使用 Number()转型函数将其转换为数值(隐式转换). 一.加法 var box = 1 + 2; //等于 3 var box = 1 + NaN; //NaN,只要有一个 NaN 就为 NaN var box = Infinity + Infinity; //Infinity var box = -Infinity + -Infinity; //-Infinity var

Python新手学习基础之运算符——算术运算符

算术运算符 之前文章在介绍变量类型的时候,其实已经用过了很多算术符,比如+.-.*././/.** 等,除此之外,还有一个符号是之前内容没提到的,就是 % ,用来返回除法余数的运算符号. 假设有变量x和y,x为10,y为3,x%y的结果就是1. 在运算符中有优先级,跟数学中的一样,所以在写的时候有些要优先运算的需要加上括号,比如:3 * (4 + 5). Python支持不同的数字类型相加,它使用数字类型强制转换的方式来解决数字类型不一致的问题,就是说它会将一个操作数转换成另一个操作数相同的数据

MySQL数据库中的算术运算符

MySQL数据库中的算数运算符 MySQL数据库中的算术运算符 一.运算符的概述: 运算符在MySQL数据库中也是很重要的知识体,在执行sql语句的时候这个运算符对操作数据帮助很大.其中运算符的运用可以帮助你减省大量的时间,操作起来也比较灵活. 二.运算符 运算符主要包括"算数运算符"."比较运算符"."罗运算符"."位运算符"四大类,下面我们就一次学习一下. 1.算术运算符 算术运算符在sql语句的时候经常使用,例如对表的字

javascript数据类型-及运算符

一.js中的数据类型 1.五种简单的 字符串(String) 加引号,引起来的都是字符串(单双引号都可以) 数字(Number) 整数.小数.负数 布尔(Boolean) true ==>真(对) false==>假(错) Undefined(未定义) 一个变量没有赋值就是undefined Null(空) 2.1种复杂(对象) ****一种特殊的Object类型 Object ***********typeof   检测类型的 typeof返回的结果是字符串 例如:typeof(str)  

5.Java算术运算符和关系运算符详解

运算符就是在用变量或常量进行运算时,经常需要用到的符号,目前常用的总共有十种:算术运算符.关系运算符.逻辑运算符.位运算符.移位运算符.赋值运算符.三元运算符.逗号运算符.字符串运算符.转型运算符.下面将会对每种运算符结合实例作详细的讲述. 一.算术运算符 算术运算符总共有 7 种:“+”.“ - ”.“*”.“/”.“%”(余数).“++”(自加).“——”(自减). 运算符的精度: 当使用运算符把两个操作数结合到一起时,首先会将两个操作数转化成相同类型的数据. 两个操作数中如有一个是 dou

Java基础---Java算术运算符(十一)

Java中的算术运算符 算术运算符主要用于进行基本的算术运算,如加法.减法.乘法.除法等. Java 中常用的算术运算符: 其中,++ 和 -- 既可以出现在操作数的左边,也可以出现在右边,但结果是不同滴 运行结果: 运行结果: 一定要注意哦!自增和自减运算符只能用于操作变量,不能直接用于操作数值或常量!例如 5++ . 8-- 等写法都是错误滴! PS:% 用来求余数,也称为"取模运算符" 代码: public class HelloWorld{    public static v

算术运算符和运算命令

1.算术运算符 算术运算符 使用说明 +.- 加法(或正号).减法(或负号). *./.% 乘法.除法.取余. ** 幂运算. !.&&.|| 逻辑非(取反).逻辑与(and).逻辑或(or) ==.!=.= 比较符号(相等.不相等.相当于). =.+=.-=.*=./=.%= 赋值运算符.例如a+=1等于a=a+1. ++.-- 增加和减少1. 2.算术运算命令 算术运算命令 使用说明 (()) 用于整数运算的常用运算符,效率较高. let 用于整数运算,类似于"(())&qu

python基础学习日记(一)注释(二)算术运算符(三)变量的基本使用

一.python程序的注释 注释部份程序运行时不起作用.用于说明代码的用途 1.单行注释 # 开始的一行文字,为单行注释 # 单行注释 print("hello python") # 单行注释 2.多行注释 一对三个引号(单引号或者双引号),为多行注释 ''' 单引号多行注释 ..... 多行注释 ''' print("hello python") """ 双引号多行注释 ..... 多行注释 """ 二.