java 面向對象編程

什麼是面向對象

回顧方法的定義與調用

方法的定義

import java.io.IOException;

//Demo01 類
public class Demo01 {

    //main方法
    public static void main(String[] args) {

    }

    public String sayHello(){
        return "helloWorld";
    }
    
    public void readFile(String file) throws IOException{
        
    }

}

方法的調用

public class Demo02 {

    public static void main(String[] args) {

        //非靜態方法這樣
        new Student().say();

        //或者
        Student student=new Student();
        student.say();


    }

    //static 的方法是和類一塊兒加載的,存在較早
    public static void a(){

        // b(); //這裏會報錯,不能調用!!!!!!!

    }

    //類實例化以後才存在
    public void b(){

    }
}
//值傳遞
public class Demo03 {
    public static void main(String[] args) {

        int a=1;
        System.out.println(a);//1
        change(a);
        System.out.println(a);//1

    }

    //返回值爲空
    public static void change(int a){
        a=10;
    }

}
//引用傳遞: 傳遞的對象,本質仍是值傳遞
//對象要理解透徹、內存要理解透徹!!!!!!!!
public class Demo04 {

    public static void main(String[] args) {

        Person person = new Person();
        System.out.println(person.name);//null
        change(person);
        System.out.println(person.name);//wda

    }

    public static void change(Person person){
        //person 是一個對象:指向的--》Person person = new Person(); 這是一個具體的人能夠改變屬性
        person.name ="wda";
    }

}


//定義了一個Person類,有一個屬性
class Person{
    String name;//null
}

類與對象的建立

public class Student {

    //屬性;字段
    String name;//null
    int age;//0

    //方法
    public void study(){
        System.out.println(this.name+"在學習");
    }



}

/*
public static void main(String[] args) {

        //類:抽象的,須要實例化
        //類實例化後會返回一個本身的對象!
        Student xiaoming = new Student();
        Student xiaohong = new Student();

        xiaoming.age=3;
        xiaoming.name="ming";

        System.out.println(xiaoming.name);
        System.out.println(xiaoming.age);

    }
 */

構造器詳解

package com.oop.demo02;

//java-->會生成一個class文件
public class Person {

    //一個類即便什麼都不寫,也會存在一個方法
    //顯式的定義構造器
    String name;
    int age;

    //構造器的功能
    //實例化初始值
    //1.使用new關鍵字,本質是在調用構造器
    //2.用來初始化值
    public Person(){
        this.name="safa";

    }

    //有參構造器:一旦定義了有參構造,無參就必須顯式定義
    public Person(String name){
        this.name=name;
    }

    //alt+ insert 快捷定義構造器


}

/*
public static void main(String[] args) {

        //new 實例化了一個對象
        Person person = new Person("aaa");
        System.out.println(person.name); //aaa

    }
    構造器:
    1.和類名相同
    2.沒有返回值
    做用:
    1.使用new關鍵字,本質是在調用構造器
    2.用來初始化值
    注意點:
    1.一旦定義了有參構造,若是想使用無參構造,無參就必須顯式定義
    alt+ insert 快捷定義構造器
    this.=
 */

建立對象內存分析

package com.oop.demo03;

public class Pet {
    public String  name;
    public int age;

    //無參構造

    public void shout(){
        System.out.println("叫了一聲");;
    }
}

/*
public static void main(String[] args) {
        Pet dog = new Pet();
        dog.name="wangcai";
        dog.age=3;
        dog.shout();

        System.out.println(dog.name);
        System.out.println(dog.age);

        Pet cat = new Pet();

    }
 */

封裝詳解

package com.oop.demo04;

//private 私有
public class Student {

    //封裝大多數時候是對屬性來講的,方法裏面用的比較少
    /*
        1.提升程序的安全性
        2.隱藏代碼的實現細節
        3.統一接口
        4.系統可維護性增長了
    */

    // 名字
    //屬性私有
    private String name;

    //學號
    private int id;

    //性別
    private char sex;

    //年齡
    private int age;

    //提供一些能夠操做這個屬性的方法
    //提供一些pubLicde的get、set方法

    //get 得到這個數據

    public String getName(){
        return this.name;
    }

    //set 給這個數據設置值
    public void setName(String name){
        this.name=name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        if(age>120||age<0){
            this.age = 3;
        }else {
            this.age=age;
        }

    }

    //學習()
    //睡覺()


}

/*
public static void main(String[] args) {
        Student s1 =new Student();
        // s1.name  會報錯

        s1.setName("sfa");
        s1.getName();

        //alt + insert 能夠智能生成get set!!!!!!!!!!

        s1.setAge(999);//不合法的

        System.out.println(s1.getAge());

    }
 */

繼承

基礎

package com.oop;

import com.oop.demo05.Student;


public class Application {
    public static void main(String[] args) {
        Student student =new  Student();
        student.say();
        System.out.println(student.money);
        //System.out.println(student.money_private);
        //報錯,說明父類私有的屬性不能繼承
    }
}
package com.oop.demo05;

//在Java中,全部的類,都默認直接或間接繼承object類
//人 父類
public class Person /*extends Object*/{

    //public
    //protected
    //default
    //private
    public int money =10_0000_0000;

    private int money_private=10;

    public void say(){
        System.out.println("說了一句話");
    }

}
package com.oop.demo05;

//學生 is 人  派生類
//子類繼承了父類,就會擁有父類的所有方法!!!
public class Student extends Person{

    //ctrl+h  打開繼承樹!!!!!!

}
package com.oop.demo05;

//Teacher is Person  派生類
public class Teacher extends Person{
}

super詳解

package com.oop;

import com.oop.demo05.Student;


public class Application {
    public static void main(String[] args) {
        Student student =new  Student();
        //Person無參構造執行了
        //Student 無參執行了



        //student.test("aa");
        student.test1();
    }
}
package com.oop.demo05;

//在Java中,全部的類,都默認直接或間接繼承object類
//人 父類
public class Person /*extends Object*/{

    //public
    //protected
    //default
    //private
    public int money =10_0000_0000;

    private int money_private=10;

    protected String name="ks";

    //public-->private則出錯,私有的東西沒法繼承
    public void print(){
        System.out.println("person");
    }

    public void say(){
        System.out.println("說了一句話");
    }

    public Person() {
        System.out.println("Person無參構造執行了");
    }
}
package com.oop.demo05;

//學生 is 人  派生類
//子類繼承了父類,就會擁有父類的所有方法!!!
public class Student extends Person{

    //ctrl+h  打開繼承樹!!!!!!
    private String name="qj";
    public void test(String name){
        System.out.println(name);//aa
        System.out.println(this.name);//qj
        System.out.println(super.name);//ks
    }

    public void print(){
        System.out.println("Student");
    }

    public void test1(){
        print();//Student
        this.print();//Student
        super.print();//person
    }

    public Student() {
        //隱藏代碼,默認調用了父類的無參構造!!!!!!!!!!
        super();//調用父類的構造器,必需要在子類構造器第一行
        System.out.println("Student 無參執行了");
    }
}
super注意點:
    1.super調用父類的構造方法,必須在構造方法的第一行
    2.super必須只能出如今子類的方法或者構造方法中!
    3.super和this不能同時調用構造方法

vs this:
    表明的對象不一樣:
        this:自己調用者這個對象
        super:表明父類對象的應用
    前提:
       this:沒有繼承也可使用
       super:只能在繼承條件纔可使用
    構造方法
    this();本類的構造
    super();父類的構造

方法重寫

package com.oop.demo05;

//繼承
public class A extends B{
    @Override //註解:有功能的註釋
    public void test() {
        System.out.println("A->test()");
    }
}
package com.oop.demo05;

//重寫都是方法的重寫,和屬性無關
public class B {

    public void test(){
        System.out.println("B->test()");
    }
}
package com.oop;

import com.oop.demo05.A;
import com.oop.demo05.B;

public class Application {
    public static void main(String[] args) {

        //靜態的方法和非靜態的方法區別很大
        //靜態方法:方法的調用只和左邊,定義的數據類型有關
        //只有非靜態才叫作重寫 ,private也不能夠,只有public才能夠

        A a=new A();
        a.test();

        //父類的引用指向了子類
        B b=new A();//子類重寫了父類的方法
        b.test();

        //test()方法都有static時
        //A->test()
        //B->test()


        //靜態的方法和非靜態的方法區別很大
        //去掉static,即重寫以後
        //A->test()
        //A->test()


    }
}
重寫:須要有繼承關係,子類重寫父類的方法!
    1.方法名必須相同
    2.參數列表必須相同
    3.修飾符:範圍能夠擴大:public>protected>default>private
    4.拋出的異常:範圍,能夠被縮小,但不能擴大;classNotFoundException(xiao)-- Exception(da)是不能夠的
重寫,子類的方法和父類必需要一致,方法體不一樣

爲何須要重寫:
    1.父類的功能,子類不必定須要,或者不必定知足!
    快捷鍵: Alt+insert :override!!!!!!

多態

什麼是多態

package com.oop;

import com.oop.demo06.Person;
import com.oop.demo06.Student;

public class Application {
    public static void main(String[] args) {

        //一個對象的實際類型是肯定的
        //new Student();
        //new Person();

        //能夠指向的引用類型就不肯定了: 父類的引用指向子類

        //Student 能調用的方法都是本身的或者繼承父類的
        Student s1 = new Student();
        //Person 父類型。能夠指向子類,可是不能調用子類獨有的方法
        Person s2 = new Student();
        Object s3 =new Student();

        s2.run();//son 子類重寫了父類的方法,執行子類的方法
        s1.run();//son

        //對象能執行哪些方法,主要看對象左邊的類型,和右邊關係不大
        // s2.eat(); 報錯
        ((Student)s2).eat();
        s1.eat();//eat


    }
}
package com.oop.demo06;

public class Student extends Person{
    @Override
    public void run() {
        System.out.println("son");
    }

    public void eat(){
        System.out.println("eat");
    }
}

/*
多態注意事項:!!!!!!!!!!!!!
1.多態是方法的多態,屬性沒有多態
2.父類和子類,有聯繫  不然有類型轉換異常 ClassCastException
3.存在條件:繼承關係,方法須要重寫,父類引用指向子類對象 Father f1= new Son();

    1.static 方法,屬於類,它不屬於實例
    2.final 常量,不能夠改變
    3.private 方法,私有的不能重寫
 */
package com.oop.demo06;

public class Person {

    public void run(){
        System.out.println("run");
    }

}

instanceof 和類型轉換

package com.oop;

import com.oop.demo06.Person;
import com.oop.demo06.Student;
import com.oop.demo06.Teacher;

public class Application {
    public static void main(String[] args) {
        //類型之間的轉換:父   子

        //高                   低
        Person obj=new Student();

        //student 將這個對象轉換爲Student類型,就可使用Student類型的方法了!

        ((Student) obj).go();

        //子類轉換爲父類,可能丟失本身的原本的一些方法!
        Student student = new Student();
        student.go();
        Person person=student;
        //person.go();//報錯


    }
}

/*
1.父類引用指向子類的對象
2.把子類轉換爲父類,向上轉型:
3.把父類轉換爲子類,向下轉型:強制轉換
4.方便方法的調用,減小重複的代碼!簡潔!

抽象:封裝、繼承、多態! 抽象類,接口
 */
package com.oop.demo06;

public class Person {

    public void run(){
        System.out.println("run");
    }

}
package com.oop.demo06;

public class Student extends Person{

    public void go(){
        System.out.println("go");
    }

}

/*
//System.out.println(X instanceof  Y);//能不能編譯經過取決因而否有父子關係

        //Object>String
        //Object>Person>Teacher
        //Object>Person>Student
        Object object = new Student();
        System.out.println(object instanceof Student);//true
        System.out.println(object instanceof Person);//true
        System.out.println(object instanceof Object);//true
        System.out.println(object instanceof Teacher);//false
        System.out.println(object instanceof String);//false

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

        Person person =new Student();
        System.out.println(person instanceof Student);//true
        System.out.println(person instanceof Person);//true
        System.out.println(person instanceof Object);//true
        System.out.println(person instanceof Teacher);//false
        //System.out.println(person instanceof String);//編譯報錯

        System.out.println("=============================");
        Student student =new Student();
        System.out.println(student instanceof Student);//true
        System.out.println(student instanceof Person);//true
        System.out.println(student instanceof Object);//true
        //System.out.println(student instanceof Teacher);//編譯報錯
        //System.out.println(student instanceof String);//編譯報錯
 */
package com.oop.demo06;

public class Teacher extends Person{
}

static關鍵字

package com.oop.demo07;

public class Student {

    private static int age;//靜態變量 多線程中會仔細說到
    private double score;//非靜態變量

    public void run(){

    }

    public static void go(){

    }

    public static void main(String[] args) {
        Student s1 = new Student();

        System.out.println(Student.age);//建議經過這種類型來訪問靜態變量,靜態的變量對於類而言在內存中只有一個,能夠被類中全部實例共享
//        System.out.println(Student.score);//報錯
        System.out.println(s1.age);
        System.out.println(s1.score);

//        Student.run();//報錯
        new Student().run();

        Student.go();
        go();//類中的的方法能夠直接訪問類中的靜態方法

    }


}
package com.oop.demo07;

public final class Person {
    //被final修飾的類不能被繼承

    {
        //匿名代碼塊
        //程序執行時不能主動調用這個代碼塊
        //建立對象時自動建立,並且在構造器以前
        //能夠用來賦初值
        System.out.println("匿名代碼塊");
    }

    static{
        //靜態代碼塊
        //類一加載就直接執行
        //永久執行一次
        System.out.println("靜態代碼塊");
    }

    public Person() {
        System.out.println("構造方法");
    }

    public static void main(String[] args) {

        Person person1=new Person();
        System.out.println("==============");
        Person person2=new Person();

        /*
        靜態代碼塊
        匿名代碼塊
        構造方法
        ==============
        匿名代碼塊
        構造方法
         */

    }
}
package com.oop.demo07;
//靜態導入包
import static java.lang.Math.random;
import static java.lang.Math.PI;

public class Test {
    public static void main(String[] args) {
        System.out.println(random());
        System.out.println(PI);
    }
}

抽象類

package com.oop.demo08;

//抽象類  extends: 單繼承~ (接口能夠實現多繼承)例如插座~
public abstract class Action {

    //約束~有人幫咱們實現
    //抽象方法,只有方法名字,沒有方法的實現
    public abstract void doSomeThing();

    //1.不能new這個抽象類,只能靠子類去實現它;約束!
    //2.抽象類中能夠寫普通方法
    //3.抽象方法必須在抽象類中
    //抽象的抽象:約束

    //思考題 不能new,存在構造器嗎?  存在!!!!↓↓↓↓↓↓↓↓
    //存在的意義是什麼  抽象出來 提升開發效率


    public Action() {
    }
}
//抽象類的全部方法,繼承了它的子類,都必須實現這些方法~除非~它也是抽象類
public class A extends Action{

    @Override
    public void doSomeThing() {

    }
}

接口的定義與實現

package com.oop.demo09;


//抽象的思惟~Java 架構師~
//interface 定義的關鍵字,接口都須要有實現類
public interface UserService {
    //接口中的全部定義的方法其實都是抽象的 默認爲public abstract

    //屬性都是常量 默認 public static final
    int AGE=99;


    void add(String name);
    void delete(String name);
    void uodate(String name);
    void query(String name);

}
package com.oop.demo09;

public interface TimeService {
    void timer();
}
package com.oop.demo09;

//抽象類:extends
//類能夠實現接口
//實現了接口的類,就須要重寫接口中的方法

//多繼承,利用接口實現多繼承
public class UserServiceImpl implements UserService,TimeService{

    @Override
    public void add(String name) {

    }

    @Override
    public void delete(String name) {

    }

    @Override
    public void uodate(String name) {

    }

    @Override
    public void query(String name) {

    }

    @Override
    public void timer() {

    }
}
做用:
    1.約束
    2.定義一些方法,讓不一樣的人實現~  10----》1
    3.方法都是 public abstract
    4.屬性都是 public static final
    5.接口不能夠實例化~,接口中沒有構造方法
    6.implements能夠實現多個接口
    7.必須重寫接口中的方法~

內部類

package com.oop;

import com.oop.demo10.Outer;

public class Application {
    public static void main(String[] args) {

        Outer outer = new Outer();

        //經過這個外部類來實例化內部類
        Outer.Inner inner = outer.new Inner();
        inner.getID();//10


    }
}
package com.oop.demo10;

public class Outer {

    private int id=10;
    public void out(){
        System.out.println("這是外部類的方法");

        //局部內部類
        class Inner{
            public void in(){

            }
        }


    }

    public class Inner{
        public void in(){
            System.out.println("這是內部類的方法");
        }

        //得到外部類的私有屬性~
        public void getID(){

            System.out.println(id);

        }

    }

    //靜態內部類
    public static class Inner2{
        public void in(){
            System.out.println("這是內部類的方法");
        }

        //不能得到外部類的屬性
        public void getID(){

//            System.out.println(id);//報錯

        }

    }


}

//一個Java類中能夠由多個class類,可是隻能由public class
class A{

}
package com.oop.demo10;

public class Test {
    public static void main(String[] args) {

        Apple apple = new Apple();

        //沒有名字初始化類,不用將實例保存在變量中
        new Apple().eat();

        //沒有名字初始化接口
        new UserService(){
            @Override
            public void hello() {

            }
        };
    }
}

class Apple{
    public void eat(){
        System.out.println("1");
    }
}

interface UserService{

    void hello();

}
相關文章
相關標籤/搜索