编程语言
首页 > 编程语言> > 6 Java基础整理 第六-七章

6 Java基础整理 第六-七章

作者:互联网

1.封装

封装的目的是简化编程和增强安全性。

简化编程是指,封装可以让使用者不必了解具体类的内部实现细节,而只是要通过提供给外部访问的方法来访问类中的属性和方法

增强安全性是指,封装可以使某个属性只能被当前类使用,从而避免被其他类或对象进行误操作。

如何增强安全性:使用访问修饰符private修饰属性

2.构造函数 

构造方法不同于普通方法,普通方法代表对象的行为,而构造方法是提供给系统用于创建对象的方法。

构造方法(也称为构造函数)是一种特殊的方法,它具有以下特点。

构造函数的语法形式:[访问修饰符] 类名([参数列表]) ;

类中没有构造方法时JVM会默认产生一个无参构造方法。但是如果类中已经有任意的构造方法,JVM不会再创建。

当使用反射创建对象时,必须要使用无参构造方法。

3.this关键字:

this指向当前对象的引用

this经常用于:

private int age ;
...
public void setAge(int age) {
...
this.age = age ;
}

 

 public Student() {
        //调用有一个String参数的构造方法
        this(" WangYun" );
    }

    public Student(String name) {
        //调用有两个参数的构造方法
         this(name,23);
    }

    public Student(String name, int age) {
        ...
    }

 

4.练习

 

//以下代码
Student s1 = new Student("zs",18);
Student s2 = new Student("zs",18);
System.out.print(s1 == s2);
System.out.print(s1.getName() == s2.getName());
//执行后,控制台输出为? false true

因为setName()都是双引号字符串对象,是对常量池中同一个变量的引用。

5.Java包

  1. 提供了类似于操作系统树形文件夹的组织形式,能分门别类地存储、管理类,易于查找并使用类。
  2. 解决了同名类的命名冲突问题。例如,学生王云定义了一个类,类名叫 TestStudent,学生刘静涛也定义了一个叫 TestStudent 的类。如果在同一个文件夹下,就会产生命名冲突的问题。而使用了包的机制,就可以把王云定义的类存放在 wangyun 包下,把刘静涛定义的类存放在 liujingtao 包下,之后就可以先通过 wangyun 和 liujingtao 这样的包名,区分不同的目录,然后再使用 TestStudent 访问两个包中各自的类,从而解决了命名冲突的问题。
  3. 包允许在更广的范围内保护类、属性和方法。关于这方面的作用,在本章后面介绍访问权限的时候,大家就能体会到。

包的声明语法格式:package pkg1[.pkg2[.pkg3…]];

命名规则:通常包名全部用小写字母,现在使用最多的规则是使用翻转的 internet 域名(不含 www、ftp 等访问协议)。

 java常用包:

引用包的两种方法:import 包名.类名;和import 包名.* ; 第二种形式的包只能引用当前包下的类,不能导入其子包中的类;同时只会导入用到的类。

import语句要写在package之后,在类定义之前。

java.lang中的类不需要import

6.Java的权限修饰符:

Java 语言中的访问权限修饰符有 4 种,但却只有 3 个关键字。因为不写访问权限修饰符时,在 Java 中被称为默认权限(包权限),本课程中以 default 代替。其他 3 个访问权限修饰符分别为 privateprotected 和 public

修饰类:public和default。public代表类能在各种地方使用,default代表类只能在本包内使用。

修饰属性、构造方法、普通方法:private default protected public。private修饰的成员只能在本类中使用。default修饰的成员只能在本类和本包内使用。protected修饰的成员只能在本类、本包内和子类中使用。public可以在所有类中使用。

可以看到,只有成员变量/方法和类/接口才可以使用访问权限修饰符,局部变量不可以使用。

7.成员变量:对象成员变量和类成员变量,对象成员变量可以在每一个对象中创建,不同对象的对象成员变量不能共享;类成员变量只创建一次,可以被所有对象共享。通过在变量前面加上static使成员变量成为静态的(类成员变量)。

可以直接通过类名引用静态变量,也可以通过实例名来引用静态变量,但推荐采用前者,因为采用后者容易混淆静态变量和实例变量。

 被static修饰的方法称为静态方法/类方法,可以通过类名.方法名直接调用。

静态方法中无法使用实例变量。

Java 类首次装入 JVM 时,会对静态成员或静态块进行一次初始化,注意此时还没有产生对象。

因此,静态成员和静态块都是和类绑定的,会在类加载时就进行初始化操作

在使用 new 关键字创建并初始化对象的过程中,具体的初始化分为以下 4 步。

  1. 给对象的实例变量分配空间,默认初始化成员变量
  2. 成员变量声明时的初始化
  3. 初始化块初始化
  4. 构造方法初始化

8.单例模式:

单例模式指的是无论创建了多少个引用,在堆中仅仅只有一个实例对象。

单例模式通过private修饰构造方法实现。也称为构造方法私有化。

public class Singleton {
private static Singleton instance;
    private Singleton() {
    }
}

同时创建一个堆内存对象供使用。这个方法在没有对象时创建,存在对象时直接返回这个对象的引用。

   public static Singleton getInstance() {
        if (instance == null) {
             instance = new Singleton();
        }
        return instance;
    }

9.继承

继承可以使得子类沿用父类的成员(属性和方法)。当多个子类具有相同的成员时,就可以考虑将这些成员提取出来,放到父类中,然后再用子类去继承这个父类,也就是将一些相同的成员提取到了更高的层次中。

继承可以大大减少冗余代码,提高代码的复用性。

继承的关键字是extends。继承的语法形式是class A extends B{}。类A称为父类、超类、基类,类B称为子类、衍生类和导出类。

    子类不能继承private修饰或者不在同包内的default修饰的父类变量。

10.final关键字

final 关键字用法如下:

若用于修饰属性,则该属性不允许被修改。
若用于修饰父类中的方法,则该方法不允许被子类重写。
若用于修饰类,则该类不允许被其他类继承。

final修饰的方法可以被重载,但不能被重写。

11.重写

12.super关键字

super关键字用于引用父类的对象。

super()用于调用父类的构造方法来创建子类对象,和this()一样,必须写在构造方法中的第一行。

需要注意的是,子类的构造方法中如果不写 super(),编译器会帮助你在子类构造方法的第一行加上super()因为在子类中调用父类构造器是“必须的”。但如果父类中只存在有参构造方法,并没有提供无参构造方法,则需要在子类构造方法中显式地调用父类存在的构造器,否则可能因为父类中没有无参构造器而得到一个编译错误。

使用super调用重写方法在父类的方法:super.重写方法()。其作用是对父类方法进行一些补充。

13.多态

多态可以优雅的解决程序中的扩展性问题。

在形式上,父类引用可以指向子类对象。在 Vehicle vehicle = new Car(); 中,子类的 Car 对象赋值给了父类 Vehicle 引用,这称为向上转型

在引用 vehicle 上调用方法,在运行时刻究竟调用的是父类 Vehicle 中的方法还是子类 Car 中的方法呢?实际需要通过运行时的对象类型来判断,这称为动态绑定

向上转型和动态绑定就是多态的具体实现机制。

向上转型的好处,是不需要针对父类的多个子类再设计不同的方法,减少了代码量并且增加了可拓展性。

动态绑定是指在编译期间方法并不会和“引用”的类型绑定在一起,而是在程序运行的过程中,JVM 需要根据具体的实例对象才能确定此时要调用的是哪个方法。重写方法遵循的就是动态绑定。

例如,子类和父类中都有info()方法。动态绑定就是指,编译过程中info()不会和具体的类绑定到一起,而是在运行期间列举出子类和父类的info()方法,根据当前的实例对象,调用该实例对象的info()方法。

静态绑定是指程序编译期的绑定。以下的类信息,使用的就是静态绑定机制:

一种推荐的编程思想是“面向基类”编程。也就是建议将面向的“对象”抽象为更高层次的基类。

向上转型的缺点:转型后的对象无法调用导出类中的方法。

向下转型:强制从基类转向衍生类。

确保向下转型的正确性:使用instance of运算符。

14.练习

 

 

无论子类构造函数中有没有super();实际运行时都会调用父类的构造器。

 当子类重写了父类的方法时,调用主体(即对象)和方法是运行时绑定的;
当子类和父类的属性重名时,调用主体(即对象)和属性是编译时绑定的。

这两种说法,前一种是方法的动态绑定,后一种是成员变量的静态绑定。

 

 java在编译时确定对象类型,同时对这个对象的成员变量进行静态编译。也就是说,sup对象的i属性是在Super类中加载的。

 

 

 此时sub对象的i属性是在sub类中加载的。

 

标签:第六,Java,变量,构造方法,对象,子类,七章,父类,方法
来源: https://www.cnblogs.com/Justhis610/p/15034176.html