欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于c++中的默認拷貝函數(shù)的使用詳解

 更新時間:2013年05月13日 08:47:49   作者:  
本篇文章對c++中默認拷貝函數(shù)的使用進行了詳細的分析介紹。需要的朋友參考下

《c++編程思想》上說一個類如果沒有拷貝函數(shù),那么編譯器就會自動創(chuàng)建一個默認的拷貝函數(shù)。下面就讓我們看一下真實的情況。

首先看一個簡單的類X,這個類沒有顯示定義拷貝構(gòu)造函數(shù)。

c++源碼如下:

復制代碼 代碼如下:

class X {
private:
    int i;
    int j;
};

int main() {
    X x1;//先定義對象x1
    X x2 = x1;//將x1拷貝給x2
}


下面是其匯編代碼:
復制代碼 代碼如下:

_main    PROC

; 7    : int main() {

    push    ebp
    mov    ebp, esp
    sub    esp, 16                    ; 為對象x1,x2預留16byte的棧空間

; 8    :     X x1;//先定義對象x1
; 9    :     X x2 = x1;//將x1拷貝給x2

    mov    eax, DWORD PTR _x1$[ebp];將x1的首地址里面的內(nèi)容給寄存器eax,也就將x1中的成員變量i的值給eax
    mov    DWORD PTR _x2$[ebp], eax;將eax里面的值寫入x2的首地址,也就是將eax里面的值寫給x2的成員變量i
    mov    ecx, DWORD PTR _x1$[ebp+4];將偏移x1首地址4byte的內(nèi)存里面的值給寄存器eax,也就是將x1中的成員變量j的值給ecx
    mov    DWORD PTR _x2$[ebp+4], ecx;將ecx里面的值寫入偏移x2首地址4byte的內(nèi)存里面,也就是將ecx里面的值寫給x2的成員變量j

; 10   : }

    xor    eax, eax
    mov    esp, ebp
    pop    ebp
    ret    0
_main    ENDP


從匯編代碼里面可以看出,根本沒有函數(shù)被調(diào)用,所有的拷貝賦值都是通過寄存器與內(nèi)存地址相互通信完成。和編譯器提供默認構(gòu)造函數(shù)一樣,可以把這種情況看成是編譯器提供了一個無用的拷貝構(gòu)造函數(shù)。

那么,什么時候編譯器才真正的提供默認拷貝構(gòu)造函數(shù),并且顯示調(diào)用呢?

下面是一種情況,類X里面含有虛成員函數(shù):

c++源碼:

復制代碼 代碼如下:

class X {
private:
    int i;
    int j;
public:
    virtual ~X() {}//虛析構(gòu)函數(shù)
};

int main() {
    X x1;//先定義對象x1
    X x2 = x1;//將x1拷貝給x2
}


由于這里只討論拷貝函數(shù),所以只看主函數(shù)main和拷貝函數(shù)里面的匯編代碼:

下面是主函數(shù)main里面的匯編代碼:

復制代碼 代碼如下:

_main    PROC

; 9    : int main() {

    push    ebp
    mov    ebp, esp
    sub    esp, 24                    ; 由于引入了虛函數(shù),每個類所占的空間編程12byte 成員變量i,j8byte vptr指針4byte 因此這里為x1 x2預留24byte

; 10   :     X x1;//先定義對象x1

    lea    ecx, DWORD PTR _x1$[ebp];獲取x1的首地址,放入ecx,為調(diào)用構(gòu)造函數(shù)的秘密參數(shù)傳入,即this
    call    ??0X@@QAE@XZ;調(diào)用構(gòu)造函數(shù)

; 11   :     X x2 = x1;//將x1拷貝給x2

    lea    eax, DWORD PTR _x1$[ebp];獲取x1的首地址,放入寄存器eax
    push    eax;將eax壓棧,作為拷貝構(gòu)造函數(shù)的參數(shù)
    lea    ecx, DWORD PTR _x2$[ebp];獲取x2的首地址,放入寄存器ecx,作為調(diào)用拷貝構(gòu)造函數(shù)的秘密參數(shù)傳入,即this
    call    ??0X@@QAE@ABV0@@Z;調(diào)用拷貝構(gòu)造函數(shù)

; 12   : }

    lea    ecx, DWORD PTR _x2$[ebp];獲取x2的首地址,放入ecx寄存器,作為調(diào)用析構(gòu)函數(shù)傳入的秘密參數(shù),即this
    call    ??1X@@UAE@XZ                ; 調(diào)用析構(gòu)函數(shù)
    lea    ecx, DWORD PTR _x1$[ebp];獲取x1的首地址,放入ecx寄存器,作為調(diào)用析構(gòu)函數(shù)傳入的秘密參數(shù),即this
                                ;析構(gòu)的順序與構(gòu)建的順序相反
    call    ??1X@@UAE@XZ                ; 調(diào)用析構(gòu)函數(shù)
    xor    eax, eax
    mov    esp, ebp
    pop    ebp
    ret    0
_main    ENDP


可以看到,編譯器為類X提供了默認的拷貝構(gòu)造函數(shù)(非無用的默認拷貝構(gòu)造函數(shù)),并且顯示調(diào)用。

由于一個類繼承自虛基類或者繼承自有虛函數(shù)成員的基類,使得它本身也含有虛函數(shù)成員,因此也就屬于上一種情形。所以編譯器在這種情況下,也會提供非無用的默認拷貝構(gòu)造函數(shù),并且能夠顯示調(diào)用。

下面是第二種情形,類X繼承自類Y,類Y有顯示定義的拷貝構(gòu)造函數(shù),而類沒有提供拷貝構(gòu)造函數(shù):

下面是c++源碼:

復制代碼 代碼如下:

class Y {
private:
    int j;
public:
   Y(const Y& y) {}
   Y() {};//必須為Y提供默認的構(gòu)造函數(shù),否則編譯出錯
};
class X : public Y {
private:
    int i;
    int j;
};


int main() {
    X x1;//先定義對象x1
    X x2 = x1;//將x1拷貝給x2
}


下面是mian函數(shù)匯編代碼:
復制代碼 代碼如下:

; 16   : int main() {

    push    ebp
    mov    ebp, esp
    sub    esp, 24                    ; 為x1 x2預留24byte空間

; 17   :     X x1;//先定義對象x1

    lea    ecx, DWORD PTR _x1$[ebp];獲取x1的首地址,作為隱含參數(shù)傳遞給構(gòu)造函數(shù)
    call    ??0X@@QAE@XZ;//調(diào)用編譯器為類X提供的默認構(gòu)造函數(shù)

; 18   :     X x2 = x1;//將x1拷貝給x2

    lea    eax, DWORD PTR _x1$[ebp];獲取x1的首地址,傳給寄存器eax
    push    eax;將eax壓棧,作為調(diào)用類X的拷貝構(gòu)造函數(shù)的參數(shù)
    lea    ecx, DWORD PTR _x2$[ebp];獲取x2的首地址,作為調(diào)用類X的拷貝函數(shù)的隱含參數(shù)
    call    ??0X@@QAE@ABV0@@Z;調(diào)用編譯器提供的默認拷貝構(gòu)造函數(shù)

; 19   : }

    xor    eax, eax
    mov    esp, ebp
    pop    ebp
    ret    0


下面是類X的拷貝構(gòu)造函數(shù)的匯編碼:
復制代碼 代碼如下:

??0X@@QAE@ABV0@@Z PROC                    ; X::X, COMDAT
; _this$ = ecx
    push    ebp
    mov    ebp, esp
    push    ecx
    mov    DWORD PTR _this$[ebp], ecx;ecx里面有x2的首地址
    mov    eax, DWORD PTR ___that$[ebp];將x1的首地址給eax
    push    eax;將eax的首地址壓棧,作為調(diào)用父類拷貝構(gòu)造函數(shù)的參數(shù)
    mov    ecx, DWORD PTR _this$[ebp];將x2的首地址給ecx,作為隱含參數(shù)傳給父類的拷貝構(gòu)造函數(shù)
    call    ??0Y@@QAE@ABV0@@Z            ; 調(diào)用父類拷貝構(gòu)造函數(shù)
    mov    ecx, DWORD PTR _this$[ebp];獲取x2的首地址給ecx
    mov    edx, DWORD PTR ___that$[ebp];獲取x1的首地址給edx
    mov    eax, DWORD PTR [edx+4];將偏移x1首地址4byte處的內(nèi)存里面的值寫給eax,即將x1中子類成員變量i的值寫給eax,因為x1的首地址處存放的是父類成員變量i,其值
                              ;由父類拷貝構(gòu)造函數(shù)負責拷貝給x2
    mov    DWORD PTR [ecx+4], eax;將eax的值寫入偏離x2首地址4byte處的內(nèi)存里面,即將eax的值寫入x2中子類成員變量i,因為x2的首地址處存放父類成員變量i,其值
                              ;由父類拷貝構(gòu)造函數(shù)負責拷貝
    mov    ecx, DWORD PTR _this$[ebp];將x2的首地址給ecx
    mov    edx, DWORD PTR ___that$[ebp];將x1的首地址給edx
    mov    eax, DWORD PTR [edx+8];將偏移x1首地址8byte處的內(nèi)存里面的值給eax,即將x1中子類成員變量j的值給eax
    mov    DWORD PTR [ecx+8], eax;將eax的值寫入偏移x2首地址8byte的內(nèi)存里面,即將eax的值寫入x2子類成員j中
    mov    eax, DWORD PTR _this$[ebp];將x2的首地址給eax,作為返回值。構(gòu)造函數(shù)總是返回對象首地址
    mov    esp, ebp
    pop    ebp
    ret    4
??0X@@QAE@ABV0@@Z ENDP

從匯編碼中可以看到,編譯器確實為類X提供了默認的拷貝構(gòu)造函數(shù),并且進行了顯示調(diào)用。而且在調(diào)用類X的拷貝構(gòu)造函數(shù)中,首先調(diào)用父類的拷貝構(gòu)造函數(shù),拷貝父類中的成員變量,然后再拷貝子類中的成員變量。

下面是父類Y中的拷貝構(gòu)造函數(shù)匯編碼:

復制代碼 代碼如下:

??0Y@@QAE@ABV0@@Z PROC                    ; Y::Y, COMDAT
; _this$ = ecx

; 5    :    Y(const Y& y) {}

    push    ebp
    mov    ebp, esp
    push    ecx;//這里壓棧的目的是為隱含傳給父類拷貝函數(shù)的this(即x2的首地址)
    mov    DWORD PTR _this$[ebp], ecx;ecx里面含有x2的首地址(即this),放入剛才的預留空間
    mov    eax, DWORD PTR _this$[ebp];將x2的首地址寫入eax,作為返回值。構(gòu)造函數(shù)總是返回對象首地址
    mov    esp, ebp
    pop    ebp
    ret    4
??0Y@@QAE@ABV0@@Z ENDP                    ; Y::Y
_TEXT    ENDS


從匯編嗎可以看到,由于父類自己顯示定義了拷貝構(gòu)造函數(shù),編譯器只是負責調(diào)用而已,并不提供像上面子類X里面默認拷貝構(gòu)造函數(shù)的拷貝功能,即并不拷貝父類成員變量i。因為,在c++源碼里面,父類拷貝構(gòu)造函數(shù)本身就是空函數(shù),什么也不做。

如果子類X 父類Y都不提供拷貝構(gòu)造函數(shù),情形有時怎樣的呢?

下面是c++源碼:

復制代碼 代碼如下:

class Y {
private:
    int j;
};
class X : public Y {
private:
    int i;
    int j;
};


int main() {
    X x1;//先定義對象x1
    X x2 = x1;//將x1拷貝給x2
}


下面是對應(yīng)的匯編碼:
復制代碼 代碼如下:

_main    PROC

; 12   : int main() {

    push    ebp
    mov    ebp, esp
    sub    esp, 24                    ; 為x1 x2預留24byte空間

; 13   :     X x1;//先定義對象x1
; 14   :     X x2 = x1;//將x1拷貝給x2

    mov    eax, DWORD PTR _x1$[ebp];獲取x1的首地址里面的值,存入eax,即獲取x1父類成員變量i的值寫給eax
    mov    DWORD PTR _x2$[ebp], eax;將eax的值寫入x2的首地址指向的內(nèi)存,即將eax的值寫給x2中的父類成員變量i
    mov    ecx, DWORD PTR _x1$[ebp+4];獲取偏移x1首地址4byte處的內(nèi)存里面的值,寫入ecx,即獲取x1子類成員變量i的值寫給ecx
    mov    DWORD PTR _x2$[ebp+4], ecx;將ecx的值寫入偏移x2首地址4byte處的內(nèi)存里面,即將ecx的值寫給x2中子類成員變量i
    mov    edx, DWORD PTR _x1$[ebp+8];獲取偏移x1首地址8byte處的內(nèi)存里面的值,寫入edx,即獲取x1子類成員變量j的值寫給edx
    mov    DWORD PTR _x2$[ebp+8], edx;將edx的值寫入偏移x2首地址8byte處的內(nèi)存里面,即將edx的值寫入x2子類成員變量j

; 15   : }

    xor    eax, eax
    mov    esp, ebp
    pop    ebp
    ret    0
_main    ENDP


可以看到,編譯器執(zhí)行了拷貝過程,但是提供的是像剛開始的無用的默認拷貝構(gòu)造函數(shù),無論是拷貝父類成員變量,還是子類成員變量,都沒有函數(shù)的調(diào)用。

下面看第三種情況,類X含有類Y的成員變量,類Y的成員變量有拷貝構(gòu)造函數(shù)。

c++源碼如下:

復制代碼 代碼如下:

class Y {
private:
    int j;
public:
    Y(const Y& y) {}
    Y() {}//必須為Y提供默認的構(gòu)造函數(shù),否則編譯報錯
};
class X  {
private:
    int i;
    int j;
    Y y;
};


int main() {
    X x1;//先定義對象x1
    X x2 = x1;//將x1拷貝給x2
}


下面是main函數(shù)中的匯編碼:
復制代碼 代碼如下:

_main    PROC

; 16   : int main() {

    push    ebp
    mov    ebp, esp
    sub    esp, 24                    ; 為x1 x2預留24byte的空間

; 17   :     X x1;//先定義對象x1

    lea    ecx, DWORD PTR _x1$[ebp];獲取x1的首地址,作為隱含參數(shù)傳遞給構(gòu)造函數(shù)
    call    ??0X@@QAE@XZ;調(diào)用構(gòu)造函數(shù)

; 18   :     X x2 = x1;//將x1拷貝給x2

    lea    eax, DWORD PTR _x1$[ebp];獲取x1的首地址,放入寄存器eax
    push    eax;將eax壓棧,為作為參數(shù)傳遞給編譯器提供的默認拷貝構(gòu)造函數(shù)
    lea    ecx, DWORD PTR _x2$[ebp];獲取x2的首地址,作為隱含參數(shù)傳遞給編譯器提供的默認拷貝構(gòu)造函數(shù)
    call    ??0X@@QAE@ABV0@@Z;調(diào)用拷貝構(gòu)造函數(shù)

; 19   : }

    xor    eax, eax
    mov    esp, ebp
    pop    ebp
    ret    0
_main    ENDP


下面是編譯器為類X提供的默認拷貝構(gòu)造函數(shù)的匯編碼:
復制代碼 代碼如下:

??0X@@QAE@ABV0@@Z PROC                    ; X::X, COMDAT
; _this$ = ecx
    push    ebp
    mov    ebp, esp
    push    ecx;壓棧的目的是為this(即x2的首地址)預留空間
    mov    DWORD PTR _this$[ebp], ecx;ecx里面含有x2的首地址,放入剛才預留的空間里面
    mov    eax, DWORD PTR _this$[ebp];將x2的首地址給eax
    mov    ecx, DWORD PTR ___that$[ebp];將x1的首地址給ecx
    mov    edx, DWORD PTR [ecx];將x1的首地址的內(nèi)容寫入edx,即將x1中的成員變量i寫入edx
    mov    DWORD PTR [eax], edx;將edx的值寫入x2的首地址,即將edx的值寫入x2的成員變量i
    mov    eax, DWORD PTR _this$[ebp];將x2的首地址寫入寄存器eax
    mov    ecx, DWORD PTR ___that$[ebp];將x1的首地址寫入寄存器ecx
    mov    edx, DWORD PTR [ecx+4];將偏移x1首地址4byte處的內(nèi)存里面的值寫入edx,即將x1的成員變量j的值寫入edx
    mov    DWORD PTR [eax+4], edx;將edx的值寫入偏移x2首地址4byte處的內(nèi)存,即將edx的值寫入x2的成員變量j
    mov    eax, DWORD PTR ___that$[ebp];將x1的首地址存入寄存器eax
    add    eax, 8;//將x1的首地址加8,得到x1中成員對象y所處的地址,放入eax中
    push    eax;將eax的值壓棧,作為調(diào)用成員變量y的拷貝函數(shù)的參數(shù)
    mov    ecx, DWORD PTR _this$[ebp];將x2的首地址存入寄存器ecx
    add    ecx, 8;將x2的首地址加8,得到x2中成員對象y所在地址,放入ecx,這個地址作為隱含的參數(shù)傳給成員變量函數(shù)的拷貝構(gòu)造函數(shù)
    call    ??0Y@@QAE@ABV0@@Z            ; 調(diào)用成員對象y的拷貝構(gòu)造函數(shù)
    mov    eax, DWORD PTR _this$[ebp];將x2的首地址放入eax,作為返回值。構(gòu)造函數(shù)總是返回對象的首地址
    mov    esp, ebp
    pop    ebp
    ret    4
??0X@@QAE@ABV0@@Z ENDP

從匯編嗎可以看到,調(diào)用類X拷貝構(gòu)造函數(shù)的時候,先將x1中的成員變量i,j拷貝到x2中,然后才是調(diào)用成員對象y的拷貝構(gòu)造函數(shù)拷貝y中的成員變量。這和繼承不同,在繼承中,總是先調(diào)用父類的拷貝構(gòu)造函數(shù),再進行子類中的拷貝。這說明,對于這種包含成員對象的情況,成員對象的拷貝函數(shù)調(diào)用時機與他們定義的位置有關(guān)。在這里,類X的成員對象y在成員變量i,j之后定義,因此,它的拷貝構(gòu)造函數(shù)要等拷貝完i,j之后才會被調(diào)用。

下面是類Y中的拷貝構(gòu)造函數(shù)匯編代碼:

復制代碼 代碼如下:

??0Y@@QAE@ABV0@@Z PROC                    ; Y::Y, COMDAT
; _this$ = ecx

; 6    :     Y(const Y& y) {}

    push    ebp
    mov    ebp, esp
    push    ecx;壓棧ecx的目的是為了存放this(x2中成員對象y的首地址)預留空間
    mov    DWORD PTR _this$[ebp], ecx;ecx里面有x2中成員對象y的首地址,放入剛才的預留空間
    mov    eax, DWORD PTR _this$[ebp];將x2中成員變量首地址放入eax,作為返回值。構(gòu)造函數(shù)總是返回對象首地址
    mov    esp, ebp
    pop    ebp
    ret    4
??0Y@@QAE@ABV0@@Z ENDP


從代碼中可以看到,由于類Y顯示定義了拷貝構(gòu)造函數(shù),編譯器也只是負責顯示調(diào)用,并沒有提供任何的拷貝功能。因為在類Y中,拷貝構(gòu)造函數(shù)就是被定義成了一個空函數(shù)

和繼承一樣,如果成員對象也沒有拷貝構(gòu)造函數(shù)呢?

下面是c++源碼:

復制代碼 代碼如下:

class Y {
private:
    int j;

};
class X  {
private:
    int i;
    int j;
    Y y;
};


int main() {
    X x1;//先定義對象x1
    X x2 = x1;//將x1拷貝給x2
}


下面是對象的匯編碼:
復制代碼 代碼如下:

_main    PROC

; 14   : int main() {

    push    ebp
    mov    ebp, esp
    sub    esp, 24                    ; 00000018H

; 15   :     X x1;//先定義對象x1
; 16   :     X x2 = x1;//將x1拷貝給x2

    mov    eax, DWORD PTR _x1$[ebp];將x1中首地址的內(nèi)容寫入eax,即將x1中的成員變量值i寫入eax
    mov    DWORD PTR _x2$[ebp], eax;將eax的值寫入x2的首地址處,即將eax的值寫入x2的成員變量i
    mov    ecx, DWORD PTR _x1$[ebp+4];將偏移x1首地址4byte處的內(nèi)存里面的內(nèi)容寫入ecx,即將x1中成員變量j的值寫入ecx
    mov    DWORD PTR _x2$[ebp+4], ecx;將ecx的值寫入偏移x2首地址4byte處的內(nèi)存,即將ecx的值寫入x2中成員變量j
    mov    edx, DWORD PTR _x1$[ebp+8];將偏移x1首地址8byte處(這里是x1成員對象y的首地址)的內(nèi)存值寫入edx,即將x1中成員對象y中的成員變量i值寫入edx
    mov    DWORD PTR _x2$[ebp+8], edx;將edx的值寫入偏移x2首地址8byte處(這里是x2成員對象y的首地址)的內(nèi)存里面,即將edx的值寫入x2中成員對象y的成員變量i里面


從匯編嗎可以看出,編譯器在這種情況下任然只是提供無用的默認拷貝構(gòu)造函數(shù),即沒有顯示的函數(shù)調(diào)用,只是用寄存器和內(nèi)存之間的通信完成拷貝過程

綜合上面的分析,可以看到:

對于一個類,如果它沒有顯示定義拷貝構(gòu)造函數(shù),編譯器并不總是提供非無用的默認拷貝構(gòu)造函數(shù),除非:

1 該類包含虛函數(shù)成員函數(shù)(包括繼承自虛基類或者繼承的基類中有虛函數(shù)成員),這時編譯器提供為該類提供非無用的默認拷貝構(gòu)造函數(shù)

2 該類繼承自一個基類,而基類含有自定義的拷貝函數(shù),這時編譯器為該類提供非無用的默認拷貝構(gòu)造函數(shù)。(如果基類本身沒有定義拷貝構(gòu)造函數(shù),但是編譯器會為基類提供一個非無用的默認拷貝構(gòu)造函數(shù),也屬于這種情況。也就是說,基類只要含有一個非無用的拷貝構(gòu)造函數(shù)就行,不管這個非無用的拷貝構(gòu)造函數(shù)是自定義的,還是編譯器提供的)

3 該類包含一個成員對象,而該成員對象有自定的拷貝構(gòu)造函數(shù),這時編譯器為該類提供非無用的默認拷貝構(gòu)造函數(shù)。(如果成員對象本身沒有定義拷貝構(gòu)造函數(shù),但是編譯器會為成員對象提供一個非無用的默認拷貝構(gòu)造函數(shù),也屬于這種情況。也就是說,成員對象只要包含一個非無用的拷貝構(gòu)造函數(shù)就行,不管這個非無用的拷貝構(gòu)造函數(shù)時自定義的,還是編譯器提供的。這中情況和上一種類似).

并且,如果一個類自定義了一個拷貝構(gòu)造函數(shù),編譯器只是負責調(diào)用,不會額外提供任何拷貝過程;而對于編譯器提供的默認拷貝函數(shù),不管是無用的,還是非無用的,都僅僅只是位拷貝(即淺拷貝).

相關(guān)文章

  • OpenCV實現(xiàn)多圖像拼接成一張大圖

    OpenCV實現(xiàn)多圖像拼接成一張大圖

    這篇文章主要為大家詳細介紹了OpenCV實現(xiàn)多圖像拼接成一張大圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • C++實現(xiàn)浮點數(shù)精確加法

    C++實現(xiàn)浮點數(shù)精確加法

    這篇文章主要為大家詳細介紹了C++實現(xiàn)浮點數(shù)精確加法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • C++中string轉(zhuǎn)換為char*類型返回后亂碼問題解決

    C++中string轉(zhuǎn)換為char*類型返回后亂碼問題解決

    這篇文章主要介紹了C++中string轉(zhuǎn)換為char*類型返回后亂碼問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • C語言與C++項目實現(xiàn)相互調(diào)用

    C語言與C++項目實現(xiàn)相互調(diào)用

    extern?“c”的作用可以實現(xiàn)c語言和c++相互調(diào)用,本文就詳細的介紹一下C語言與C++項目實現(xiàn)相互調(diào)用,感興趣的可以了解一下
    2022-01-01
  • Qt?事件處理機制的深入理解

    Qt?事件處理機制的深入理解

    本文主要介紹了Qt?事件處理機制的深入理解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-04-04
  • 深入理解C語言 static、extern與指針函數(shù)

    深入理解C語言 static、extern與指針函數(shù)

    這篇文章主要介紹了C語言 static、extern與指針函數(shù),有需要的朋友可以參考一下
    2013-12-12
  • C語言求兩個正整數(shù)的最大公約數(shù)示例代碼

    C語言求兩個正整數(shù)的最大公約數(shù)示例代碼

    在C語言中求兩個數(shù)的最大公約數(shù)是學習循環(huán)語句的非常經(jīng)典的問題,下面這篇文章主要給大家介紹了關(guān)于C語言求兩個正整數(shù)的最大公約數(shù)的相關(guān)資料,需要的朋友可以參考下
    2021-12-12
  • C語言lseek()函數(shù)詳解

    C語言lseek()函數(shù)詳解

    這篇文章主要介紹了C語言lseek()函數(shù)詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C語言泛型編程實例教程

    C語言泛型編程實例教程

    這篇文章主要介紹了C語言泛型編程,針對泛型的用法做了深入淺出的實例介紹,是C程序設(shè)計中非常實用的技巧,需要的朋友可以參考下
    2014-09-09
  • C++服務(wù)器和客戶端交互的項目實踐

    C++服務(wù)器和客戶端交互的項目實踐

    本文主要介紹了C++服務(wù)器和客戶端交互的項目實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-07-07

最新評論