Java开发笔记(九)赋值运算符及其演化
前面的加减乘除四则运算,计算结果通过等号输出给指定变量,注意此时代码把变量放到等号左边。而在算术课本里,加法运算的完整写法类似于“1+1=2”这样,运算结果应该跟在等号右边。不过代数课本里的方程式存在“x=y+1”的写法,表示等号两边的结果数值是一样的,因此变量放在等号左边也是可以理解的。然而Java编程里的“=”并非数学上的相等涵义,而是一种赋值操作,所谓“赋值”,指的是将某一数值赋给某个变量的过程。计算机程序在运行的时候,不管操作什么类型的数据,都要有处地方保存运算前后的数值。变量在参与计算的时候,它可能存在多种身份,当变量作为运算过程的操作数之时,它保存的是运算前的数值;当变量作为运算结果的输出数之时,它保存的是运算后的数值。故而等号两边同时出现某个变量是完全正常的,就像下面代码演示的那样:
// 日常生活中的加法例子是:1+1=2,运算结果在右边。但Java编程中是把运算结果放在左边的
int x = 1+1;
// 注意这里的等号是赋值操作,并非代数方程式里面的等号,否则x=x+7将会求得0=7的荒诞结果
x = x+7;
注意上述演示代码里的“x = x+7”,等号的左右两边虽然都出现了整型变量x,但是这两个x所处的时间点不同,使得它们代表的数值也不一样。等号右边的x,保存的是运算开始前的变量值,即2;而等号左边的x,保存的是运算结束后的数值,即9。所以前面的代码看似代数方程式,其实表示的是一个存在时间先后概念的赋值语句。
就赋值语句“x = x+7”而言,尽管它从数学角度来看很是无理,可是在计算机编程中却十分常见。该语句仅仅要求给某个整型变量加上若干数值,并未涉及到其它别的什么变量,好比某人的背包里原本装了三本书,然后往里面塞两本书,最终背包一共装了五本书。由于这种加法运算只对某个变量进行,因此Java又提供了“+=”运算符来简化变量的自增操作,新运算符的使用代码示例如下:
// 对变量进行加法运算后,假如相加之和仍然保存在原变量,那么可按如下格式使用运算符“+=”
x += 7; // 该行代码等同于 x = x+7;
System.out.println("相加之和 x="+x);
既然有“+=”开了个自增运算的头,那么其它的四则运算依此类推,均可分别演变出自减运算符“-=”、自乘运算符“*=”、自除运算符“/=”,以及对变量自身取余数的运算符“%=”,相应的例子代码如下所示:
// 运算符“-=”的作用类似“+=”,即把相减之差保存到原变量中
x -= 7; // 该行代码等同于 x = x-7;
System.out.println("相减之差 x="+x);
// 若要将相乘之积保存到原变量中,则可使用运算符“*=”
x *= 7; // 该行代码等同于 x = x*7;
System.out.println("相乘之积 x="+x);
// 若要将相除之商保存到原变量中,则可使用运算符“/=”
x /= 7; // 该行代码等同于 x = x/7;
System.out.println("相除之商 x="+x);
// 若要将相除之余保存到原变量中,则可使用运算符“%=”
x %= 7; // 该行代码等同于 x = x%7;
System.out.println("相除之余 x="+x);
推而广之,凡是对变量自身进行某种基础运算,然后运算结果又保存在该变量中,这些情况都适用于扩展了的赋值语句。譬如之前提到的按位左移操作符<<、按位右移操作符>>,均可演化出对应的自身左移运算符“<<=”,以及自身右移运算符“>>=”,这两个运算符的演示代码如下:
// 若要将按位左移结果保存到原变量中,则可使用运算符“<<=”
x <<= 2; // 该行代码等同于 x = x << 2;
System.out.println("x按位左移两位="+x);
// 若要将按位右移结果保存到原变量中,则可使用运算符“>>=”
x >>= 2; // 该行代码等同于 x = x >> 2;
System.out.println("x按位右移两位="+x);
Java开发笔记(九)赋值运算符及其演化的更多相关文章
- Java开发笔记(八十九)缓存字节I/O流
文件输出流FileOutputStream跟FileWriter同样有个毛病,每次调用write方法都会直接写到磁盘,使得频繁的写操作性能极其低下.正如FileWriter搭上了缓存兄弟Buffere ...
- Java开发笔记(二十九)大整数BigInteger
早期的编程语言为了节约计算机的内存,给数字变量定义了各种存储规格的数值类型,比如字节型byte只占用一个字节大小,短整型short占用两个字节大小,整型int占用四个字节大小,长整型long占用八个字 ...
- Java开发笔记(三十九)日期工具Date
Date是Java最早的日期工具,编程中经常通过它来获取系统的当前时间.当然使用Date也很简单,只要一个new关键字就能创建日期实例,就像以下代码示范的那样: // 创建一个新的日期实例,默认保存的 ...
- Java开发笔记(四十九)关键字super的用法
前面介绍了如何从Bird类继承而来Swallow类,按道理子类应当继承父类的所有要素,但是对于构造方法来说,Swallow类仅仅继承了Bird类的默认构造方法,并未自动继承带参数的构造方法.如果子类想 ...
- Java开发笔记(五十九)Java8之后的扩展接口
前面介绍了接口的基本用法,有心的朋友可能注意到这么一句话“在Java8以前,接口内部的所有方法都必须是抽象方法”,如此说来,在Java8之后,接口的内部方法也可能不是抽象方法了吗?之所以Java8对接 ...
- Java开发笔记(六十九)泛型类的定义及其运用
前面从泛型方法的用法介绍到了泛型的起源,既然单个方法允许拥有泛化的参数类型,那么一个类也应当支持类级别的泛化类型,例如各种容器类型ArrayList.HashMap等等.一旦某个类的定义代码在类名称后 ...
- Java开发笔记(七十九)利用反射技术操作私有属性
早在介绍多态的时候,曾经提到公鸡实例的性别属性可能被篡改为雌性,不过面向对象的三大特性包含了封装.继承和多态,只要把性别属性设置为private私有级别,也不提供setSex这样的性别修改方法,那么性 ...
- Java开发笔记(九十一)IO流处理简单的数据压缩
前面介绍的文件I/O,不管是写入文本还是写入对象,文件中的数据基本是原来的模样,用记事本之类的文本编辑软件都能浏览个大概.这么存储数据,要说方便确实方便,只是不够经济划算,原因有二:其一,写入的数据可 ...
- Java开发笔记(九十七)利用Runnable启动线程
前面介绍了线程的基本用法,按理说足够一般的场合使用了,只是每次开辟新线程,都得单独定义专门的线程类,着实开销不小.注意到新线程内部真正需要开发者重写的仅有run方法,其实就是一段代码块,分线程启动之后 ...
- Java开发笔记(九十九)定时器与定时任务
前面介绍了线程的几种运行方式,不管哪种方式,一旦调用了线程实例的start方法,都会立即启动线程的事务处理.然而某些业务场景在事务执行时间方面有特殊需求,例如期望延迟若干时间之后才开始事务运行,又如期 ...
随机推荐
- 反编译python打包的exe文件
目录 1.前言 2.使用环境 3.还原过程 4.号外 5.exe文件和所用到的反编译工具 6.参考 7.去签名(补漏) 前言 拿到了利用驱动人生进行传播的病毒样本,发现是python打包成的exe文件 ...
- 算法与数据结构(十) 二叉排序树的查找、插入与删除(Swift版)
在上一篇博客中,我们主要介绍了四种查找的方法,包括顺序查找.折半查找.插入查找以及Fibonacci查找.上面这几种查找方式都是基于线性表的查找方式,今天博客中我们来介绍一下基于二叉树结构的查找,也就 ...
- 美图App的移动端DNS优化实践:HTTPS请求耗时减小近半
本文引用了颜向群发表于高可用架构公众号上的文章<聊聊HTTPS环境DNS优化:美图App请求耗时节约近半案例>的部分内容,感谢原作者. 1.引言 移动互联网时代,APP 厂商之间的竞争非常 ...
- [Swift]LeetCode224. 基本计算器 | Basic Calculator
Implement a basic calculator to evaluate a simple expression string. The expression string may conta ...
- [Swift]LeetCode754. 到达终点数字 | Reach a Number
You are standing at position 0 on an infinite number line. There is a goal at position target. On ea ...
- [Swift]LeetCode761. 特殊的二进制序列 | Special Binary String
Special binary strings are binary strings with the following two properties: The number of 0's is eq ...
- [Swift]LeetCode946. 验证栈序列 | Validate Stack Sequences
Given two sequences pushed and popped with distinct values, return true if and only if this could ha ...
- [Swift]LeetCode970.强整数 | Powerful Integers
Given two non-negative integers x and y, an integer is powerful if it is equal to x^i + y^j for some ...
- Java运行原理及内存分析
Java运行原理及内存分析 一.Java运行原理 二.Java内存分析
- Windows环境安装运行:Angular.js
一.下载 Node.js https://nodejs.org/en/download/ 检测版本: cmd: node -v 二.安装typescript和typings 使用 Node.js 包管 ...