&和&&
相同点:都可以表示逻辑与(and),当运算符两边的结果都为true时,结果才为true,只要有一边为false,结果就为false。
不同点:&&还有短路的作用,即如果第一个表达式的结果为false,就不再计算第二个表达式。而&会把第二个表达式也计算了。
==和equals
(1)对于字符串变量来说,使用“==”和“equals()”方法比较字符串时,其比较方法不同。
“==”比较两个变量本身的值,即两个对象在内存中的首地址。
“equals()”比较字符串中所包含的内容是否相同。
(2)对于非字符串变量来说,"=="和"equals"方法的作用是相同的都是用来比较其对象在堆内存的首地址,即用来比较两个引用变量是否指向同一个对象。
关于equals与==的区别从以下几个方面来说:
(1) 如果是基本类型比较,那么只能用==来比较,不能用equals
(2)对于基本类型的包装类型,比如Boolean、Character、Byte、Shot、Integer、Long、Float、Double等的引用变量,==是比较地址的,而equals是比较内容的。
这是Integer的实例,如果是其他的比如Double、Character、Float等也一样
(3) 对于String(字符串)作进一步的说明。
package com.learn;
/**
* @ author:森林之下
* @ Date: Created in 14:26 2018/11/19
* @ Description: 测试==和equals
*/
public class Test1 {
public static void main(String[] args) {
String s1 = "123";
String s2 = "123";
String s3 = "abc";
String s4 = new String("123");
String s5 = new String("123");
String s6 = new String("abc");
System.out.println(s1 == s2);//true,s1与s2分别指向由字符串常量”123” 创建的对象,在常量池中,只有一个对象,
// 内容为123,有两个引用s1和s2指向这个对象,故这两个引用变量所指向的地址是相同的
System.out.println(s1.equals(s2));//true,两个对象的内容都是字符串常量”123”
System.out.println(s1 == s3);//false,s1和s3指向对象不同,地址当然不同
System.out.println(s1.equals(s3));//false,内容当然不同
System.out.println(s4 == s5);//false,s4和s5是用new操作符创建出来的,是在内存中分配两块空间给这两个对象的,
// 因而这两个对象的内存地址不一样
System.out.println(s4.equals(s5));//true,内容相同
System.out.println(s4 == s6);//false,是两块不同的空间,不同的对象,内存地址不同
System.out.println(s4.equals(s6));//false,内容不同
System.out.println(s1 == s4);//false,分别指向两个不同的对象
System.out.println(s1.equals(s4));//true,内容相同
}
}
(4)最后一种情况
class Value {
int i;
}
public class EqualsMethod2 {
public static void main(String[] args) {
Value v1 = new Value();
Value v2 = new Value();
v1.i = v2.i = 100;
System.out.println(v1.equals(v2));//(1)flase
System.out.println(v1 == v2);//(2)false
}
}
/*如果在新类中被覆盖了equals方法,就可以用来比较内容的。但是在上面的例子中类Value并没有覆盖Object中的equals方法,而是继承了该方法,因此它就是被用来比较地址的,又v1和v2的所指向的对象不相同,故标记(1)处的v1.equals(v2)运行结果为false,标记为(2)处的v1 == v2运行结果也为false。 */
注:==和equals部分引用https://www.cnblogs.com/bluestorm/archive/2012/03/02/2377615.html