深入理解char *a與char a[]的區(qū)別
前言
指針和數(shù)組存在著一些本質(zhì)的區(qū)別。當(dāng)然,在某種情況下,比如數(shù)組作為函數(shù)的參數(shù)進(jìn)行傳遞時(shí),由于該數(shù)組自動(dòng)退化為同類型的指針,所以在函數(shù)內(nèi)部,作 為函數(shù)參數(shù)傳遞進(jìn)來的指針與數(shù)組確實(shí)具有一定的一致性,但這只是一種比較特殊的情況而已,在本質(zhì)上,兩者是有區(qū)別的。
下面來看看詳細(xì)的介紹。
char *a = "hello"
中的a是指向第一個(gè)字符‘a(chǎn)'的一個(gè)指針
char a[20] = "hello"
中數(shù)組名a也是執(zhí)行數(shù)組第一個(gè)字符‘h'的指針
但二者并不相同:
看實(shí)例:把兩個(gè)字符串相加:
結(jié)果:
對(duì)比:
結(jié)果:
把字符串加到指針?biāo)傅淖执先?,出現(xiàn)段錯(cuò)誤,本質(zhì)原因:*d="0123456789"存放在常量區(qū),是無法修的。而數(shù)組是存放在棧中,是可以修改的。
兩者區(qū)別如下:
一. ”讀“ ”寫“ 能力
char *a = "abcd";
此時(shí)"abcd"存放在常量區(qū)。通過指針只可以訪問字符串常量,而不可以改變它。
而char a[20] = "abcd";
此時(shí) "abcd"存放在棧??梢酝ㄟ^指針去訪問和修改數(shù)組內(nèi)容。
二. 賦值時(shí)刻
char *a = "abcd";
是在編譯時(shí)就確定了(因?yàn)闉槌A浚?br />
而char a[20] = "abcd";
在運(yùn)行時(shí)確定
三. 存取效率
char *a = "abcd";
存于靜態(tài)存儲(chǔ)區(qū)。在棧上的數(shù)組比指針?biāo)赶蜃址?。因此?br />
而char a[20] = "abcd";
存于棧上???br />
另外注意:
char a[] = "01234",
雖然沒有指明字符串的長(zhǎng)度,但是此時(shí)系統(tǒng)已經(jīng)開好了,就是大小為6-----'0' '1' '2' '3' '4' '5' '\0',(注意strlen(a)
是不計(jì)‘\0')
看一結(jié)構(gòu)中出現(xiàn)的同樣的問題:
這樣紅色部分在調(diào)用Init
函數(shù)時(shí)會(huì)出現(xiàn)“Segment Default", 因?yàn)榇藭r(shí) 指針n是靜態(tài)的,只有“讀”的本事,不可以改變。
內(nèi)存分配方式
內(nèi)存分配有三種:靜態(tài)存儲(chǔ)區(qū)、堆區(qū)和棧區(qū)。他們的功能不同,對(duì)他們使用方式也就不同。
1、靜態(tài)存儲(chǔ)區(qū):內(nèi)存在程序編譯的時(shí)候就已經(jīng)分配好,這塊內(nèi)存在程序的整個(gè)運(yùn)行期間都存在。它主要存放靜態(tài)數(shù)據(jù)、全局?jǐn)?shù)據(jù)和常量。
2、棧區(qū):在執(zhí)行函數(shù)時(shí),函數(shù)(包括main函數(shù))內(nèi)局部變量的存儲(chǔ)單元都可以在棧上創(chuàng)建,函數(shù)執(zhí)行結(jié)束時(shí)這些存儲(chǔ)單元自動(dòng)被釋放。棧內(nèi)存分配運(yùn)算內(nèi)置于處理器的指令集中,效率很高,但是分配的內(nèi)存容量有限。(任何變量都處于站區(qū),例如int a[] = {1, 2},變量a處于棧區(qū)。數(shù)組的內(nèi)容也存在于棧區(qū)。)
3、堆區(qū):亦稱動(dòng)態(tài)內(nèi)存分配。程序在運(yùn)行的時(shí)候用malloc或new申請(qǐng)任意大小的內(nèi)存,程序員自己負(fù)責(zé)在適當(dāng)?shù)臅r(shí)候用free或delete釋放內(nèi)存。動(dòng)態(tài)內(nèi)存的生存期可以由我們決定,如果我們不釋放內(nèi)存,程序?qū)⒃谧詈蟛裴尫诺魟?dòng)態(tài)內(nèi)存。 但是,良好的編程習(xí)慣是:如果某動(dòng)態(tài)內(nèi)存不再使用,需要將其釋放掉,并立即將指針置位NULL,防止產(chǎn)生野指針。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關(guān)文章
C語言數(shù)據(jù)結(jié)構(gòu)深入探索順序表
順序表,全名順序存儲(chǔ)結(jié)構(gòu),是線性表的一種,線性表用于存儲(chǔ)邏輯關(guān)系為“一對(duì)一”的數(shù)據(jù),順序表自然也不例外,不僅如此,順序表對(duì)數(shù)據(jù)的物理存儲(chǔ)結(jié)構(gòu)也有要求,跟隨下文來具體了解吧2022-03-03C++ Invalidaterect()函數(shù)作用案例詳解
這篇文章主要介紹了C++ Invalidaterect()函數(shù)作用案例詳解,本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08C++實(shí)現(xiàn)LeetCode(8.字符串轉(zhuǎn)為整數(shù))
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(8.字符串轉(zhuǎn)為整數(shù)),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C數(shù)據(jù)結(jié)構(gòu)之單鏈表詳細(xì)示例分析
以下是對(duì)C語言中的單鏈表進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下2013-08-08Qt實(shí)現(xiàn)TCP網(wǎng)絡(luò)編程
這篇文章主要為大家詳細(xì)介紹了Qt實(shí)現(xiàn)TCP網(wǎng)絡(luò)編程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08