java面向对象

快捷键生成构造方法和取值赋值方法Shift + Alt + s

1.继承

*继承是java面向对象编程技术的一块基石,因为它允许创建分等级层次的类。

 *继承就是子类继承父类的特征(属性)和行为(方法),使得子类对象(实例)具有父类的实例域和方法,或子类从父类继承方法,使得子类具有父类相同的行为。

 *格式

 *class 父类{

 *}

 *class 子类 extends 父类{

 *

 *}   

继承的限制:

 *Java中只有单继承,多重继承,没有多继承。

继承内存中过程

私有的外部通过get获取,set设置

继承也不可以直接对私有的s.name设置

This 与 super 不能共存

super:

 *通过super 可以访问父类构造方法

 *         通过super,可以访问父类的属性

 *         通过super,可以访问父类的方法

想用指定的构造方法时通过super调用

调用super构造方法的代码,必须写 在子类构造方法的第一行。

2.重写

重写:子类父类有相同方法

* 重写(override)规则:

 * 1、参 数列表必须完全与被重写方法的相同;

 * 2、返回类型必须完全与被 重写方法的返回类型相同;

 *3 访问权限不能比父类中被重写的方法的访问权限更低。例如:如果父类的一个方法被声明为public,那么在子类中重写该方法就不能声明为protected.

 *4 父类的成员方法只能被它的子类重写。

 *5、声明为staticprivete的方法不能被重写, 但是能够被再次声明。

3.final关键字

 final用于修饰属性、变量。

             变量成为了常量,无法对其再次进行賦值。

             final修饰的局部变量,只能赋值一次 (可以先声明后赋值)

             final修饰的是成员属性,必须在 声明时赋值。

         final用于修饰类

            final修饰的类,不可以被继承

         final用于修饰方法

            final修饰的方法,不能被子类重写。

全局常量( public static final )

常量的命名规范:

1个或多个单词组成,单词与单 词之间必须使用下划线隔开,单词中所有字母大写

例如: SQL_INSERT

4.抽象类

概念

抽象类必须使用abstract class声明

一个抽象类中可以没有抽象方法。抽象方法必须写在抽象类或者接口中。

格式:

abstract class 类名{ // 抽象类

}

抽象方法

只声明而未实现的方法称为抽象方法(未实现指的是:没有“{}”方法体),抽象方法必须使用abstract关键字声明。

格式:

abstract class 类名{ // 抽象类

public abstract void 方法名() ; // 抽象方法,只声明而未实现

}

不能被实例化

在抽象类的使用中有几个原则:

· 抽象类本身是不能直接进行实例化操作的,即:不能直接使用关键字new完成。

· 一个抽象类必须被子类所继承,被继承的子类(如果不是抽象类)则必须覆写(重写)抽象类中的全部抽象方法。

常见问题

1、 抽象类能否使用final声明?

不能,因为final属修饰的类是不能有子类的 , 而抽象类必须有子类才有意义,所以不能。

2、 抽象类能否有构造方法?

能有构造方法,而且子类对象实例化的时候的流程与普通类的继承是一样的,都是要先调用父类中的构造方法(默认是无参的),之后再调用子类自己的构造方法。

我们不可以用new创建但是java的虚拟机是可以创建的

抽象类和普通类的区别

1、抽象类必须用public或protected修饰(如果为private修饰,那么子类则无法继承,也就无法实现其抽象方法)。

默认缺省为 public

2、抽象类不可以使用new关键字创建对象, 但是在子类创建对象时, 抽象父类也会被JVM实例化。

3、如果一个子类继承抽象类,那么必须实现其所有的抽象方法。如果有未实现的抽象方法,那么子类也必须定义为

abstract

5.接口

概念

如果一个类中的全部方法都是抽象方法,全部属性都是全局常量,那么此时就可以将这个类定义成一个接口。

定义格式:

interface 接口名称{

全局常量 ;

抽象方法 ;

}

面向接口编程思想

这种思想是接口是定义(规范,约束)与实现(名实分离的原则)的分离。

优点:

1、 降低程序的耦合性

2、 易于程序的扩展

3、 有利于程序的维护

全局常量和抽象方法的简写

因为接口本身都是由全局常量和抽象方法组成 , 所以接口中的成员定义可以简写:

1、全局常量编写时, 可以省略public static final 关键字,例如:

public static final String INFO = "内容" ;

简写后:

String INFO = "内容" ;

2、抽象方法编写时, 可以省略 public abstract 关键字, 例如:

public abstract void print() ;

简写后:

void print() ;

接口的实现 implements

接口可以多实现:

格式:

class 子类 implements 父接口1,父接口2...{

}

以上的代码称为接口的实现。那么如果一个类即要实现接口,又要继承抽象类的话,则按照以下的格式编写即可:

class 子类 extends 父类 implements 父接口1,父接口2...{

}

接口的继承

接口因为都是抽象部分, 不存在具体的实现, 所以允许多继承,例如:

interface C extends A,B{

}

注意

如果一个接口要想使用,必须依靠子类。 子类(如果不是抽象类的话)要实现接口中的所有抽象方法。

接口和抽象类的区别

1、抽象类要被子类继承,接口要被子类实现。

2、接口只能声明抽象方法,抽象类中可以声明抽象方法,也可以写非抽象方法。

3、接口里定义的变量只能是公共的静态的常量,抽象类中的变量是普通变量。

4、抽象类使用继承来使用, 无法多继承。 接口使用实现来使用, 可以多实现

5、抽象类中可以包含static方法 ,但是接口中不允许(静态方法不能被子类重写,因此接口中不能声明静态方法

6、接口不能有构造方法,但是抽象类可以有

6.多态

概念

多态:就是对象的多种表现形式,(多种体现形态)

多态的体现

对象的多态性,从概念上非常好理解,在类中有子类和父类之分,子类就是父类的一种形态 ,对象多态性就从此而来。

ps: 方法的重载 和 重写 也是多态的一种, 不过是方法的多态(相同方法名的多种形态)。

重载: 一个类中方法的多态性体现

重写: 子父类中方法的多态性体现。

多态的使用:对象的类型转换

类似于基本数据类型的转换:

· 向上转型:将子类实例变为父类实例

|- 格式:父类 父类对象 = 子类实例 ;

· 向下转型:将父类实例变为子类实例

|- 格式:子类 子类对象 = (子类)父类实例 ;(强制转换,从大范围到小范围时)

注意:护士是不可以转为学生的,但他是人

Eg

 

4、instanceof

作用:

判断某个对象是否是指定类的实例,则可以使用instanceof关键字

格式:

实例化对象 instanceof 类 //此操作返回boolean类型的数据

5、Object类

概念

Object类是所有类的父类(基类),如果一个类没有明确的继承某一个具体的类,则将默认继承Object类。

例如我们定义一个类:

public class Person{

}

其实它被使用时 是这样的:

public class Person extends Object{

}

Object的多态

使用Object可以接收任意的引用数据类型 ( 万物 )

有很多定义好的方法在Object中,所以继承它

Eg

public static void main(String[] args) {

       String s = "5d9";

        say(s);

        int a = 100;

        say(a);

 

    }

    public static void say(Object o) {

       System.out.println(o);

    }

//Ctrl+鼠标左键查看类的源码

API文档,辅助查看源码

toString

建议重写Object中的toString方法。 此方法的作用:返回对象的字符串表示形式。

Object的toString方法, 返回对象的内存地址

Equals

建议重写Object中的equals(Object obj)方法,此方法的作用:指示某个其他对象是否“等于”此对象。

Object的equals方法:实现了对象上最具区别的可能等价关系; 也就是说,对于任何非空引用值x和y ,当且仅当x和y引用同一对象( x == y具有值true )时,此方法返回true 。

equals方法重写时的五个特性:

自反性 :对于任何非空的参考值x , x.equals(x)应该返回true 。

对称性 :对于任何非空引用值x和y , x.equals(y)应该返回true当且仅当y.equals(x)回报true 。

传递性 :对于任何非空引用值x , y和z ,如果x.equals(y)回报true个y.equals(z)回报true ,然后

x.equals(z)应该返回true 。

一致性 :对于任何非空引用值x和y ,多次调用x.equals(y)始终返回true或始终返回false ,前提是未修改对象

上的equals比较中使用的信息。

非空性 :对于任何非空的参考值x , x.equals(null)应该返回false 。

public boolean equals(Object o) { //传入任意值

       //先比较地址

       if(this == o) {

           return true; //return表示结束

       }

       //地址为空

       if(o == null) {

           return false;

       }

       //判断是否是同一类

       if(o instanceof Person10) {

           Person10 p = (Person10)o;

           //因为nameString 所以用equals比,ageint所以直接比

           if(this.name.equals(p.name)&&this.age == p.age) {

              //相同

              return true;

           }else {

              return false;

           }

       }else {

           return false;

       }

    }

6、内部类

概念

在Java中,可以将一个类定义在另一个类里面或者一个方法里面,这样的类称为内部类。

广泛意义上的内部类一般来说包括这四种:

1、成员内部类

2、局部内部类

3、匿名内部类

4、静态内部类

成员内部类

成员内部类是最普通的内部类,它的定义为位于另一个类的内部,形如下面的形式:

class Outer {

private double x = 0;

public Outer(double x) {

this.x = x;

}

class Inner { //内部类

public void say() {

System.out.println("x="+x);

}

}

}

特点: 成员内部类可以无条件访问外部类的所有成员属性和成员方法(包括private成员和静态成员)。//因为在内部类可以被时,表示对象已经创建了

不过要注意的是,当成员内部类拥有和外部类同名的成员变量或者方法时,会发生隐藏现象,即默认情况下访问

的是成员内部类的成员。如果要访问外部类的同名成员,需要以下面的形式进行访问:

外部类.this.成员变量

外部类.this.成员方法

外部使用成员内部类

Outter outter = new Outter();

Outter.Inner inner = outter.new Inner();

局部内部类

局部内部类是定义在一个方法或者一个作用域里面的类,它和成员内部类的区别在于局部内部类的访问仅限于方法内或

者该作用域内。

例如:

class Person{

public Person() {

}

}

class Man{

public Man(){

}

public People getPerson(){

class Student extends People{ //局部内部类

int age =0;

}

return new Student();

}

}

注意:局部内部类就像是方法里面的一个局部变量一样,是不能有public、protected、private以及static修饰符的。

匿名内部类

匿名内部类由于没有名字,所以它的创建方式有点儿奇怪。创建格式如下:

new 父类构造器(参数列表)|实现接口()

{

//匿名内部类的类体部分

}

在这里我们看到使用匿名内部类我们必须要继承一个父类或者实现一个接口,当然也仅能只继承一个父类或者实现一个接口。同时它也是没有class关键字,这是因为匿名内部类是直接使用new来生成一个对象的引用。当然这个引用是隐式的。

注意:

在使用匿名内部类的过程中,我们需要注意如下几点:

1、使用匿名内部类时,我们必须是继承一个类或者实现一个接口但是两者不可兼得,同时也只能继承一个类或者实现一个接口。

2、匿名内部类中是不能定义构造函数的。

3、匿名内部类中不能存在任何的静态成员变量和静态方法。

4、匿名内部类为局部内部类,所以局部内部类的所有限制同样对匿名内部类生效。

5、匿名内部类不能是抽象的,它必须要实现继承的类或者实现的接口的所有抽象方法。

6、只能访问final型的局部变量(1.8之前需要加入final,1.8之后自动默认了,不需要加了)

注意:局部内部类就像是方法里面的一个局部变量一样,是不能有public、protected、private以及static修饰符的。

静态内部类

静态内部类也是定义在另一个类里面的类,只不过在类的前面多了一个关键字static。

静态内部类是不需要依赖于外部类对象的,这点和类的静态成员属性有点类似,并且它不能使用外部类的非static成员变量或者方法.

格式:

public class Test {

public static void main(String[] args) {

Outter.Inner inner = new Outter.Inner();

}

}

class Outter {

public Outter() {

}

static class Inner {

public Inner() {

}

}

}

7、 包装类

概述

在Java中有一个设计的原则“一切皆对象”,那么这样一来Java中的一些基本的数据类型,就完全不符合于这种设计思

想,因为Java中的八种基本数据类型并不是引用数据类型,所以Java中为了解决这样的问题,引入了八种基本数据类型

的包装类。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值