马士兵J2SE-第三章-面向对象-Object类:toString方法、equals方法、对象转型、抽象类抽象方法、final关键字、接口

简介:

toString方法

public class test {
	public static void main(String[] args) {
		Teacher t=new Teacher();
		System.out.println("1 "+t+" 2 "+t.toString());
	}
}


class Teacher {
	public String toString() {
		return "I am a teacher";
	}
}

输出:

1 I am a teacher 2 I am a teacher

说明:

public String toString() {return "I am a teacher";}不能写成大写的public String ToString!

重写必须要COPY过来!

toString

public String toString()
返回该对象的字符串表示。通常, toString 方法会返回一个“以文本方式表示”此对象的字符串。结果应是一个简明但易于读懂的信息表达式。建议所有子类都重写此方法。

Object 类的 toString 方法返回一个字符串,该字符串由类名(对象是该类的一个实例)、at 标记符“@”和此对象哈希码的无符号十六进制表示组成。换句话说,该方法返回一个字符串,它的值等于:

getClass().getName() + '@' + Integer.toHexString(hashCode())
 

返回:
该对象的字符串表示形式。

认识一下toString方法,并且重写父类方法!

 

 equals方法:

public class test {
	public static void main(String[] args) {
		Cat c1=new Cat(1,2,3);
		Cat c2=new Cat(1,2,3);
		System.out.println(c1==c2);
	}
}

class Cat {
   	int color;
    int height,weight;
    public Cat(int color,int height,int weight) {
    	this.color=color;
    	this.height=height;
    	this.weight=weight;
    }
}

//永远不等,比较的是地址


输出:

false

 

 

public class test {
	public static void main(String[] args) {
		Cat c1=new Cat(1,2,3);
		Cat c2=new Cat(1,2,3);
		System.out.println(c1==c2);
		System.out.println (c1.equals(c2));
	}
}

class Cat {
   	int color;
    int height,weight;
    public Cat(int color,int height,int weight) {
    	this.color=color;
    	this.height=height;
    	this.weight=weight;
    }
    
    //重写方法
    public boolean equals(Object obj) {
    	return true;
    }//永远都相等,不好!就是写在这里需要注意一下重写要从JDK文档中COPY一下
}

//永远不等,比较的是地址


输出:

 false
true

 

 重写equals方法正确写法

public class test {
	public static void main(String[] args) {
		Cat c1=new Cat(1,2,3);
		Cat c2=new Cat(1,2,3);
		System.out.println(c1==c2);
		System.out.println (c1.equals(c2));
	}
}

class Cat {
   	int color;
    int height,weight;
    
    public Cat(int color,int height,int weight) {
    	this.color=color;
    	this.height=height;
    	this.weight=weight;
    }
    
    //重写方法
    public boolean equals(Object obj) {
    	if(obj==null) return false;
    	else {
    		if(obj instanceof Cat) {//如果obj是猫对象的一个引用
    			Cat c=(Cat)obj;//obj强制转化为猫类型
    			if(c.color==this.color&&c.height==this.height&&c.weight==this.weight) {
    				return true;
    			}
    		}
    	}
    	return false;
    }
}


输出:

false
true

 

 

public class test {
	public static void main(String[] args) {
		Cat c1=new Cat(1,2,3);
		Cat c2=new Cat(1,2,3);
		System.out.println(c1==c2);
		System.out.println (c1.equals(c2));
		
		
		String s1=new String("Hello");
		String s2=new String("Hello");
		System.out.println(s1==s2);
		
		//java.lang包下的string重写了equals方法
		//将此字符串与指定的对象比较。当且仅当该参数不为 null,并且是与此对象表示相同字符序列的 String 对象时,结果才为 true。 
		System.out.println(s1.equals(s2));//s2不为空,是true
	}
}

class Cat {
   	int color;
    int height,weight;
    
    public Cat(int color,int height,int weight) {
    	this.color=color;
    	this.height=height;
    	this.weight=weight;
    }
    
    //重写方法
    public boolean equals(Object obj) {
    	if(obj==null) return false;
    	else {
    		if(obj instanceof Cat) {//如果obj是猫对象的一个引用
    			Cat c=(Cat)obj;//obj强制转化为猫类型
    			if(c.color==this.color&&c.height==this.height&&c.weight==this.weight) {
    				return true;
    			}
    		}
    	}
    	return false;
    }
}


输出:

 false
true
false
true

equals

public boolean equals(Object obj)
指示其他某个对象是否与此对象“相等”。

equals 方法在非空对象引用上实现相等关系:

  • 自反性:对于任何非空引用值 xx.equals(x) 都应返回 true
  • 对称性:对于任何非空引用值 xy,当且仅当 y.equals(x) 返回true 时,x.equals(y) 才应返回true
  • 传递性:对于任何非空引用值 xyz,如果 x.equals(y) 返回 true,并且 y.equals(z) 返回 true,那么x.equals(z) 应返回true
  • 一致性:对于任何非空引用值 xy,多次调用 x.equals(y) 始终返回true 或始终返回false,前提是对象上equals 比较中所用的信息没有被修改。
  • 对于任何非空引用值 xx.equals(null) 都应返回 false

Object 类的 equals 方法实现对象上差别可能性最大的相等关系;即,对于任何非空引用值 xy,当且仅当xy 引用同一个对象时,此方法才返回truex == y 具有值true)。

注意:当此方法被重写时,通常有必要重写 hashCode 方法,以维护 hashCode 方法的常规协定,该协定声明相等对象必须具有相等的哈希码。

参数:
obj - 要与之比较的引用对象。
返回:
如果此对象与 obj 参数相同,则返回 true;否则返回 false
另请参见:
hashCode(), Hashtable

 对象转型:

class Animal {
	public String name;
	Animal(String name) {
		this.name=name;
	}
}

class Cat extends Animal {
	public String eyesColor;
	Cat(String n,String c) {
		super(n);
		eyesColor=c;
	}
}

class Dog extends Animal {
	public String furcolor;
	Dog(String n,String c) {
		super(n);
		furcolor=c;
	}
}

public class test {
	public static void main(String[] args) {
		Animal a=new Animal("name");
		Cat c=new Cat("name","blue");
		Dog d=new Dog("dogname","black");
		
		System.out.println(a instanceof Animal);//true
		System.out.println(c instanceof Animal);//true
		System.out.println(d instanceof Animal);//true
		System.out.println(a instanceof Cat);//false
		
		a=new Dog("bigyellow","yellow");;
		System.out.println(a.name);//bigyellow
		//System.out.println(a.furname);//error!
		System.out.println(a instanceof Animal);//true
		System.out.println(a instanceof Dog);//true
		Dog d1=(Dog)a;//要加强制你转换符
		System.out.println(d1.furcolor);//yellow
		
	}
}


输出:

true
true
true
false
bigyellow
true
true
yellow

 

 

class Animal {
	public String name;
	Animal(String name) {
		this.name=name;
	}
}

class Cat extends Animal {
	public String eyesColor;
	Cat(String n,String c) {
		super(n);
		eyesColor=c;
	}
}

class Dog extends Animal {
	public String furcolor;
	Dog(String n,String c) {
		super(n);
		furcolor=c;
	}
}

public class test {
	public static void main(String[] args) {
		test testdemo=new test();
		Animal a=new Animal("name");
		Cat c=new Cat("catname","blue");
		Dog d=new Dog("dogname","black");
		testdemo.f(a);
		testdemo.f(c);
		testdemo.f(d);
	}
	
	public void f(Animal a) {
		System.out.println("name:"+a.name);
		if(a instanceof Cat) {
			Cat cat=(Cat) a;
			System.out.println(" "+cat.eyesColor+" eyes");
		}
			else if(a instanceof Dog) {
				Dog dog =(Dog) a;
				System.out.println(" "+dog.furcolor+" fur");
			}
	}
}
输出:

name:name
name:catname
 blue eyes
name:dogname
 black fur


abstract class Animal {//有了抽象方法,这个类必须被声明为抽象类
  private String name;
  Animal(String name) {this.name = name;}
  /*
  public void enjoy(){
    System.out.println("叫声......");
  }
  */
  //抽象类的方法没有写的必要
  public abstract void enjoy();//只有;没有左右大括号定义,相当于C++里的纯虚函数
}

abstract class Cat extends Animal {
  private String eyesColor;
  Cat(String n,String c) {super(n); eyesColor = c;}
  /*
  public void enjoy() {
    System.out.println("猫叫声......");
  }
  */
  //public abstract void enjoy();
}

class Dog extends Animal {
  private String furColor;
  Dog(String n,String c) {super(n); furColor = c;}
 
  public void enjoy() {
    System.out.println("狗叫声......");
  }
}

class Bird extends Animal {
	 Bird() {
	 	 super("bird");
	 }
	 public void enjoy() {
    System.out.println("鸟叫声......");
  }
}

class Lady {
    private String name;
    private Animal pet;
    Lady(String name,Animal pet) {
        this.name = name; this.pet = pet;
    }
    public void myPetEnjoy(){pet.enjoy();}
}

public class test {
    public static void main(String args[]){
        //Cat c = new Cat("catname","blue");//抽象的类是残缺的类,NEW不出来
        Dog d = new Dog("dogname","black");
        Bird b = new Bird();
        //Lady l1 = new Lady("l1",c);
        Lady l2 = new Lady("l2",d);
        Lady l3 = new Lady("l3",b);
       //l1.myPetEnjoy();
        l2.myPetEnjoy();
        l3.myPetEnjoy();
    }
}


输出:

狗叫声......
鸟叫声......

 


 final关键字

public class test {
	public static void main(String[] args) {
		T t=new T();
		System.out.println(t.i);
	}
}

final class T {
	final int i = 8;
	public final void m() {
		//j=9;
	}
}


输出:

8

说白了,就是只可以读不可以写

 

 

 

 接口:

interface Singer {
	public void sing();
	public void sleep();
}

interface Painter {
	public void paint();
	public void eat();
}

class Student implements Singer {
	private String name;
	
	Student(String name) {
		this.name=name;
	}
	
	public void study() {
		System.out.println("studying");
	}
	
	public String getName() {
		return name;
	}
	
	public void sing() {
		System.out.println("student is singing");
	}
	
	public void sleep() {
		System.out.println("student is sleeping");	
	}
}


class Teacher implements Singer,Painter {
	private String name;
	
	public String getString() {
		return name;
	}
	
	Teacher(String name) {this.name=name;}
	
	public void teach() {
		System.out.println("teacher is teaching");
	}
	
	public void sing() {
		System.out.println("teacher is singing");
	}
	public void sleep() {
		System.out.println("teacher is sleeping");
	}
	public void eat() {
		System.out.println("teacher is eating");
	}

	@Override
	public void paint() {
		// TODO Auto-generated method stub
		System.out.println("teacher is painting");
	}
}

public class test {
	public static void main(String[] args) {
		Singer s1=new Student("tom");
		s1.sing();
		s1.sleep();
		Teacher t1=new Teacher("jack");
		t1.eat();
		t1.sing();
		t1.sleep();
		t1.paint();
		Painter p1=(Painter)t1;
		p1.paint();
		p1.eat();
	}

}


输出:

student is singing
student is sleeping
teacher is eating
teacher is singing
teacher is sleeping
teacher is painting
teacher is painting
teacher is eating

 

 


 

 

目录
相关文章
|
5天前
|
C#
c# 所有类的最终基类:Object
c# 所有类的最终基类:Object
5 0
|
20天前
|
XML JSON Java
作为所有类的顶层父类,没想到Object的魔力如此之大!
在上一篇博文中我们提到了Java面向对象的四大特性,其中谈及“抽象”特性时做了一个引子,引出今天的主人公Object,作为所有类的顶级父类,Object被视为是James.Gosling的哲学思考,它高度概括了事务的自然与社会行为。
53 13
|
20天前
|
存储 Java 开发者
Java Object类
Java Object类
14 0
|
1月前
|
JavaScript
js 字符串String转对象Object
该代码示例展示了如何将一个以逗号分隔的字符串(`'1.2,2,3,4,5'`)转换为对象数组。通过使用`split(',')`分割字符串并`map(parseFloat)`处理每个元素,将字符串转换成浮点数数组,最终得到一个对象数组,其类型为`object`。
|
2月前
|
存储 设计模式 Python
Python中的类(Class)和对象(Object)
Python中的类(Class)和对象(Object)
32 0
|
2月前
|
存储 JavaScript
JS中Map对象与object的区别
JS中Map对象与object的区别
|
3月前
|
Java 流计算
在Flink实时任务中,POJO(Plain Old Java Object)对象的模式演进可能会引起不兼容的问题
【2月更文挑战第6天】在Flink实时任务中,POJO(Plain Old Java Object)对象的模式演进可能会引起不兼容的问题
22 3
|
7月前
|
Java
【面试题精讲】Object类的常见方法有哪些?
【面试题精讲】Object类的常见方法有哪些?
|
8月前
|
Java API 开发工具
Java之API详解之Object类的详细解析(下)
Java之API详解之Object类的详细解析(下)
40 0
|
7月前
|
Java
Java常用类--------Object类
Java常用类--------Object类