Java入門4

来源:https://www.cnblogs.com/te9uila/archive/2023/03/29/17270196.html
-Advertisement-
Play Games

面向對象2 訪問修飾符 | | private | default | protected | public | | | | | | | | 當前類 | :heavy_check_mark: | :heavy_check_mark: | :heavy_check_mark: | :heavy_che ...


面向對象2

訪問修飾符

private default protected public
當前類 ✔️ ✔️ ✔️ ✔️
同一個包 ✖️ ✔️ ✔️ ✔️
不同包 ✖️ ✖️ ✔️ ✔️
無關類 ✖️ ✖️ ✖️ ✔️

參數傳遞

基本類型和String類型的參數傳遞(值傳遞)

​ 在進行基本類型的參數傳遞是,傳的是參數的值,並不是參數本身!當main方法調用其他方法時,改變的只是被調用的方法的參數,與main方法內的參數無關。當方法執行結束後,所有的參數對象都會被gc自動銷毀回收。

引用類型的參數傳遞(記憶體地址傳遞)

​ 引用數據類型非常多,大致包括:
​ 類、 介面類型、 數組類型、 枚舉類型、 註解類型

​ 在進行引用類型的參數傳遞是,傳的是引用類型的參數地址!當main方法調用其他方法時,進行操作的是賣弄傳進來的地址,當方法執行結束後,並不影響更改後的參數對象。

public class Test01 {
    public static void test(int a, int[] arr){
        a = 3;
        int[] arr1 ={5,4,3,2,1};
        arr[0] = 10;
        arr = arr1;
    }

    public static void main(String[] args) {
        int[] arr={1,2,3,4,5};
        int a = 0;
        test(a,arr);
        System.out.println(arr[0]);
    }
}
// 輸出的結果:
// a = 0;
// arr = {10,2,3,4,5};

final常量

特點

  1. 被final修飾的類不可以被繼承
  2. 被final修飾的方法被不可以被重寫
  3. 被final修飾的變數不可以更改值
  4. 被final修飾的引用不可以存儲其他對象的記憶體地址

封裝

封裝的目的

提供一個統一的用來設置對象屬性和訪問對象屬性的入口

封裝的要求

  1. 所有成員的變數全部私有
  2. 需要提供公有的set和get方法來提供對象成員變數的訪問
  3. 需要提供一個無參構造方法(必須是public所修飾的)用來給外界創建對象

Java Bean

​ 想象一下存在這樣一個箱子,其內部被分割成幾個格子,每個格子用來存放特定的物品,工人取出或者放入物品後封箱,然後叫了個快遞把箱子發出去了。這個箱子就是 Java Bean 啊,取出、放入就是getter、setter,物品就是屬性,封箱發出就是序列化和傳輸。

// 舉個慄子
public class Product {
    private int id;
    private String name;
    private double price;
    private double stock;
    public Product(){}

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

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

    public double getPrice() {
        return price;
    }

    public void setPrice(double price) {
        this.price = price;
    }

    public double getStock() {
        return stock;
    }

    public void setStock(double stock) {
        this.stock = stock;
    }
}

繼承(Java中只支持單繼承)

​ Java種的繼承解決的是代碼復用的問題(父類:共性抽取。子類:功能表現-功能拓展)

​ 每一個類都只能有一個父類,但是可以有許多子類

繼承帶來的好處

  1. 提高了代碼的復用性,提高了軟體開發的效率
  2. 繼承的出現讓類和類之間產生了關係,提供了多態的前提
// 舉個一個慄子
// 新建一個父類Person
public class Person {
    public String name;
    public int age;
    public void eat(){
        System.out.println("Person => eat()");
    }
}
// 新建一個子類Student繼承Person
public class Student extends Person{
    public int sno;
    public void study(){
        System.out.println("Student => study()");
    }
}
// 新建一個子類Teacher繼承Person
public class Teacher extends Person{
    public int tno;
    public void teach(){
        System.out.println("Teacher => teach()");
    }
}
// 主運行類,Student實例化的對象,擁有Person類里的參數和方法
public static void main(String[] args) {
    Student student1 = new Student();
    student1.name = "student01";
    student1.sno = 10001;
    student1.eat();
    student1.study();
}

繼承里的構造方法

當new了子類新對象的時候(即對子類對象進行初始化的時候),父類的構造方法也會執行,且其優先順序在子類的構造方法之前,因此父類必須擁有無參構造!

(⭐)對於子類的構造方法而言,不管是子類的是有參構造方法,還是無參構造方法,都是預設調用父類的無參構造方法,所以不管父類的構造方法是否有做對象的初始化,都必須將父類的無參構造方法給顯式的定義出來

super 的三種用法

  1. 在子類的構造方法種的第一行,用來訪問父類的指定構造函數,如果不寫,則預設訪問父類的無參構造
  2. 在子類中有和父類名字相同的成員變數時,用於訪問父類的指定成員變數(阿裡編程規範里不允許使用)
  3. 在子類有和父類完全相同的方法的時候(方法名相同&參數的數量,順序,類型相同),訪問父類的方法

this 的三種用法

  1. 在當前子類的構造方法時,會調用自己的其他構造方法
  2. 訪問自己的成員變數
  3. 訪問當前類的其他方法
// 舉個一個慄子
// 新建一個父類Person
public class Person {
    public String name;
    public int age;
    // 重寫無參構造
    public Person(){
        System.out.println("Person => Person()");
    }
    // 重寫有參構造
    public Person(String name, int age) {
        System.out.println("Person => Person(name,age)");
        this.name = name;
        this.age = age;
    }
    public void eat(){
        System.out.println("Person => eat()");
    }
}
// 新建一個子類Student繼承Person
public class Student extends Person{
    public int sno;
    // 重寫無參構造
    public Student(){
        super(); // 調用父類的無參構造,如果不寫預設生成
        System.out.println("Student => Student()");
    }
    // 重寫有參構造
    public Student(String name, int age, int sno) {
        super(name, age);// 調用父類的有參構造,如果不寫預設調用無參構造,會爆紅!!!!!!!
        this.sno = sno;
    }
    public void study(){
        System.out.println("Student => study()");
    }
}
// 主運行類,Student實例化的對象時,先調用父類Person的無參構造,再調用自己的構造方法
public static void main(String[] args) {
    // 通過子類的無參構造,實例化對象(父類無參構造 => 子類無參構造)
    Student student1 = new Student();
    // 通過子類的有參構造,實例化對象(父類有參構造 => 子類有參構造)
    Student student2 = new Student("Robot01",18,10001);
}

@Override註解

  1. 聲明當前方法重寫了父類方法

  2. 如果被標記的方法沒有重寫父類方法,編譯則無法通過

// 新建一個父類Person
public class Person {
    public String name;
    public int age;
    public void eat(){
        System.out.println("Person => eat()");
    }
}
// 新建一個子類Student繼承Person
public class Student extends Person{
    public int sno;
    public void study(){
        System.out.println("Student => study()");
    }
    @Override
    public void eat(){
        System.out.println("Student => eat()");
    }
}

抽象類(abstract)

抽象類的概念

​ 抽象類是用來捕捉子類的通用性的,它不能被實例化,只能用作子類的超類,抽象類是被用來創建子類的模板,如果父類中的方法無法滿足所有子類的需求,這個方法就應該是一個抽象方法

抽象類的特點

  1. 抽象類本身不可以使用new 創建對象
  2. 必須通過子類來創建對象
  3. 子類必須覆寫父類當中所有的抽象方法
  4. 抽象類中可以定義非抽象方法,用於給子類繼承使用,自己無法調用
  5. 抽象類中可以定義成員變數,用於給子類繼承使用,自己同樣無法調用
  6. 抽象類中可以定義構造方法,用於給子類繼承使用,自己同樣無法使用
  7. 抽象類中可以不定義抽象方法
  8. 如果一個類繼承了抽象類,卻沒有覆寫父類的所有抽象方法,那麼這個類,一定也是一個抽象類

抽象類實現

// 新建抽象類Pic,定義抽象方法area()
public abstract class Pic {
    public abstract void area();
}
// 新建類TriAngle,覆寫抽象方法area()
public class TriAngle extends Pic {
    @Override
    public void area() {
        System.out.println("TriAngle => area()");
    }
}
// 新建主運行類,測試代碼
public static void main(String[] args) {
    TriAngle triAngle = new TriAngle();
    triAngle.area();
}

介面(interface)(變向實現多繼承)

介面的概念

​ 介面相比抽象類,抽象的更加徹底,介面只能描述子類所應當具備的方法,但是沒有具體的實現,將功能的定義和實現進行分離,給程式解耦

​ 在 JDK1.7 之後介面中可以定義常量,在 JDK1.8 之後介面中可以定義帶有方法體的預設方法(default)和靜態方法(static),所有版本中都不可以定義普通方法,也不可以定義構造函數,成員變數

介面的特點

  1. 允許多實現(相當於多繼承)
  2. 不允許定義成員變數和非抽象方法
  3. 可以定義抽象方法和靜態常量
  4. 介面相當於是功能的集合
// 定義介面
public interface Brake {
    void brakeRole();
}
public interface EnvironmentProtect {
    void emission();
}
public interface Safe {
    void safeRule();
}
// 定義類Car繼承介面
public class Car implements Brake,EnvironmentProtect,Safe{
    @Override
    public void brakeRole() {
        System.out.println("Brake => breakRole()");
    }

    @Override
    public void emission() {
        System.out.println("EnvironmentProtect => emission()");
    }

    @Override
    public void safeRule() {
        System.out.println("Safe => safeRule()");
    }
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 點右上角加星標,江湖要事早知道 前幾天在脈脈上看到一個熱議話題“23年找工作的心酸歷程” 大家都知道近幾年互聯網大環境不好,找工作變得越來越捲了、 就算是BAT這種大廠出來的,也不見得就有多好找工作,可想而知,如果你的背景和能力不是特別強,很有可能練簡歷關都過不了。 特別是工作時間久的老程式員,總包 ...
  • 對象樹管理 個人經驗總結,如有錯誤或遺漏,歡迎各位大佬指正 :) @ 設置父對象的作用 眾所周知,Qt中,有為對象設置父對象的方法——setParent。 而設置父對象的作用主要有,在父對象析構的時候,會自動去析構其子對象。如果是一個視窗對象,如果其父對象設置了樣式表(Style Sheet),子對 ...
  • 終於在2023/3/29日,黑馬程式員旗下的ssm框架視頻看完了,也是總結了1萬多字的筆記,把黑馬的和自己的整合了一下 完結撒花,接下來開始學習SpringBoot和軟考中級設計師。 總的來說,我還是比較喜歡.NET,SSM配置實在是太麻煩了,基本沒怎麼寫代碼,時間都花到配置文件上面去了。 筆記部分 ...
  • JSON Web Token(縮寫 JWT)是目前最流行的跨域認證解決方案。 傳統的session認證 http協議本身是一種無狀態的協議,而這就意味著如果用戶向我們的應用提供了用戶名和密碼來進行用戶認證,那麼下一次請求時,用戶還要再一次進行用戶認證才行,因為根據http協議,我們並不能知道是哪個用 ...
  • 功能實現02 6.功能05-顯示家居信息 6.1需求分析 進入後臺系統,可以在頁面進行所有家居信息的展示 6.2思路分析 完成從後端代碼從mapper(dao層)-->Service層-->Controller層,並對代碼進行測試 完成前端代碼,使用axios發送http請求,返回所有家居信息,將數 ...
  • 使用 VLD 記憶體泄漏檢測工具輔助開發時整理的學習筆記。本篇介紹 VLD 配置文件中配置項 StartDisabled 的使用方法。 ...
  • QAbstractBUtton: 所有按鈕控制項的基類 提供按鈕的通用功能 繼承自QWidget 屬於抽象類別,不能直接去使用,必須藉助於子類(除非你覺得子類不夠用,想自定義一個按鈕) 大部分功能之前已經使用過,在這裡只作簡單介紹 文本設置: setText(str) :設置按鈕提示文本 text() ...
  • 推薦一些學習qml教程 Qt官方的QML教程: https://doc.qt.io/qt-5/qtqml-index.html 這是一個由Qt官方提供的完整的QML教程,包含了所有基本知識和高級語法。 QML中文網:http://www.qmlcn.com/ 這是一個非常不錯的中文QML學習網站,提 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 推薦一款基於.NET 8、WPF、Prism.DryIoc、MVVM設計模式、Blazor以及MySQL資料庫構建的企業級工作流系統的WPF客戶端框架-AIStudio.Wpf.AClient 6.0。 項目介紹 框架採用了 Prism 框架來實現 MVVM 模式,不僅簡化了 MVVM 的典型 ...
  • 先看一下效果吧: 我們直接通過改造一下原版的TreeView來實現上面這個效果 我們先創建一個普通的TreeView 代碼很簡單: <TreeView> <TreeViewItem Header="人事部"/> <TreeViewItem Header="技術部"> <TreeViewItem He ...
  • 1. 生成式 AI 簡介 https://imp.i384100.net/LXYmq3 2. Python 語言 https://imp.i384100.net/5gmXXo 3. 統計和 R https://youtu.be/ANMuuq502rE?si=hw9GT6JVzMhRvBbF 4. 數 ...
  • 本文為大家介紹下.NET解壓/壓縮zip文件。雖然解壓縮不是啥核心技術,但壓縮性能以及進度處理還是需要關註下,針對使用較多的zip開源組件驗證,給大家提供個技術選型參考 之前在《.NET WebSocket高併發通信阻塞問題 - 唐宋元明清2188 - 博客園 (cnblogs.com)》講過,團隊 ...
  • 之前寫過兩篇關於Roslyn源生成器生成源代碼的用例,今天使用Roslyn的代碼修複器CodeFixProvider實現一個cs文件頭部註釋的功能, 代碼修複器會同時涉及到CodeFixProvider和DiagnosticAnalyzer, 實現FileHeaderAnalyzer 首先我們知道修 ...
  • 在軟體行業,經常會聽到一句話“文不如表,表不如圖”說明瞭圖形在軟體應用中的重要性。同樣在WPF開發中,為了程式美觀或者業務需要,經常會用到各種個樣的圖形。今天以一些簡單的小例子,簡述WPF開發中幾何圖形(Geometry)相關內容,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 在 C# 中使用 RabbitMQ 通過簡訊發送重置後的密碼到用戶的手機號上,你可以按照以下步驟進行 1.安裝 RabbitMQ 客戶端庫 首先,確保你已經安裝了 RabbitMQ 客戶端庫。你可以通過 NuGet 包管理器來安裝: dotnet add package RabbitMQ.Clien ...
  • 1.下載 Protocol Buffers 編譯器(protoc) 前往 Protocol Buffers GitHub Releases 頁面。在 "Assets" 下找到適合您系統的壓縮文件,通常為 protoc-{version}-win32.zip 或 protoc-{version}-wi ...
  • 簡介 在現代微服務架構中,服務發現(Service Discovery)是一項關鍵功能。它允許微服務動態地找到彼此,而無需依賴硬編碼的地址。以前如果你搜 .NET Service Discovery,大概率會搜到一大堆 Eureka,Consul 等的文章。現在微軟為我們帶來了一個官方的包:Micr ...
  • ZY樹洞 前言 ZY樹洞是一個基於.NET Core開發的簡單的評論系統,主要用於大家分享自己心中的感悟、經驗、心得、想法等。 好了,不賣關子了,這個項目其實是上班無聊的時候寫的,為什麼要寫這個項目呢?因為我單純的想吐槽一下工作中的不滿而已。 項目介紹 項目很簡單,主要功能就是提供一個簡單的評論系統 ...