1.Java基础-面向对象编程思想(封装继承多态接口)

封装:java

1.定义:隐藏对象的属性和实现细节,仅对外公开接口,控制在程序中属性的读和修改的访问级别。编程

2.封装的目的是:加强安全性和简化编程,使用者没必要了解具体的实现细节,而只是要经过外部接口,一特定的访问权限来使用类的成员。安全

3.封装的基本要求是:把全部的属性私有化,对每一个属性提供getter和setter方法,若是有一个带参的构造函数的话,那必定要写一个不带参的构造函数。在开发的时候常常要对已经编写的类进行测试,因此在有的时候还有重写toString方法,但这不是必须的。函数

 

继承:测试

1.目的:实现代码的复用。this

2.介绍:当两个类具备相同的特征(属性)和行为(方法)时,能够将相同的部分抽取出来放到一个类中做为父类,其它两个类继承这个父类。继承后子类自动拥有了父类的属性和方法,但特别注意的是,父类的私有属性和构造方法并不能被继承。另外子类能够写本身特有的属性和方法,目的是实现功能的扩展,子类也能够复写父类的方法即方法的重写。子类不能继承父类中访问权限为private的成员变量和方法。子类能够重写父类的方法,及命名与父类同名的成员变量。有时候咱们须要这样的需求:咱们须要将某些事物尽量地对这个世界隐藏,可是仍然容许子类的成员来访问它们。这个时候就须要使用到protected。.net

 

 

 

 

 

多态:设计

1.概念:相同的事物,调用其相同的方法,参数也相同时,但表现的行为却不一样。指针

 

2. Java实现多态有三个必要条件:继承、重写、向上转型。对象

         继承:在多态中必须存在有继承关系的子类和父类。

         重写:子类对父类中某些方法进行从新定义,在调用这些方法时就会调用子类的方法。

         向上转型:在多态中须要将子类的引用赋给父类对象,只有这样该引用才可以具有技能调用父类的方法和子类的方法。

      只有知足了上述三个条件,咱们才可以在同一个继承结构中使用统一的逻辑实现代码处理不一样的对象,从而达到执行不一样的行为。

 

3.多态的实现方式:

 

 

(1)基于继承实现的多态

      基于继承的实现机制主要表如今父类和继承该父类的一个或多个子类对某些方法的重写,多个子类对同一方法的重写能够表现出不一样的行为。

 

 

(2)基于接口实现的多态

      继承是经过重写父类的同一方法的几个不一样子类来体现的,那么就可就是经过实现接口并覆盖接口中同一方法的几不一样的类体现的。

      在接口的多态中,指向接口的引用必须是指定这实现了该接口的一个类的实例程序,在运行时,根据对象引用的实际类型来执行对应的方法。

      继承都是单继承,只能为一组相关的类提供一致的服务接口。可是接口能够是多继承多实现,它可以利用一组相关或者不相关的接口进行组合与扩充,可以对外提供一致的服务接口。因此它相对于继承来讲有更好的灵活性。

 

4.多态性主要表如今以下两个方面:

 

 

(1)方法重载.一般指在同一个类中,相同的方法名对应着不一样的方法实现,可是方法的参数不一样.
 
(2)成员覆盖.一般指在不一样类(父类和子类)中,容许有相同的变量名,可是数据类型不一样;也容许有相同的方法名,可是对应的方法实现不一样.
 

5.多态的好处:程序的可扩展性及可维护性加强。

 

 

抽象:

1.介绍:在面向对象的概念中,咱们知道全部的对象都是经过类来描绘的,可是并非全部的类都是用来描绘对象的,若是一个类中没有包含足够的信息来描绘一个具体的对象,这样的类就是抽象类。抽象类每每用来表征咱们在对问题领域进行分析、 设计中得出的抽象概念,是对一系列看上去不一样,可是本质上相同的具体概念的抽象,咱们不能把它们实例化(拿不出一个具体的东西)因此称之为抽象。

 

  好比:咱们要描述“水果”,它就是一个抽象,它有质量、体积等一些共性(水果有质量),但又缺少特性(苹果、橘子都是水果,它们有本身的特性),咱们拿不出惟一一种能表明水果的东西(由于苹果、橘子都不能表明水果),可用抽象类来描述它,因此抽象类是不可以实例化的。当咱们用某个类来具体描述“苹果”时,这个类就能够继承描述“水果”的抽象类,咱们都知道“苹果”是一种“水果”。

 

2.抽象方法:被abstract修饰的方法是抽象方法,抽象方法没有方法体。修饰符 abstract 返回值类型 函数名();抽象方法的修饰符只能用public或者protected或者没有修饰,不能被final,static,private修饰。

(1)、类即便不包含抽象方法,也能够定义成抽象类。
(2)、类中含有抽象方法的类必定要定义成抽象类。
(3)、抽象类中字段的定义和子类的访问与通常类没有变化。
(4)、扩展抽象类有两种方法,第一种是在子类中定义部分抽象方法或者抽象方法不定义,这样子类也必须定义成抽象类,第二种是定义所有的抽象方法,这样子类就能够不定义成抽象的了。
(5)、抽象类不能被实例化,可是能够定义一个抽象类的对象变量,这个变量能够引用非抽象子类的对象。
(6)、抽象类中包含有构造方法,也能够显式书写构造方法,构造方法在实例化子类的对象中调用。


接口与抽象类的区别:


不一样点:
一、接口能够多实现,而抽象类只能单继承
二、抽象类能够有非抽象的方法和构造方法、变量,可是接口只能有抽象方法,静态常量。
三、抽象类和子类具备父子关系,子类能拥有父类中一些属性。接口虽然某个类实现一个接口,可是因为接口中的变量都为静态常量,不存在继承关系。


相同点:
一、不管接口仍是抽象类,都没法直接实例化,其自身实例化须要靠实现类或子类来实现。
二、接口和抽象类都必须实现其中的全部方法。

 

抽象类(abstract class)的定义方式以下: 


public abstract class AbstractClass             //里面至少有一个抽象方法
{
   public int t;  //普通数据成员
   public abstract void method1();   //抽象方法,抽象类的子类在类中必须实现抽象类中的抽象方法
   public abstract void method2(); 
   public void method3();   //非抽象方法
   public int method4();
   publi int method4 (){
        …… //抽象类中能够赋予非抽象方法方法的默认行为,即方法的具体实现
   }

       public void method3(){
        …… //抽象类中能够赋予非抽象方法方法的默认行为,即方法的具体实现
   } 

}

 

接口(interface)的定义方式以下: 


public interface Interface

   static final int i;  //接口中不能有普通数据成员,只可以有静态的不能被修改的数据成员,static表示全局,final表示不可修改,能够不用static final 修饰,会隐式的声明为static和final
   

   public void method1();  //接口中的方法必定是抽象方法,因此不用abstract修饰
   

   public void method2();  //接口中不能赋予方法的默认行为,即不能有方法的具体实现
}

一、一个接口能够被多个类实现,一个类也能够实现多个接口。
二、接口中全部的定义的字段默认都是public static final 的属性,写和不写没有区别。
三、接口中的方法都是抽象的方法,而且抽象的方法默认都是public abstract修饰的,不能用其余的修饰符修饰,能够不写。
四、接口中没有构造方法
五、接口不是类,尤为不能使用new运算符实例化一个接口。可是能够声明接口的变量,这个变量能够指向实现了此接口的子类。

简言之抽象类是一种功能不全的类,接口只是一个抽象方法声明和静态不能被修改的数据的集合,二者都不能被实例化。


  从某种意义上说,接口是一种特殊形式的抽象类,在java语言中抽象类表示的是一种继承关系,一个类只能继承继承一个抽象类,而一个类却能够实现多个接口。在许多状况下,接口确实能够代替抽象类,若是你不须要刻意表达属性上的继承的话。

 super的用法:

1.     子类的构造函数若是要引用super的话,必须把super放在函数的首位.

class Base {

    Base() {

       System.out.println("Base");

    }

}

 

public class Checket extends Base {

    Checket() {

       super();//调用父类的构造方法,必定要放在方法的首个语句

       System.out.println("Checket");

    }

 

    public static void main(String argv[]) {

       Checket c = new Checket();

    }

}

          若是想用super继承父类构造的方法,可是没有放在第一行的话,那么在super以前的语句,确定是为了知足本身想要完成某些行为的语句,可是又用了super继承父类的构造方法。那么之前所作的修改就都回到之前了,就是说又成了父类的构造方法了。

 

2.       在java中,有时还会遇到子类中的成员变量或方法与超类(有时也称父类)中的成员变量或方法同名。由于子类中的成员变量或方法名优先级高,因此子类中的同名成员变量或方法就隐藏了超类的成员变量或方法,可是咱们若是想要使用超类中的这个成员变量或方法,就须要用到super.

 class Country {

    String name;

 

    void value() {

       name = "China";

    }

}

 

class City extends Country {

    String name;

 

    void value() {

    name = "Hefei";

    super.value();//不调用此方法时,super.name返回的是父类的成员变量的值null

       System.out.println(name);

       System.out.println(super.name);

    }

 

    public static void main(String[] args) {

       City c=new City();

       c.value();

       }

}

         为了在子类中引用父类中的成员变量name和方法value(),在代码中使用了super、super.name和super.value(),若不调用super.value()时,super.name返回父类成员变量默认值null,调用此方法时,super.value()方法把成员变量name赋值为China,再利用super.name调用父类的成员变量的值。

     另外,要注意的是super.name调用的是成员变量的值,

class Country {

    String name="xianfan";

 

    String value(String name) {

       name = "China";

       return name;

    }

}

 

class City extends Country {

    String name;

 

    String value(String name) {

    name = "Hefei";

super.value("失败");//不调用此方法时,super.name返回的是父类的成员变量的值null

       System.out.println(name);

       System.out.println(super.name);

       return name;

    }

 

    public static void main(String[] args) {

       City c=new City();

       c.value("成功");

    }

}

    结果为:Hefei

xianfan

     此时,super.name返回的值是父类成员变量的值xianfan,而此时的super.value()方法是不起做用的。

 

3.用super直接传递参数:

  class Person {

    public static void prt(String s) {

       System.out.println(s);

    }

 

    Person() {

       prt("A Person.");

    }

 

    Person(String name) {

       prt("A person name is:" + name);

    }

}

 

public class Chinese extends Person {

    Chinese() {

       super(); // 调用父类构造函数(1)

       prt("A chinese.");// (4)

    }

 

    Chinese(String name) {

       super(name);// 调用父类具备相同形参的构造函数(2)

       prt("his name is:" + name);

    }

 

    Chinese(String name, int age) {

       this(name);// 调用当前具备相同形参的构造函数(3)

       prt("his age is:" + age);

    }

 

    public static void main(String[] args) {

       Chinese cn = new Chinese();

       cn = new Chinese("kevin");

       cn = new Chinese("kevin", 22);

    }

}

      结果为:A Person.

A chinese.

A person name is:kevin

his name is:kevin

A person name is:kevin

his name is:kevin

his age is:22

          在这段程序中,this和super再也不是像之前那样用“.”链接一个方法或成员,而是直接在其后跟上适当的参数,所以它的意义也就有了变化。super后加参数的是用来调用父类中具备相同形式的构造函数,如1和2处。this后加参数则调用的是当前具备相同参数的构造函数,如3处。固然,在Chinese的各个重载构造函数中,this和super在通常方法中的各类用法也仍可以使用,好比4处,你能够将它替换为“this.prt”(由于它继承了父类中的那个方法)或者是“super.prt”(由于它是父类中的方法且可被子类访问),它照样能够正确运行。但这样彷佛就有点多此一举的味道了。

 

 this的用法:“this是指向对象自己的一个指针”

 

说明在什么状况下须要用到this:


        第1、经过this调用另外一个构造方法,用发是this(参数列表),这个仅仅在类的构造方法中,别的地方不能这么用。


        第2、函数参数或者函数中的局部变量和成员变量同名的状况下,成员变量被屏蔽,此时要访问成员变量则须要用“this.成员变量名”的方式来引用成员变量。固然,在没有同名的状况下,能够直接用成员变量的名字,而不用this。

 

        第3、在函数中,须要引用该函所属类的当前对象时候,直接用this。

 

super和this的异同:

       1)super(参数):调用基类中的某一个构造函数(应该为构造函数中的第一条语句) 

       2)this(参数):调用本类中另外一种造成的构造函数(应该为构造函数中的第一条语句)
       3)super: 它引用当前对象的直接父类中的成员(用来访问直接父类中被隐藏的父类中成员数据或函数,基类与派生类中有相同成员定义时如:super.变量名    super.成员函数据名(实参)

      4)this:它表明当前对象名(在程序中易产生二义性之处,应使用this来指明当前对象;若是函数的形参与类中的成员数据同名,这时需用this来指明成员变量名)

 

      5)调用super()必须写在子类构造方法的第一行,不然编译不经过。每一个子类构造方法的第一条语句,都是隐含地调用super(),若是父类没有这种形式的构造函数,那么在编译的时候就会报错。

      6)super()和this()相似,区别是,super()从子类中调用父类的构造方法,this()在同一类内调用其它方法。

   7)super()和this()均需放在构造方法内第一行。

   8)尽管能够用this调用一个构造器,但却不能调用两个。

   9)this和super不能同时出如今一个构造函数里面,由于this必然会调用其它的构造函数,其它的构造函数必然也会有super语句的存在,因此在同一个构造函数里面有相同的语句,就失去了语句的意义,编译器也不会经过。

 10)this()和super()都指的是对象,因此,均不能够在static环境中使用。包括:static变量,static方法,static语句块。

 11)从本质上讲,this是一个指向本对象的指针, 然而super是一个Java关键字。

 

如下是关于子类父类的构造方法的注意事项:

       

   转载自http://blog.csdn.net/qq_22118507/article/details/51422591

相关文章
相关标签/搜索