一,封装

在面向对象程式设计方法中,封装(英语:Encapsulation)是指一种将抽象性函式接口的实现细节部分包装、隐藏起来的方法。

封装可以被认为是一个保护屏障,防止该类的代码和数据被外部类定义的代码随机访问。

要访问该类的代码和数据,必须通过严格的接口控制。

封装最主要的功能在于我们能修改自己的实现代码,而不用修改那些调用我们代码的程序片段。

适当的封装可以让程式码更容易理解与维护,也加强了程式码的安全性。

封装的优点

  • 1. 良好的封装能够减少耦合。
  • 2. 类内部的结构可以自由修改。
  • 3. 可以对成员变量进行更精确的控制。
  • 4. 隐藏信息,实现细节。

二,封装的体现

体现一:将类的属性私有化(private),同时提供公共的(public)方法来获取(get)和设置(set)此属性的值。

三,四种权限修饰符

同一个类中

同一个包中

子类中

任何地方

public

可以

可以

可以

可以

protected

可以

可以

可以

不可以

默认修饰符

可以

可以

不可以

不可以

private

可以

不可以

不可以

不可以

说明:4种权限修饰符都可以修饰类的内部结构:属性,方法,构造器,内部类,修饰类的话只能使用:缺省(默认修饰符),public 

 四,封装的步骤 

封装redis starter 封装英文_封装redis starter

五,构造器(构造方法)

1,构造器的作用

1)创建对象(new对象)

2)初始化对象的信息(赋值)

2,使用说明

1)如果没有定义构造器的话,系统会默认提供一个空参的构造器

2)定义构造器的格式:权限修饰符     类名     (形参列表)  {             }

3)一旦我们自己定义了构造器系统就不会提供默认的空参构造器了,需要我们自己定义一个空参的构造器

4)一个类中定义多个构造器彼此构成重载

5)一个类中,至少必须有一个构造器

六,关键字this的理解

1)   在类的方法中,我们可以使用"this.属性"或"this.方法"的方式,调用当前对象属性或方法。但
通常情况下,我们都择省略"this."。特殊情况下,如果方法的形参和类的属性同名时,我们必须显式的使用"this.变量"的方式,表明此变量是属性,而非形参
2)  在类的构造器中,我们可以使用"this.属性"或"this.方法"的方式,调用当前正在创建的对象属性或方法。但是,通常情况下,我们都择省略"this.".特殊情况下,如果构造器的形参和类的属性同名时,我们必须显式的使用"this.变量"的方式,表明此变量是属性,而非形参。
3) this调用构造器:
3.1我们在类的构造是中,可以显式的使用"this(形参列表)"方式,调用本类中指定的其他构造器

3.2构造器中不能通过this(形参列表)"方式调用自己

3.3如果一个类中有n个构造器,则最多有n-1个构造器中使用了"this(形参列表)”

3.4规定:"this(形参列表)"必须声明在当前构造器的首行

3.5构造器内部,最多只能声明一个"this(形参列表)",用来调用其他的构造器

七,代码展示


//快速生成构造器快捷键 :Alt + Insert //快速生成get set 方法快捷键 :Alt + Insert


权限修饰符修饰属性

构造器声明格式方法

get ,set 方法声明格式

package com.bdqn.lianxi;

public class Lian {
    //权限修饰符修饰过的属性
    private String name;

    private int age;
    //无参构造器
    public Lian(){

    }
    //带一个参数的构造器
    public Lian(String name){

    }
    //带两个参数的构造器
    public Lian(String name,int age){

    }
    //快速生成构造器快捷键 :Alt + Insert
    //快速生成get set 方法快捷键 :Alt + Insert
    public String getName() {
        return name;
    }

    public void setName(String name) {
         = name;
    }

    public int getAge() {
        return age;
    }

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