主頁 > 後端開發 > 初識C++02:類和物件

初識C++02:類和物件

2022-05-11 06:28:25 後端開發

類和物件

創建方法

第一種式直接宣告:

class Student {
private:
    string name;
public:
    Student(string name) {
        this->name = name;
    }
}
//宣告:
Student lu;//不帶初始化
//帶初始化;
Student lu(huang);
Student lu = Student(huang);
//訪問方式
lu.name;

這樣的宣告方式,是將物件在堆疊上創建堆疊記憶體自動管理,在執行函式時,函式內區域變數的存盤單元都可以在堆疊上創建,函式執行結束后在將這些區域變數的記憶體空間回收,在堆疊上分配記憶體空間效率很高,但是分配的記憶體容量有限,

第二種使用物件指標宣告

Student *plu = new Student;//不帶初始化;
Student *plu = new Student(huang);//帶初始化;
//訪問方式
plu->name;

這樣宣告,是將物件在堆中創建,堆記憶體代碼人員管理,new和delete配對使用,使用 new 在堆上創建出來的物件是匿名的,沒法直接使用,必須要用一個指標指向它,再借助指標來訪問它的成員變數或成員函式,

函式宣告

成員函式必須先在類體中作原型宣告,然后在類外定義,也就是說類體的位置應在函式定義之前,因為類體內定義的函式默認是行內函式,一般用行內函式的時候才會在類內部實作;例子:

class Student {
private:
    string name;
    int age;
public:
    //函式宣告
    Student(string name, int age);
}
//函式定義
Student::Student(string name, int age) {
    this->name = name;
    this->age = age;
}

類成員的訪問權限以及封裝

在類的內部(定義類的代碼內部),無論成員被宣告為 public、protected 還是 private,都是可以互相訪問的,沒有訪問權限的限制,

在類的外部(定義類的代碼之外),只能通過物件訪問成員,并且通過物件只能訪問 public 屬性的成員,不能訪問 private、protected 屬性的成員,

成員變數大都以m_開頭,這是約定成俗的寫法,易區分,

建議在開發中不需要暴暴露出來的屬性和方法都寫成private;

給成員變數賦值的函式通常稱為 set XXX函式,讀取成員變數的值的函式通常稱為 get XXX函式,XXX表示變數名;類中的不寫private這些關鍵詞默認是private

class Student {
private:
    string m_name;
public:
    void setname(string name);
    void getname;
}
void Student::setname(string name) {
    m_name = name;//這里可以直接用m_name;
}
.....

物件記憶體模型和函式編譯原理及實作

image-20220305221802319

編譯器會將成員變數和成員函式分開存盤:分別為每個物件的成員變數分配記憶體,但是所有物件都共享同一段函式代碼,節省空間,sizeof一個物件大小就是全部成員變數的總和大小

C++和C語言的編譯方式不同,C語言中的函式在編譯時名字不變,或者只是簡單的加一個下劃線_(不同的編譯器有不同的實作),c++是通過一種特殊的演算法來實作的,對函式重命名(這個程序叫字編碼(Name Mangling));下圖是一個編譯器重命名的方式,?方法@類名.....

image-20220305223020866

從上圖可以看出,成員函式最終被編譯成與物件無關的全域函式,如果函式體中沒有成員變數,不用對函式做任何處理,直接呼叫即可,

如果由成員變數(它的作用域不是全域的),C++規定,編譯成員函式時要額外添加一個引數,把當前物件的指標傳遞進去,通過指標來訪問成員變數(實際上傳遞的就是this指標

void Demo::display(){
    cout<<a<<endl;
}

會編譯為類似:

void new_function_name(Demo * const p){//const表示指標不能被修改;
    //通過指標p來訪問a、b
    cout<<p->a<<endl;
}

這樣通過傳遞物件指標就完成了成員函式和成員變數的關聯,這與我們從表明上看到的剛好相反,通過物件呼叫成員函式時,不是通過物件找函式,而是通過函式找物件,

建構式

建構式的呼叫是強制性的,一旦在類中定義了建構式,那么創建物件時就一定要呼叫,不呼叫是錯誤的,如果有多個多載的建構式,那么創建物件時提供的實參必須和其中的一個建構式匹配;反過來說,創建物件時只有一個建構式會被呼叫;

一個類必須有建構式,要么用戶自己定義,要么編譯器自動生成,一旦用戶自己定義了建構式,不管有幾個,也不管形參如何,編譯器都不再自動生成

建構式定義由兩種寫法:正常函式寫法和使用建構式初始化串列

//第一種
Student::Student(char *name, int age){
    m_name = name;
    m_age = age;
}
//第二種
Student::Student(char *name, int age): m_name(name), m_age(age){}

注意??第二種:成員變數的初始化順序與初始化串列中列出的變數的順序無關,它只與成員變數在類中宣告的順序有關;如:

class Demo{
private:
    int m_a;
    int m_b;
public:
    Demo(int b);
    void show();
};

Demo::Demo(int b): m_b(b), m_a(m_b){
    m_a = m_b;
    m_b = b;
}
//錯誤,給 m_a 賦值時,m_b 還未被初始化,它的值是不確定的,所以輸出的 m_a 的值是一個奇怪的數字;給 m_a 賦值完成后才給 m_b 賦值,此時 m_b 的值才是 值b,
//obj 在堆疊上分配記憶體,成員變數的初始值是不確定的,

使用建構式初始化串列并沒有效率上的優勢,但是書寫方便,而且,初始化 const 成員變數的唯一方法就是使用初始化串列,原因:為什么要用初始化串列

解構式

解構式(Destructor)也是一種特殊的成員函式,沒有回傳值,不需要程式員顯式呼叫(程式員也沒法顯式呼叫),而是在銷毀物件時自動執行,

class VLA{
public:
    VLA(int len);  //建構式
    ~VLA();  //解構式
private:
    const int m_len;  //陣列長度
    int *m_arr; //陣列指標
    int *m_p;  //指向陣列第i個元素的指標
};
VLA::VLA(int len): m_len(len){  //使用初始化串列來給 m_len 賦值
    if(len > 0){ m_arr = new int[len];  /*分配記憶體*/ }
    else{ m_arr = NULL; }
}
VLA::~VLA(){
    delete[] m_arr;  //釋放記憶體
}

通過直接用類宣告的物件在堆疊中,出了作用域(比如說函式return了),就會呼叫解構式;在全域建的物件在.data區,程式結束后才釋放; 注意?????♂?:兩中方法呼叫解構式的順序都是先生成的后析構,后生成的先析構;

new 創建的物件位于堆區,通過 delete 洗掉時才會呼叫解構式,例如在main函式中new物件然后delete物件;如果宣告了變數在堆中,不通過解構式釋放記憶體,即使外面delete了,也只是洗掉了指標,里面的空間還是被占用著,沒有被釋放掉,如上面的int[len];

此處補充指標知識:

int a = 10;
int* p = &a;//p是指標,這個*表示是int的指標型別;
此時 *p = 10//這里的*說明是這個指標指向的物件,與上面*大大不同;而p只是以一個地址

成員物件和封閉類

一個類的成員變數如果是另一個類的物件,就稱之為“成員物件”,包含成員物件的類叫封閉類,

創建封閉類的物件時,它包含的成員物件也需要被創建,這就會引發成員物件建構式的呼叫,對于沒有默認建構式的成員物件,必須要使用封閉類建構式的初始化串列!!!

類名::建構式名(引數表): 成員變數1(引數表), 成員變數2(引數表), ...
{
//TODO:
}

一定要用初始化串列的四種情況

初始化時:封閉類物件生成時,先執行所有成員物件的建構式,然后才執行封閉類自己的建構式;

消亡時:先執行封閉類的解構式,然后再執行成員物件的解構式,剛剛好和創建相反,

this指標、static關鍵字

C++ 中的一個關鍵字,也是一個 const 指標, 所以要用->來訪問成員變數或成員函式,它指向當前物件,通過它可以訪問當前物件的所有成員,

this的本質:this 實際上是成員函式的一個形參,在呼叫成員函式時將物件的地址作為實參傳遞給 this,不過 this 這個形參是隱式的,它并不出現在代碼中,而是在編譯階段由編譯器默默地將它添加到引數串列中,

上述中函式編譯原理:成員函式最終被編譯成與物件無關的普通函式,除了成員變數,會丟失所有資訊,所以編譯時要在成員函式中添加一個額外的引數,把當前物件的首地址傳入,以此來關聯成員函式和成員變數,這個額外的引數,實際上就是 this,它是成員函式和成員變數關聯的橋梁,

static修飾成員變數:

  • 一個類中可以有一個或多個靜態成員變數,所有的物件都共享這些靜態成員變數,都可以參考它,

  • static 成員變數和普通 static 變數一樣,都在記憶體磁區中的全域資料區分配記憶體,到程式結束時才釋放,這就意味著,static 成員變數不隨物件的創建而分配記憶體,也不隨物件的銷毀而釋放記憶體,而普通成員變數在物件創建時分配記憶體,在物件銷毀時釋放記憶體,

  • 靜態成員變數必須初始化,而且只能在類體外進行,例如:int Student::m_total = 10;初始化時可以賦初值,也可以不賦值,如果不賦值,那么會被默認初始化為 0,全域資料區的變數都有默認的初始值 0,而動態資料區(堆區、堆疊區)變數的默認值是不確定的,一般認為是垃圾值,

  • 靜態成員變數既可以通過物件名訪問,也可以通過類名訪問,但要遵循 private、protected 和 public 關鍵字的訪問權限限制,當通過物件名訪問時,對于不同的物件,訪問的是同一份記憶體,

static修飾成員函式:

靜態成員函式與普通成員函式的根本區別在于:普通成員函式有 this 指標,可以訪問類中的任意成員;而靜態成員函式沒有 this 指標,只能訪問靜態成員(包括靜態成員變數和靜態成員函式)

原因:編譯器在編譯一個普通成員函式時,會隱式地增加一個形參 this,并把當前物件的地址賦值給 this,所以普通成員函式只能在創建物件后通過物件來呼叫,因為它需要當前物件的地址,而靜態成員函式可以通過類來直接呼叫編譯器不會為它增加形參 this,它不需要當前物件的地址,所以不管有沒有創建物件,都可以呼叫靜態成員函式,所以靜態成員函式也無法訪問普通成員變數,只能訪問靜態成員(在全域),

const 成員變數/成員函式(常成員函式)/物件

const成員變數:加上 const 關鍵字,初始化 const 成員變數只有一種方法,就是通過建構式的初始化串列

const成員函式: const 成員函式可以使用類中的所有成員變數,但是不能修改它們的值,這種措施主要還是為了保護資料而設定的,一般類中的get函式都設定為常成員函式,只讀不給改

  • 函式開頭的 const 用來修飾函式的回傳值,表示回傳值是 const 型別,也就是不能被修改,例如const char * getname()

  • 函式頭部的結尾加上 const 表示常成員函式,這種函式只能讀取成員變數的值,而不能修改成員變數的值,例如char * getname() const

    class Student {
    public:
        Student(char *name, int age, float score): m_name(name), m_age(age), m_score(score) {}//方法實作都不寫;
        char *getname() const;
    prviate:
        char *m_name;
        int m_age;
        float m_score; 
    };
    char* Student::getname() const {
        return m_name;
    }//方法實作都不寫;
    

const物件: const 也可以用來修飾物件,稱為常物件,一旦將物件定義為常物件之后,就只能呼叫類的 const 成員(包括 const 成員變數和 const 成員函式)了,因為非 const 成員可能會修改物件的資料(編譯器也會這樣假設),C++禁止這樣做,

友元函式和友元類

借助友元(friend),可以使得其他類中的成員函式以及全域范圍內的函式訪問當前類的 private 成員,在當前類以外定義的、不屬于當前類的函式也可以在類中宣告,但要在前面加 friend 關鍵字,這樣就構成了友元函式,友元函式可以是不屬于任何類的 非成員函式,也可以是其他類的成員函式,

  • 將非成員函式宣告為友元函式
class Student{
public:
    Student(char *name, int age, float score);
public:
    friend void show(Student *pstu);  //將show()宣告為友元函式
private:
    char *m_name;
    int m_age;
    float m_score;
};
//非成員函式
void show(Student *pstu){//屬于全域函式,通過引數傳遞物件,可以訪問private成員變數
    cout<<pstu->m_name<<"的年齡是 "<<pstu->m_age<<",成績是 "<<pstu->m_score<<endl;
}
  • 將其他類的成員函式宣告為友元函式,該成員函式提供給一個類用
class Address;  //一定要提前宣告Address類
//宣告Student類
class Student{
public:
    Student(char *name, int age, float score);
public:
    void show(Address *addr);//要使用的類,前面有宣告address所以不會報錯!!!!!!!!!!!!!!!!!
private:
    char *m_name;
    int m_age;
    float m_score;
};
//宣告Address類
class Address{
private:
    char *m_province;  //省份
    char *m_city;  //城市
    char *m_district;  //區(市區)
public:
    Address(char *province, char *city, char *district);
    //將Student類中的成員函式show()宣告為友元函式
    friend void Student::show(Address *addr);//!!!!!!!!!!!!!!!!!!!
};
//實作Student類
Student::Student(char *name, int age, float score): m_name(name), m_age(age), m_score(score){ }
void Student::show(Address *addr){
    cout<<m_name<<"的年齡是 "<<m_age<<",成績是 "<<m_score<<endl;
    cout<<"家庭住址:"<<addr->m_province<<"省"<<addr->m_city<<"市"<<addr->m_district<<"區"<<endl;
}

image-20220308014446508

友元類:

將類 B 宣告為類 A 的友元類,那么類 B 中的所有成員函式都是類 A 的友元函式,可以訪問類 A 的所有成員,包括 public、protected、private 屬性的

class Address;  //提前宣告Address類
//宣告Student類
class Student{
public:
    Student(char *name, int age, float score);
public:
    void show(Address *addr);
private:
    char *m_name;
    int m_age;
    float m_score;
};
//宣告Address類
class Address{
public:
    Address(char *province, char *city, char *district);
public:
    //將Student類宣告為Address類的友元類
    friend class Student;
private:
    char *m_province;  //省份
    char *m_city;  //城市
    char *m_district;  //區(市區)
};
//實作Student類
Student::Student(char *name, int age, float score): m_name(name), m_age(age), m_score(score){ }
void Student::show(Address *addr){
    cout<<m_name<<"的年齡是 "<<m_age<<",成績是 "<<m_score<<endl;
    cout<<"家庭住址:"<<addr->m_province<<"省"<<addr->m_city<<"市"<<addr->m_district<<"區"<<endl;
}
//實作Address類
Address::Address(char *province, char *city, char *district){
    m_province = province;
    m_city = city;
    m_district = district;
}
  • 友元的關系是單向的而不是雙向的,如果宣告了類 B 是類 A 的友元類,不等于類 A 是類 B 的友元類,類 A 中的成員函式不能訪問類 B 中的 private 成員,
  • 友元的關系不能傳遞,如果類 B 是類 A 的友元類,類 C 是類 B 的友元類,不等于類 C 是類 A 的友元類,
  • 除非有必要,一般不建議把整個類宣告為友元類,而只將某些成員函式宣告為友元函式,這樣更安全一些,

ps: 其實類也是一種作用域 , 普通的成員只能通過物件(可以是物件本身,也可以是物件指標或物件參考)來訪問,靜態成員既可以通過物件訪問,又可以通過類訪問,而 typedef 定義的型別只能通過類來訪問

struct和class的區別

C++中,struct 類似于 class,既可以包含成員變數,又可以包含成員函式,

C++中的 struct 和 class 基本是通用的,唯有幾個細節不同:

  • 使用 class 時,類中的成員默認都是 private 屬性的;而使用 struct 時,結構體中的成員默認都是 public 屬性的,
  • class 繼承默認是 private 繼承,而 struct 繼承默認是 public 繼承(到繼承會講),
  • class 可以使用模板,而 struct 不能(到模板會講),

建議使用 class 來定義類,而使用 struct 來定義結構體,這樣做語意更加明確

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/472233.html

標籤:C++

上一篇:避免意外重復點擊Anybtn的最佳方法是什么?

下一篇:“有土唄”心機得把視頻分成了兩部分,還不是我被用python下載了完整版~

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more