A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 杨盼 中级黑马   /  2012-3-4 19:18  /  2111 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

在查询信息时,以instanceof的形式与直接比较Class对象有什么差别

评分

参与人数 1技术分 +1 收起 理由
老罗 + 1

查看全部评分

4 个回复

正序浏览
哦了,差不多明白了
回复 使用道具 举报
  1. package LianXi;
  2. public class TestDemo
  3. {
  4.         public static void main(String[] args)
  5.         {

  6.                 A objA = new A();
  7.                 A objA2 = new A();
  8.                 Class  classA = objA.getClass();
  9.                 B objB = new B();
  10.                 Class classB = objB.getClass();

  11.                 if( objB instanceof A)
  12.                          print("objA 是 A 类型");

  13.                 if(classA == objA2.getClass())
  14.                         print("证明相同类型的class实例是单例模式");

  15.                 if(classA == classB)
  16.                         print("objA 与 objB是同一个类型的变量");
  17.                 else
  18.                         print("不同类型的实例的class实例是不同的");
  19.                 if(     objB instanceof Object &&
  20.                                 objB instanceof AbBase &&
  21.                                 objB instanceof Base&&
  22.                                 objB instanceof A &&
  23.                                 objB instanceof B &&
  24.                                 objB instanceof I )
  25.                         print("只要类型T 在某个对象继承链上 instanceof T 都会返回 true");
  26.        
  27.                        
  28.         }

  29.         public static void print(Object o){
  30.                 System.out.println(o);
  31.         }
  32. }

  33. abstract  class AbBase
  34. {
  35. }
  36. class Base extends AbBase
  37. {
  38. }

  39. class A extends Base
  40. {
  41. }

  42. class B extends A
  43.                         implements I
  44. {
  45. }

  46. class C implements I
  47. {
  48. }

  49. interface I
  50. {
  51. }
复制代码
不知道 下面的代码能不能说明白。我想应该是比较清楚的了

评分

参与人数 1技术分 +2 收起 理由
老罗 + 2

查看全部评分

回复 使用道具 举报
本帖最后由 田啸 于 2012-3-4 20:57 编辑

这里对比下instance of和equals的区别:
instanceof 看一个对象(或称为引用)是否与某类兼容。兼容的有其自身所属的类、所有的父类、实现的所有接口及这些接口的父接口。这样返回为true
Java语言对equals()的要求如下,这些要求是必须遵循的(也是两者的主要区别):  
对称性:如果x.equals(y)返回是“true”,那么y.equals(x)也应该返回是“true”。 对于instance of就不一定了: 如果a是b的子类对象 a instanceof b 为true ,但 b instanceof a就是false了,关于下面几点可以自己推敲下.   
反射性:x.equals(x)必须返回是“true”。
类推性:如果x.equals(y)返回是“true”,而且y.equals(z)返回是“true”,那么z.equals(x)也应该返回是“true”。
还有一致性:如果x.equals(y)返回是“true”,只要x和y内容一直不变,不管你重复x.equals(y)多少次,返回都是“true”。
任何情况下,x.equals(null),永远返回是“false”;x.equals(和x不同类型的对象)永远返回是“false”。
String 、Math、还有Integer、Double。。。。等这些封装类在使用equals()方法时,已经覆盖了object类的equals()方法。是进行的内容比较,而已经不再是地址的比较。




评分

参与人数 1技术分 +2 收起 理由
老罗 + 2

查看全部评分

回复 使用道具 举报
instanceof操作符用于判断一个引用类型所引用的对象是否是一个类的实例
对于引用类型变量,Java 编译器只根据变量被先生声明的类去编译。
   instanceof 左边操作元被显式声明的类型与右边操作元必须是同种类或者有继承关系,即位于继承树的同一个继承分支上,否则编译出错
Object 类的 equals() 方法的比较规则为:当参数 obj 引用的对象与当前对象为同一个对象时,就返回true,否则返回false
在JDK中有一些类覆盖了 Object 类的equals()方法,它们的比较规则为:
  如果两个对象的类型一致,并且内容一致,则返回true。
这些类包括:java.io.File、java.util.Date、java.lang.String、包装类(如java.lang.Integer和java.lang.Double类)。
如果是自己定义的类的话,可以复写equals()方法,自己定义比较规则

Java语言对equals()的要求如下,这些要求是必须遵循的,以下几点也算是和instance of 的区别:
• 对称性:如果x.equals(y)返回是“true”,那么y.equals(x)也应该返回是“true”。
• 反射性:x.equals(x)必须返回是“true”。
• 类推性:如果x.equals(y)返回是“true”,而且y.equals(z)返回是“true”,那么z.equals(x)也应该返回是“true”。
• 还有一致性:如果x.equals(y)返回是“true”,只要x和y内容一直不变,不管你重复x.equals(y)多少次,返回都是“true”。
• 任何情况下,x.equals(null),永远返回是“false”;x.equals(和x不同类型的对象)永远返回是“false”。

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马