java怎么自增2_从头认识java-2.3 自增自减与关系操作符

这一章节我们来聊聊自增自减与关系操作符。

1.自增自减其实没什么特别需要关注,只要把基础原理弄懂即可。

package com.ray.ch03;

public class Test {

public static void main(String[] args) {

int a = 0;

System.out.println("before ++:" + a);

System.out.println(" ++:" + a++);

System.out.println("after ++:" + a);

System.out.println("--------");

System.out.println("before ++:" + a);

System.out.println(" ++:" + (++a));

System.out.println("after ++:" + a);

System.out.println("--------");

System.out.println("before --:" + a);

System.out.println(" --:" + a--);

System.out.println("after --:" + a);

System.out.println("--------");

System.out.println("before --:" + a);

System.out.println(" --:" + --a);

System.out.println("after --:" + a);

}

}

输出:

before ++:0

++:0

after ++:1

--------

before ++:1

++:2

after ++:2

--------

before --:2

--:2

after --:1

--------

before --:1

--:0

after --:0

从代码以及输出,我们可以看见a在每个阶段的变化,只要大家弄明白这个即可。

2.关系操作符

其实就是>,

(1)对象的等价性

package com.ray.ch03;

public class Test {

public static void main(String[] args) {

Dog jack = new Dog();

Dog rose = new Dog();

System.out.println(jack == rose);

System.out.println(jack.equals(rose));

Integer a = new Integer(1);

Integer b = new Integer(1);

System.out.println(a == b);

System.out.println(a.equals(b));

Integer d = new Integer(100000);

Integer e = new Integer(100000);

System.out.println(d == e);

System.out.println(d.equals(e));

int f = 1;

int g = 1;

System.out.println(f == g);

// System.out.println(f.equals(g));//报错

}

}

class Dog {

private String name;

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

}

输出:

false

false

false

true

false

true

true

Dog那里的对比就不说了,我们重点说说Integer那里的几个对比。

==一般是对比对象的引用,一次a==b,d==e返回false,而使用equals,则是对比两个对象里面的值,因为在Integer里面已经重写了equals方法。

public boolean equals(Object obj) {

if (obj instanceof Integer) {

return value == ((Integer)obj).intValue();

}

return false;

}

他对比的是数值,而不是对象的引用,而在==使用的是Object的equals

public boolean equals(Object obj) {

return (this == obj);

}

他只对比两者的引用是否指向同一个对象。

有一点需要注意:基本类型不能使用equals

我们再看下面的两个例子:

package com.ray.ch03;

public class Test {

public static void main(String[] args) {

Dog jack = new Dog();

Dog rose = new Dog();

jack.setName("100");

rose.setName("100");

System.out.println(jack == rose);

System.out.println(jack.equals(rose));

}

}

class Dog {

private String name;

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

}

输出:

false

false

虽然两个对象都设置同样的值,但是他们使用的是Object的equals,只是对比引用,所以同时返回false,我们修改一下上面的代码。

package com.ray.ch03;

public class Test {

public static void main(String[] args) {

Dog jack = new Dog();

Dog rose = new Dog();

jack.setName("100");

rose.setName("100");

System.out.println(jack == rose);

System.out.println(jack.equals(rose));

}

}

class Dog {

private String name;

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

@Override

public boolean equals(Object obj) {

if (obj instanceof Dog) {

return ((Dog) obj).getName().equals(name);

}

return super.equals(obj);

}

}

输出:

false

true

我们自己重写了equals方法,方法里面只是对比两者的名称,因此返回的是false和true。

总结:这一章节简单介绍了自增自减和关系操作符,以及==和equals需要注意的地方。

这一章节就到这里,谢谢。

-----------------------------------

版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您解答关于Java实现常用的排序算法中的冒泡和选择排序。 首先,我们来看一下冒泡排序的实现。 冒泡排序的基本思想是比较相邻的元素。如果第一个比第二个大,就交换它们两个;否则不交换。对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对。这样一趟过去,最后的元素一定是最大的数。然后再从头开始进行相同的操作,但是不包括已经排序好的最大元素。以此类推,直到全部排序完成。 下面是Java代码实现: ```java public class BubbleSort { public static void main(String[] args) { int[] arr = {3, 9, 8, 5, 2}; bubbleSort(arr); for (int i : arr) { System.out.print(i + " "); } } public static void bubbleSort(int[] arr) { int n = arr.length; for (int i = 0; i < n; i++) { for (int j = 1; j < n - i; j++) { if (arr[j - 1] > arr[j]) { int temp = arr[j - 1]; arr[j - 1] = arr[j]; arr[j] = temp; } } } } } ``` 接下来,我们看一下选择排序的实现。 选择排序的基本思想是每次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部排完序。 下面是Java代码实现: ```java public class SelectionSort { public static void main(String[] args) { int[] arr = {3, 9, 8, 5, 2}; selectionSort(arr); for (int i : arr) { System.out.print(i + " "); } } public static void selectionSort(int[] arr) { int n = arr.length; for (int i = 0; i < n - 1; i++) { int minIndex = i; for (int j = i + 1; j < n; j++) { if (arr[j] < arr[minIndex]) { minIndex = j; } } int temp = arr[i]; arr[i] = arr[minIndex]; arr[minIndex] = temp; } } } ``` 希望这些代码可以帮助您更好地理解冒泡排序和选择排序的实现方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值