首页 > 编程语言 > 详细

java编程思想 -- 多态

时间:2015-03-11 02:15:20      阅读:379      评论:0      收藏:0      [点我收藏+]

:?向上转型和向下转型

面向对象中的转型只会发生在有继承关系的子类和父类中(接口的实现也包括在这里)。
父类:人????子类:男人
向上转型:?Person?p?=?new?Man()?;?//向上转型不需要强制类型转化
向下转型:?Man?man?=?(Man)new?Person()?;?//必须强制类型转化

?

向上转型??子类创建对象时,可以使用向上转型的形式操作,方法程序的后期维护,??List队列也是使用的向上转型

?

?

package com.wj.interfaceDemo;

/**
 *向上转型
 */
 class People{ //定义一个基类:三个属性和打印属性的方法
	String name ="java",sex="android";//名字和性别
	int age=15;//年龄
	//打印输出
	public void getAll(){
		System.out.println("name:"+name+"  sex:"+sex+"  age:"+age);
	}
	
}

 //子类继承基类
 public class Man extends People{
	 //主方法
	public static void main(String[] args) {
		//向上转型  
		Man p = new Man();
		//调用父类的方法
		p.getAll();
	}
}

?

?

运行结果:

?name:java??sex:android??age:15

?

<!--[if !supportLists]-->2)<!--[endif]-->,向下转型

子类必须强制的转型为父类的数据类型

???向下转型:?Man?man?=?(Man)new?Person()?;?//必须强制类型转化

向上转型子类不需要强制转型为父类的数据类型

?

向下转型不要使用?一下的方式

?

?

A?demo?=(A)?new?ManDemo();

demo.getName();

?

/**
 * 向下转型
 */


class ManDemo {
	String name = "android";

	public void getName() {
		System.out.println(name);
	}
}

//A类继承ManDemo
class A extends ManDemo {

}

public class PeopleDemo {
	public static void main(String[] args) {
		// 向下转型
		// cannot convert from ManDemo to PeopleDemo
		// 必须要向上转型,ManDemo不可以转为PeopleDemo
		// PeopleDemo p=new ManDemo();
		// 向下转型必须要是子类才可以转型
		ManDemo demo = new A();
		// 将父类转为子类
		A a = (A) demo;
		// 调用父类的方法
		a.getName();

		// *************第二种转型
		ManDemo demos = new A();
		//使用instanceof控制类型,防止类型不一样的情况
		if(demos instanceof A){
			//转为A
		A aa = (A) demos;
        aa.getName();
		}
	}
}

?运行结果;

?????android

???android

?

?

:多态:允许不同类的对象对同一消息做出处理

package com.wj.interfaceDemo;

//*多态

public class Shape {
	public static void main(String[] args) {
		// 创建对象时使用的是多态
		ShapeMain s = new ShapeMain();
		s = new Circle();
		// 此时的s.draw()调用的是父类还是子类的方法
		s.draw();
	}

}

// 基类
class ShapeMain {
	// 基类定义方法
	public void draw() {
		System.out.println("ShapeMain");
	};
}

// Circle继承基类
class Circle extends ShapeMain {
	@Override
	// 重写基类基类的方法
	public void draw() {
		System.out.println("Circle");
	};
}

?运行结果:

??Circle

?

三;多态的缺陷缺陷?

?

<!--[if !supportLists]-->1)<!--[endif]-->.不能覆盖?私有方法?

package com.wj.interfaceDemo;

//覆盖私有的方法

public class PrivateOverride {

	private void f() {
		System.out.println("private f()");
	}

	public static void main(String[] args) {   创建
		PrivateOverride p = new Derived();
		p.f();//调用f()方法
	}
}

class Derived extends PrivateOverride {
	public void f() {
		System.out.println("public f()");
	}
}

?运行结果:

???Private?f()

?

???从前面写的程序中一眼就看出执行的结果是:public?f(),??但是多态中是不能够覆盖私有方法?如果存在私有的方法就睡直接在前面加上final??执行结果为private?f()??,只有非private的方法才可以被覆盖??这是多态的缺陷之一

?

?

?

<!--[if !supportLists]-->2)<!--[endif]-->缺陷?:不能覆盖域与静态方法

???

???What?is?a?field?in?java?

?

A?field?is?an?attribute.?A?field?may?be?a?class‘s?variable,?an?object‘s?variable,?an?object‘s?method‘s?variable,?or?a?parameter?of?a?function.

package com.wj.interfaceDemo;

class Super{
	public int field=0;
	public int getField(){
		return field;	
	}
}


class Sub extends Super{
	public int field=1;
	public int getField(){
		return field;	
	}
	
	public int getSuperField(){
		//调用父类的Field
		return super.field;
		
	}
}

public class FieldAccess {

	public static void main(String[] args) {
		//创建对象	
		Super sup=new Sub();
		System.out.println("sup.field ="+sup.field+"  sup.getField()="+sup.getField());
	   //创建对象
		Sub sub = new Sub();
	   System.out.println("sub.field ="+sub.field+"  sub.getField()="+sub.getField()+" sub.getSuperField() ="+sub.getSuperField());

	}
}

?sup.field?=0??sup.getField()=1

sub.field?=1??sub.getField()=1?sub.getSuperField()?=0

?

3),不能覆盖静态属性和方法

package com.wj.interfaceDemo;
/*
 * 多态性不能覆盖静态方法
 */

class StaticSuper{
	//静态属性
	public static String getName(){
		return "java";
	}
	
	public String getSex(){
		return "男";
	}
	//静态方法
	static int age=10;
}

class StaticSub extends StaticSuper{
	//静态方法
	public static String getName(){
		return "android";
	}
	
	public String getSex(){
		return "女";
	}
	//静态属性
	static int age=7;
}

public class StaticField {

	public static void main(String[] args) {
		//静态属性在多态性中是不能被覆盖的
		StaticSuper s=new StaticSub();
		System.out.println(s.getName());
		System.out.println(s.getSex());
		System.out.println(s.age);
	}
}

?运行结果:

java

10

?

:构造器的执行顺序

? ?构造器是不同于其它种类的方法,涉及到多态时也是如此,构造器是不具有多态性的,通过static方法,static为隐式的

package com.wj.interfaceDemo;

/*构造器的调用顺序
 */

class Construct1 {
	public Construct1() {
		print();
	}

	private int print() {
		System.out.println("Construct1");
		return 1;
	}
}

class Construct2 extends Construct1 {
	public Construct2() {
		print();
	}

	private int print() {
		System.out.println("Construct2");
		return 2;

	}
}

class Construct3 extends Construct2 {
	public Construct3() {
		print();
	}

	private int print() {
		System.out.println("Construct3");
		return 3;
	}
}

public class Construct {
	public static void main(String[] args) {
	Construct1 c = new Construct3();
	}

}

运行结果:

?Construct1

Construct2

Construct3

?

五:用继承进行设计

package com.wj.interfaceDemo;

/**
 * 用继承设计
 */

class Actor {
	public void act() {
	}
}

class HappyActor extends Actor {
	public void act() {
		System.out.println("HappyActor");
	}
}

class SadActor extends Actor {
	public void act() {
		System.out.println("SadActor");
	}
}

class Stage {
	private Actor actor = new HappyActor();

	public void change() {
		actor = new SadActor();
	}

	public void performplay() {
		actor.act();
	}
}

public class ExtendsDesign {
	public static void main(String[] args) {
		Stage stage = new Stage();
		stage.performplay();
		stage.change();
		stage.performplay();
	}
}

?实现没有搞清楚用继承设计到底讲的什么,求大神指教

?

?

java编程思想 -- 多态

原文:http://baihe747.iteye.com/blog/2191212

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!