y=gap++;y等于几

简介: y=gap++;y等于几


直接上代码

先来看一下下面的代码:

public class TestValue {
    public static void main(String[] args) {
        int gap = 1;
        List<Integer> vals = new ArrayList<Integer>();
        vals.add(1);
        vals.add(2);
        vals.add(3);
        vals.add(4);
        vals.add(5);
        int y = 1;
        while (vals.contains(gap)) {
            System.out.println("gap:" + gap + "; y:" + y );
            y = gap++;
            // y = gap;
            // gap = gap + 1;
            System.out.println("gap++后:" + gap + "; y:" +y);
        }
    }
}

提问:第二次刚刚进入循环时,y的值是多少?

回答

看一下结果:

gap:1; y:1
gap++后:2; y:1
--------------------------------
gap:2; y:1
gap++后:3; y:2
--------------------------------
gap:3; y:2
gap++后:4; y:3
--------------------------------
gap:4; y:3
gap++后:5; y:4
--------------------------------
gap:5; y:4
gap++后:6; y:5
--------------------------------

为什么第二次时,y=1

y = gap++语句将y的值更新为当前的gap值,并将gap的值自增1。

也就是说,

y = gap++等价于以下两个操作:

  1. y = gap;:将y的值更新为当前的gap值。
  2. gap = gap + 1;:将gap的值自增1。

这两个操作分别实现了将y更新为当前的gap值,并将gap的值自增1的效果。所以,y = gap++可以等价地表示为y = gap; gap = gap + 1;

解释

实际上,y = gap++语句会先将y的值更新为当前的gap值,然后再将gap的值自增1。

在这段代码中,gap++是后缀自增操作符,它会先将当前的gap值赋给y,然后再将gap的值自增1。因此,y = gap++语句执行后,y被赋值为当前的gap值,然后gap的值才会增加。

对于循环的每次迭代,y都会被赋值为当前的gap值,然后gap的值才会自增。所以在每次循环开始时,y的值都是上一次循环迭代结束时的gap值。

什么是后缀自增操作符?

后缀自增操作符(post-increment operator)是一种用于增加变量值的操作符。在大多数编程语言中,包括Java,后缀自增操作符用两个加号表示 “++”。

后缀自增操作符的作用是将变量的值加1,并返回变量的旧值。具体执行过程如下:

  1. 使用变量的旧值进行表达式的计算或赋值操作。
  2. 将变量的值加1。

例如,考虑以下代码片段:

int x = 5;
int y = x++;

在这个例子中,后缀自增操作符应用于变量x。首先,将x的旧值5赋给y,然后将x的值增加1。因此,y的值是5,而x的值变为6。

需要注意的是,后缀自增操作符在执行后会更新变量的值,但在表达式中仍然使用其旧值。这意味着,如果将后缀自增操作符应用于变量,并将该变量的值用于后续的计算或赋值,那么这些计算或赋值将使用变量的旧值。

目录
相关文章
|
6月前
|
算法 前端开发
最大公因数等于 K 的子数组数目
最大公因数等于 K 的子数组数目
50 0
|
6月前
|
存储 前端开发 JavaScript
为什么0.1 + 0.2 不等于 0.3 ?
这篇编程技术文章探讨了为什么在多种编程语言中,0.1 + 0.2 不等于 0.3 的现象。问题源于计算机使用二进制浮点数表示小数,而二进制无法精确表示某些十进制分数,如 0.1 和 0.2。这导致它们在计算机内部被近似表示,从而在相加时产生微小误差。文章通过示例和图片解释了二进制浮点数的表示原理,并提供了将小数转换为整数再相加以及使用 `toFixed()` 方法或 decimal.js 库等解决精度问题的方法。
|
6月前
|
算法 测试技术 C#
【状态机dp】【 排序 】 2809使数组和小于等于 x 的最少时间
【状态机dp】【 排序 】 2809使数组和小于等于 x 的最少时间
|
6月前
|
算法 Java 测试技术
连号区间数
连号区间数
56 0
|
算法
Light oj 1082 - Array Queries(区间最小值)
这里只要知道这种算法即可,因为数据量过大,都编译不通过,不过思想算法没有任何问题。
30 0
|
人工智能 算法
Hungry Sequence (找递增数列)
Hungry Sequence (找递增数列)
55 0
小于等于K的最大子数组累加和
小于等于K的最大子数组累加和
|
C++
acwing 716. 最大数和它的位置 int的最大值和最小值
acwing 716. 最大数和它的位置 int的最大值和最小值
91 0
7-10 求最大值及其下标
本题要求编写程序,找出给定的n个数中的最大值及其对应的最小下标(下标从0开始)。
112 0
|
Java
y=gap++;y等于几
y=gap++;y等于几
70 0