电脑显卡风扇不转电脑黑屏,但是显卡能用,请问风扇能换吗

==比较两个对象在内存里是不是同一个对象,就是说在内存里的存储位置一致。两个String对象存储的值是一样的,但有可能在内存里存储在不同的地方 .
==比较的是引用而equals方法比较的是内容。public boolean equals(Object obj) 这个方法是由Object对象提供的,可以由子类进行重写。默认的实现只有当对象和自身进行比较时才会返回true,这个时候和==是等价的。String, BitSet, Date, 和File都对equals方法进行了重写,对两个String对象 而言,值相等意味着它们包含同样的字符序列。对于基本类型的包装类来说,值相等意味着对应的基本类型的值一样。
public class EqualsTest {
public static void main(String[] args) {
String s1 = &abc&;
String s2 = s1;
String s3 = new String(&abc&);
String s4 = new String(&abc&);
String s5 = &abc&;
System.out.println(&== comparison : & + (s1 == s5));
System.out.println(&== comparison : & + (s1 == s2));
System.out.println(&Using equals method : & + s1.equals(s2));
System.out.println(&== comparison : & + s3 == s4);
System.out.println(&Using equals method : & + s3.equals(s4));
== comparison : true
== comparison : true
Using equals method : true
Using equals method :true
阅读(...) 评论()equals与”==”的区别 - ImportNew
equals()和“==”操作用于对象的比较,检查俩对象的相等性,但是他们俩的主要区别在于前者是方法后者是操作符。由于java不支持操作符重载(overloading),“==”的行为对于每个对象来说与equals()是完全相同的,但是equals()可以基于业务规则的不同而重写(overridden )。另一个需要注意的不同点是“==”习惯用于原生(primitive)类型之间的比较,而equals()仅用于对象之间的比较。同时初学者奋力地想找到什么时候使用等号操作“==”,什么时候使用equals方法。这篇教程中你将将看到equals()方法和“==”操作是如果工作的、他们之间有什么不同、什么时候用“==”、什么时候使用equals()方法。
“==”等号操作是什么
“==”或等号操作在Java编程语言中是一个二元操作符,用于比较原生类型和对象。就原生类型如boolean、int、float来说,使用“==”来比较两者,这个很好掌握。但是在比较对象的时候,就会与equals()造成困惑。“==”对比两个对象基于内存引用,如果两个对象的引用完全相同(指向同一个对象)时,“==”操作将返回true,否则返回false。
什么是equals方法
equals()方法定义在Object类里面,根据具体的业务逻辑来定义该方法,用于检查两个对象的相等性。例如:两个Employees被认为是相等的如果他们有相同的empId的话,你可以在你自己的domain对象中重写equals方法用于比较哪两个对象相等。equals与hashcode是有契约的(无论什么时候你重写了equals方法,你同样要重写hashcode()方法),默认的equals方法实现是与“==”操作一样的,基于业务需求重写equals方法是最好的实践之一,同样equals与compareTo保持一致也不足为奇,以至于存储对象在Treemap或treeset集合中时,将使用compareTo方法检查相等性,行为是一致的。
==与equals方法的区别
==与equals的主要区别是:==常用于比较原生类型,而equals()方法用于检查对象的相等性。另一个不同的点是:如果==和equals()用于比较对象,当两个引用地址相同,==返回true。而equals()可以返回true或者false主要取决于重写实现。最常见的一个例子,字符串的比较,不同情况==和equals()返回不同的结果。
字符串的==和equals对比
字符串的比较是一个常见的情景,因为java.lang.String类重写了equals方法,它返回true如果两个字符串对象包含有相同的内容,但是==只有他们的引用地址相同时才返回true,下面这个例子就是通过==和equals方法分别比较两个字符串。
String personalLoan = new String(&cheap personal loans&);
String homeLoan = new String(&cheap personal loans&);
//since two strings are different object result should be false
boolean result = personalLoan == homeL
System.out.println(&Comparing two strings with == operator: & + result);
//since strings contains same content , equals() should return true
result = personalLoan.equals(homeLoan);
System.out.println(&Comparing two Strings with same content using equals method: & + result);
homeLoan = personalL
//since both homeLoan and personalLoand reference variable are pointing to same object
//&==& should return true
result = (personalLoan == homeLoan);
System.out.println(&Comparing two reference pointing to same String with == operator: & + result);
Comparing two strings with == operator: false
Comparing two Strings with same content using equals method: true
Comparing two reference pointing to same String with == operator: true
==与equals在对象之间的对比
另一中情景是:当你对比两个对象时,在选择==和equals方法中很容易困惑,当你比较的两个引用指向的对象是Object的类型的时候,那么你看到的结果和==是一致的,因为默认的equals方法实现仅仅比较的内存地址。如果两个引用变量完全指向的是同一个对象的话就返回true,下面这个例子是equals和==方法操作比较的是两个对象。
Object obj1 = new Object();
Object obj2 = new Object();
// == should return false
result = (obj1==obj2);
System.out.println(&Comparing two different Objects with == operator: & + result);
//equals should return false because obj1 and obj2 are different
result = obj1.equals(obj2);
System.out.println(&Comparing two different Objects with equals() method: & + result);
// &==& should return true because both obj1 and obj2 points same object
obj1=obj2;
result = (obj1==obj2);
System.out.println(&Comparing two reference pointing to same Object with == operator: & + result);
Comparing two different Objects with == operator: false
Comparing two different Objects with equals() method: false
Comparing two reference pointing to same Object with == operator: true
使用==比较原生类型如:boolean、int、char等等,使用equals()比较对象。
==返回true如果两个引用指向相同的对象,equals()的返回结果依赖于具体业务实现
字符串的对比使用equals()代替==操作符
以上就是关于equals方法和==操作符的区别,其主要的不同是一个是操作符一个是方法,==用于对比原生类型而equals()方法比较对象的相等性。
原文链接:
- 译文链接: [ 转载请保留原文出处、译者和译文链接。]
关于作者:
程序员,关注 Java、Python、云计算,移动互联网。(新浪微博:)
优先队列的作用是能保证每次取出的元素都是队列中权值最小的(Java的优先队列每次取最小元素,C++的...
关于ImportNew
ImportNew 专注于 Java 技术分享。于日 11:11正式上线。是的,这是一个很特别的时刻 :)
ImportNew 由两个 Java 关键字 import 和 new 组成,意指:Java 开发者学习新知识的网站。 import 可认为是学习和吸收, new 则可认为是新知识、新技术圈子和新朋友……
新浪微博:
推荐微信号
反馈建议:@
广告与商务合作QQ:
– 好的话题、有启发的回复、值得信赖的圈子
– 写了文章?看干货?去头条!
– 为IT单身男女服务的征婚传播平台
– 优秀的工具资源导航
– 活跃 & 专业的翻译小组
– 国内外的精选博客文章
– UI,网页,交互和用户体验
– JavaScript, HTML5, CSS
– 专注Android技术分享
– 专注iOS技术分享
– 专注Java技术分享
– 专注Python技术分享
& 2017 ImportNew==与equals的区别,还有空值比较哪个放在前面哪个放在后面?
空值比较:比如说用户提交一个变量a,有可能是空值,那么判断语句 if(a.equals(null)){} 和 if(null.eauals.(a)){} 哪个正确?
非常感谢!
写下你的评论...
写下你的评论...
Copyright (C)
All Rights Reserved | 京ICP备 号-2Java中equals和==的区别
我的图书馆
Java中equals和==的区别
值类型是存储在内存中的堆栈(以后简称栈),而引用类型的变量在栈中仅仅是存储引用类型变量的地址,而其本身则存储在堆中。
&&& ==操作比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量在堆中存储的地址是否相同,即栈中的内容是否相同。
&&& equals操作表示的两个变量是否是对同一个对象的引用,即堆中的内容是否相同。
&&& ==比较的是2个对象的地址,而equals比较的是2个对象的内容。
&&& 显然,当equals为true时,==不一定为true;
&&& 一、String中的equals和==
&&& public class TestString {
&&& public static void main(String[] args) {
&&& String s1 = "Monday";
&&& String s2 = "Monday";
&&& 上面这段程序中,到底有几个对象呢?
&&& 来检测一下吧,稍微改动一下程序
&&& public class TestString {
&&& public static void main(String[] args) {
&&& String s1 = "Monday";
&&& String s2 = "Monday";
&&& if (s1 == s2)
&&& System.out.println("s1 == s2");
&&& System.out.println("s1 != s2");
&&& 编译并运行程序,输出:s1 == s2说明:s1 与 s2 引用同一个 String 对象 -- "Monday"!
&&& 2.再稍微改动一下程序,会有更奇怪的发现:
&&& public class TestString {
&&& public static void main(String[] args) {
&&& String s1 = "Monday";
&&& String s2 = new String("Monday");
&&& if (s1 == s2)
&&& System.out.println("s1 == s2");
&&& System.out.println("s1 != s2");
&&& if (s1.equals(s2)) System.out.println("s1 equals s2");
&&& System.out.println("s1 not equals s2");
我们将s2用new操作符创建
&&& 程序输出:
&&& s1 != s2
&&& s1 equals s2
&&& 说明:s1 s2分别引用了两个"Monday"String对象
&&& 3. 字符串缓冲池
&&& 原来,程序在运行的时候会创建一个字符串缓冲池当使用 s2 = "Monday" 这样的表达是创建字符串的时候,程序首先会在这个String缓冲池中寻找相同值的对象,在第一个程序中,s1先被放到了池中,所以在s2被创建的时候,程序找到了具有相同值的 s1
&&& 将s2引用s1所引用的对象"Monday"
&&& 第二段程序中,使用了 new 操作符,他明白的告诉程序:"我要一个新的!不要旧的!"于是一个新的"Monday"Sting对象被创建在内存中。他们的值相同,但是位置不同,一个在池中游泳一个在岸边休息。哎呀,真是资源浪费,明明是一样的非要分开做什么呢?
&&& 再次更改程序:
&&& public class TestString {
&&& public static void main(String[] args) {
&&& String s1 = "Monday";
&&& String s2 = new String("Monday");
&&& s2 = s2.intern();
&&& if (s1 == s2)
&&& System.out.println("s1 == s2");
&&& System.out.println("s1 != s2");
&&& if (s1.equals(s2)) System.out.println("s1 equals s2");
&&& System.out.println("s1 not equals s2");
&&& 这次加入:s2 = s2.intern();
&&& 程序输出:
&&& s1 == s2
&&& s1 equals s2
&&& 原来,(java.lang.String的intern()方法"abc".intern()方法的返回值还是字符串"abc",表面上看起来好像这个方法没什么用处。但实际上,它做了个小动作:检查字符串池里是否存在"abc"这么一个字符串,如果存在,就返回池里的字符串;如果不存在,该方法会把"abc"添加到字符串池中,然后再返回它的引用。
&&& 更好的办法:
&&& 把所有的String都intern()到缓冲池去吧
&&& 最好在用到new的时候就进行这个操作
&&& String s2 = new String("Monday").intern();
&&& 然后就可以用==比较两个字符串的值了
二、简单数据类型和封装类中的equals和==
&&& Java为每一个简单数据类型提供了一个封装类,每个基本数据类型可以封装成对象类型。
&&& 除int(Integer)和char(Character),其余类型首字母大写即成封装类类型名。double (Double), float(Float),long(Long), short(Short),byte(Byte),boolean(Boolean).
&&& 以int和Integer为例说明
&&& Java中int和Integer区别如下:
&&& 1.int是基本的数据类型,默认值可以为0;2.Integer是int的封装类,默认值为null;3.int和Integer都可以表示某一个数值;4.int和Integer不能够互用,因为他们两种不同的数据类型;
&&& int a1=1;
&&& int a2=1;
&&& Integer b1 =new Integer (1);
&&& Integer b2 =new Integer (1);
& ------------------------------
&&& a1==a2 这个是成立的,很简单,都知道a1==b1 这个是不成立的.表达式的值为 false ,它们是不同的数据类型b1==b2 这个也是不成立的.表达式的值为 false,虽然是相同的数据类型,但是它们是两个对象,==比较的是2个对象的地址,它们的地址是不相等的,内容相等都是1;
&&& b1.equals(b2)==true 这个是成立的,表达式的值为 true. 相同数据类型,两个对象,地址不同,内容相同, quals比较的是2个对象的内容,所以成立。
&&& (a.equals(b),因为equals比较的是两个对象,所以a,b都不能为基本数据类型,否则会出编译错误。)同理,其它的封装类和基本类型也是这样的.
&&& java中equals和==的区别
&&& ==比较的是2个对象的地址,而equals比较的是2个对象的内容。
&&& 三、其他类怎么使用equals和==
&&& API里的类大部分都重写了equals方法,没有重写的一般是自己写的类,如果是你自己定义的一个类,比较自定义类用equals和==是一样的,都是比较句柄地址,因为自定义的类是继承于object,而object中的equals就是用==来实现的,你可以看源码。
&&& 四、java里equals和hashCode之间什么关系
&&& 只是为了维护 hashCode 方法的常规协定,才要求用equals比较的两个对象的hashCode相同. equals()和hashCode()都来自java.lang.Object.你当然可以重写.
&&& 比如a.equals(b).仅当a的内存地址相等时,才返回true.当然如String等类已经对这个方法进行了重写,比较的就不再是内存地址了. hashCode()的值也是与内存地址相关的.所以仅当内存地址相等时,hashCode才相等.
&&& 同样很多类也重写了这个方法,还是以String为例:
&&& public int hashCode() {
&&& int h =
&&& if (h == 0) {
&&& int off =
&&& char val[] =
&&& int len =
&&& for (int i = 0; i & i++) {
&&& h = 31*h + val[off++];
&&& hash =
&&& 就不在与内存地址相关了.这样做是为了保证用equals比较返回为true的两个对象,他们的hashCode是相同的.
&&& 所以一般重写equals的时候都会重写hashCode().当然,这个相当于一个约定,一个协议.你不这么做并不会错.
&&& 五、hashCode
&&& 在一般的应用中你不需要了解hashcode的用法,但当你用到hashmap,hashset等集合类时要注意下hashcode。
&&& 你想通过一个object的key来拿hashmap的value,hashmap的工作方法是,通过你传入的object的hashcode在内存中找地址,当找到这个地址后再通过equals方法来比较这个地址中的内容是否和你原来放进去的一样,一样就取出value。
&&& 所以这里要匹配2部分,hashcode和equals但假如说你new一个object作为key去拿value是永远得不到结果的,因为每次new一个object,这个object的hashcode是永远不同的,所以我们要重写hashcode,你可以令你的hashcode是object中的一个恒量,这样永远可以通过你的object的hashcode来找到key的地址,然后你要重写你的equals方法,使内存中的内容也相等。。。
TA的最新馆藏[转]&[转]&[转]&[转]&[转]&[转]&equals与==之间的区别 -
- ITeye技术网站
equals与==之间的区别
1. 简单数据类型的比较
在java中!简单数据类型的比较是通过==
来进行的。在比较中!只要表达式两边的“值”是相
等的!那么表达式的结果就是true!否则为false。
2. 复杂数据类型的比较
复杂数据类型的比较可以采用“==”,也可以采用"equals"方法进行比较.
如:
Object a = new& Object();
Object b = new& Object();
a==b 的结果应返回false。因为"=="在比较复
杂数据类型的时候(比较的是是否是同一个对象(
只有两个变量指向的是同一个对象的时候( 才能
返回true. 也就是说(在比较的时候(也比较了对象
的地址信息. 只有地址相同的对象才能够返回
true. 而new运算符在每一次运算时(都将会产生
一个新的对象( 每一个新的对象都有自己的内存
和地址. 所以上文代码的比较结果是false。
如果将代码改写为如下形式:
Object a = new& Object();
Object b =
那么a==b 的结果将返回true.
如果使用equals()方法,那么应注意该方法是
在哪一个类中实现的, 以及该方法实现的具体形
式.在类Object中,该方法的比较与"=="的比较具
有同样的效果.如下代码将输出false.
public static void main(String args[])
{
&& Object a = new Object();
&& Object b = new Object();
&& System.out.println(a.equals(b));
}
但是,如果比较的数据类型不是Object,而是
其他的数据类型String,StringBuffer 以及各
种包裹类等,这些类中重写了Object类中的函数
equals(),所以在调用equals()方法时将跟据多态
的规则来进行调用,而不一定是要使用Object类
中定义的equals()方法.如下例代码将输出true.
public static void main(String args[])
{
&& String a = new String("hello");
&& String b = new String("hello");
&& System.out.println(a.equals(b));
}
此时调用的是String类中的函数equals(),所
以比较的结果就不同了,它比较时只比较对象的
内容,也就是说,只要字符串中的每一个字符对应
相等,那么字符串对象是相等的,而不管对象的地
址是否相同,对象是否是同一个对象.
上例代码改写为如下形式,将依然返回false.
public static void main(String args[])
{
&& String a = new String("hello");
&& String b = new String("hello");
&& System.out.println(a==b);
}
由此可以看出,equals()方法的重写不影响
"=="的比较规则.
在String类中,除了重写了一个equals()函数
来进行比较外,还有一个函数也可以用于字符串
的比较equalsIgnoreCase(),它的比较规则是只要
字符串对象的对应字符是相等的,那么对象是相
等的,而且,在比较对应的字符的时候,认为大写
字母与小写字母是相等的,如下代码输出true.
public static void main(String args[])
{
&& String a = new String("HELLO");
&& String b = new String("hello");
&& System.out.println(a.equalsIgnoreCase(b));
}
magic_agate
浏览: 62710 次
来自: 武汉
hechuangqiang 写道配置了老半天,tomcat能运 ...
配置了老半天,tomcat能运行,但去启动当前项目,怎么回事啊 ...
555[u][/u]
window.onload 必须是赋值为function类型的 ...

我要回帖

更多关于 显卡风扇在转电脑黑屏 的文章

 

随机推荐