C/C++ 淺拷貝和深拷貝的實(shí)例詳解
C/C++ 淺拷貝和深拷貝的實(shí)例詳解
深拷貝是指拷貝對象的具體內(nèi)容,而內(nèi)存地址是自主分配的,拷貝結(jié)束之后,兩個對象雖然存的值是相同的,但是內(nèi)存地址不一樣,兩個對象也互不影響,互不干涉。
淺拷貝就是對內(nèi)存地址的復(fù)制,讓目標(biāo)對象指針和源對象指向同一片內(nèi)存空間.
淺拷貝只是對對象的簡單拷貝,讓幾個對象共用一片內(nèi)存,當(dāng)內(nèi)存銷毀的時候,指向這片內(nèi)存的幾個指針需要重新定義才可以使用,要不然會成為野指針。
在iOS開發(fā)中也會涉及到淺拷貝和深拷貝,簡而言之:
淺拷貝:拷貝指針變量的值
深拷貝:拷貝指針?biāo)赶騼?nèi)存空間
不過這次我們通過C語言來實(shí)現(xiàn):
//聲明一個結(jié)構(gòu)體 typedef struct Person { char name[20]; int age; char *alias; }Person; //拷貝方法 void copyPerson(Person *from, Person *to){ *to = *from; } //main函數(shù) int main(int argc, const char * argv[]) { Person p1; p1.age = 11; strcpy(p1.name, "royce"); p1.alias = "owen"; Person p2; copyPerson(&p1, &p2); printf("p2:%p p1:%p\np2-alias:%p p1-alias:%p\n",&p2,&p1,p2.alias,p1.alias); return 0; } //打印 p2-alias:0x100000f80 p1-alias:0x100000f80
我們發(fā)現(xiàn)p1的alias和p2的alias指向了同一塊內(nèi)存空間,編譯器=號賦值默認(rèn)淺拷貝
實(shí)現(xiàn)深拷貝
void copyPerson(Person *from, Person *to){ *to = *from; to->alias = (char *)malloc(100); strcpy(to->alias, from->alias); } //打印 p2-alias:0x1003069a0 p1-alias:0x100000f82
我們給p2的alias重寫分配了內(nèi)存,然后將p1的alias拷貝進(jìn)去
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
C語言:利用指針編寫程序,用梯形法計算給定的定積分實(shí)例
今天小編就為大家分享一篇C語言:利用指針編寫程序,用梯形法計算給定的定積分實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12C語言實(shí)現(xiàn)一個多線程委托模型的示例詳解
這篇文章主要介紹了C語言實(shí)現(xiàn)一個多線程委托模型,這就是一個使用C語言實(shí)現(xiàn)多線程委托模型的例子,其中包含boss線程和worker線程,可以處理工作線程的異常情況,需要的朋友可以參考下2023-06-06