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

深入理解char *a與char a[]的區(qū)別

 更新時間:2016年12月15日 15:16:54   作者:jihite  
很多人可能或多或少知道char *a與char a[]的一些區(qū)別,但如果詳細的說出來卻不知如何說去,下面這篇文章就給大家詳細介紹了關(guān)于C語言中char *a與char a[]的區(qū)別,有需要的朋友們可以參考借鑒,下面來一起學(xué)習(xí)學(xué)習(xí)吧。

前言

指針和數(shù)組存在著一些本質(zhì)的區(qū)別。當(dāng)然,在某種情況下,比如數(shù)組作為函數(shù)的參數(shù)進行傳遞時,由于該數(shù)組自動退化為同類型的指針,所以在函數(shù)內(nèi)部,作 為函數(shù)參數(shù)傳遞進來的指針與數(shù)組確實具有一定的一致性,但這只是一種比較特殊的情況而已,在本質(zhì)上,兩者是有區(qū)別的。

下面來看看詳細的介紹。

char *a = "hello" 中的a是指向第一個字符‘a(chǎn)'的一個指針

char a[20] = "hello" 中數(shù)組名a也是執(zhí)行數(shù)組第一個字符‘h'的指針

但二者并不相同:

看實例:把兩個字符串相加:

結(jié)果:

對比:

結(jié)果:

把字符串加到指針?biāo)傅淖执先?,出現(xiàn)段錯誤,本質(zhì)原因:*d="0123456789"存放在常量區(qū),是無法修的。而數(shù)組是存放在棧中,是可以修改的。

兩者區(qū)別如下:

一. ”讀“ ”寫“ 能力

     char *a = "abcd";  此時"abcd"存放在常量區(qū)。通過指針只可以訪問字符串常量,而不可以改變它。

     而char a[20] = "abcd"; 此時 "abcd"存放在棧??梢酝ㄟ^指針去訪問和修改數(shù)組內(nèi)容。

二. 賦值時刻

     char *a = "abcd"; 是在編譯時就確定了(因為為常量)。

     而char a[20] = "abcd"; 在運行時確定

三. 存取效率

     char *a = "abcd"; 存于靜態(tài)存儲區(qū)。在棧上的數(shù)組比指針?biāo)赶蜃址?。因此?br />

     而char a[20] = "abcd"; 存于棧上。快

另外注意:

     char a[] = "01234",雖然沒有指明字符串的長度,但是此時系統(tǒng)已經(jīng)開好了,就是大小為6-----'0' '1' '2' '3' '4' '5' '\0',(注意strlen(a)是不計‘\0')

看一結(jié)構(gòu)中出現(xiàn)的同樣的問題:

這樣紅色部分在調(diào)用Init函數(shù)時會出現(xiàn)“Segment Default", 因為此時 指針n是靜態(tài)的,只有“讀”的本事,不可以改變。

內(nèi)存分配方式

內(nèi)存分配有三種:靜態(tài)存儲區(qū)、堆區(qū)和棧區(qū)。他們的功能不同,對他們使用方式也就不同。

     1、靜態(tài)存儲區(qū):內(nèi)存在程序編譯的時候就已經(jīng)分配好,這塊內(nèi)存在程序的整個運行期間都存在。它主要存放靜態(tài)數(shù)據(jù)、全局數(shù)據(jù)和常量。

      2、棧區(qū):在執(zhí)行函數(shù)時,函數(shù)(包括main函數(shù))內(nèi)局部變量的存儲單元都可以在棧上創(chuàng)建,函數(shù)執(zhí)行結(jié)束時這些存儲單元自動被釋放。棧內(nèi)存分配運算內(nèi)置于處理器的指令集中,效率很高,但是分配的內(nèi)存容量有限。(任何變量都處于站區(qū),例如int a[] = {1, 2},變量a處于棧區(qū)。數(shù)組的內(nèi)容也存在于棧區(qū)。)

      3、堆區(qū):亦稱動態(tài)內(nèi)存分配。程序在運行的時候用malloc或new申請任意大小的內(nèi)存,程序員自己負責(zé)在適當(dāng)?shù)臅r候用free或delete釋放內(nèi)存。動態(tài)內(nèi)存的生存期可以由我們決定,如果我們不釋放內(nèi)存,程序?qū)⒃谧詈蟛裴尫诺魟討B(tài)內(nèi)存。 但是,良好的編程習(xí)慣是:如果某動態(tài)內(nèi)存不再使用,需要將其釋放掉,并立即將指針置位NULL,防止產(chǎn)生野指針。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

相關(guān)文章

  • C語言數(shù)據(jù)結(jié)構(gòu)深入探索順序表

    C語言數(shù)據(jù)結(jié)構(gòu)深入探索順序表

    順序表,全名順序存儲結(jié)構(gòu),是線性表的一種,線性表用于存儲邏輯關(guān)系為“一對一”的數(shù)據(jù),順序表自然也不例外,不僅如此,順序表對數(shù)據(jù)的物理存儲結(jié)構(gòu)也有要求,跟隨下文來具體了解吧
    2022-03-03
  • C語言經(jīng)典順序表真題演練講解

    C語言經(jīng)典順序表真題演練講解

    程序中經(jīng)常需要將一組數(shù)據(jù)元素作為整體管理和使用,需要創(chuàng)建這種元素組,用變量記錄它們,傳進傳出函數(shù)等。一組數(shù)據(jù)中包含的元素個數(shù)可能發(fā)生變化,順序表則是將元素順序地存放在一塊連續(xù)的存儲區(qū)里,元素間的順序關(guān)系由它們的存儲順序自然表示
    2022-04-04
  • C++ Invalidaterect()函數(shù)作用案例詳解

    C++ Invalidaterect()函數(shù)作用案例詳解

    這篇文章主要介紹了C++ Invalidaterect()函數(shù)作用案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C++實現(xiàn)LeetCode(8.字符串轉(zhuǎn)為整數(shù))

    C++實現(xiàn)LeetCode(8.字符串轉(zhuǎn)為整數(shù))

    這篇文章主要介紹了C++實現(xiàn)LeetCode(8.字符串轉(zhuǎn)為整數(shù)),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C數(shù)據(jù)結(jié)構(gòu)之單鏈表詳細示例分析

    C數(shù)據(jù)結(jié)構(gòu)之單鏈表詳細示例分析

    以下是對C語言中的單鏈表進行了詳細的分析介紹,需要的朋友可以過來參考下
    2013-08-08
  • C語言快速掌握位段使用

    C語言快速掌握位段使用

    位段位段的聲明和結(jié)構(gòu)是類似的,但是也會有所不同,此篇文章將帶你了解位段是什么已以及位段的使用和位段的特性,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-09-09
  • C++成員解除引用運算符的示例詳解

    C++成員解除引用運算符的示例詳解

    這篇文章主要介紹了C++成員解除引用運算符,本例子在編譯期間給指針賦值,在更為復(fù)雜的類中,可以使用指向數(shù)據(jù)成員和方法的成員指針,需要的朋友可以參考下
    2022-01-01
  • OpenGL畫bezier曲線

    OpenGL畫bezier曲線

    這篇文章主要為大家詳細介紹了OpenGL畫bezier曲線,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • Qt實現(xiàn)TCP網(wǎng)絡(luò)編程

    Qt實現(xiàn)TCP網(wǎng)絡(luò)編程

    這篇文章主要為大家詳細介紹了Qt實現(xiàn)TCP網(wǎng)絡(luò)編程,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • C語言return, exit, abort的區(qū)別

    C語言return, exit, abort的區(qū)別

    這篇文章主要介紹了C語言return, exit, abort的區(qū)別,一般情況下,在C語言中退出一個程序用return,如果在main函數(shù)中,return在清理局部對象之后,會調(diào)用exit函數(shù),和return相比,exit并不會銷毀局部對象,下面一起進入文章了解更詳細內(nèi)容吧,需要的朋友也可以參考一下
    2022-01-01

最新評論