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

C語言詳細(xì)講解const的用法

 更新時(shí)間:2022年05月10日 08:41:59   作者:lonely-hermit  
今天探討const,首先來說是將變量常量化。為什么要將變量常量化,原因有諸多好處有諸多。比如可以使數(shù)據(jù)更加安全不會(huì)被修改

一、int const a / const int a

int 和const 都作為一個(gè)類型限定詞,有相同的地位,所以誰在前誰在后無所謂了,標(biāo)題中的這兩種寫法是一致的。

這是我們常規(guī)的用途,我們發(fā)現(xiàn)這樣的話我們對(duì)a已經(jīng)不能做任何修改了。

int main() {
    int const a = 10;
    printf("%d\n",a);
    return 0;
}

真的不能修改嗎?未必的

int main() {
    int const a = 10;
    int *p = &a;
    *p = 20;
    printf("%d\n",a);
    return 0;
}

成功修改,這是為什么呢,其實(shí)也很簡單,這與編譯器有關(guān),gcc編譯器中const是通過編譯器在編譯的時(shí)候執(zhí)行檢查來確保實(shí)現(xiàn)的,也就是檢查的時(shí)候我發(fā)現(xiàn)你沒有修改a的值,那我就認(rèn)為你是對(duì)的。更深入一層的原因,是因?yàn)間cc把const類型的常量也放在了data段,其實(shí)和普通的全局變量放在data段是一樣實(shí)現(xiàn)的,只是通過編譯器認(rèn)定這個(gè)變量是const的,運(yùn)行時(shí)并沒有標(biāo)記const標(biāo)志,所以只要騙過編譯器就可以修改了。

這個(gè)本質(zhì)上是C語言的問題,因?yàn)镃語言就沒有強(qiáng)制要求說const就是不能修改的,所以在C語言中使用const,就好象是 一種道德約束而非法律約束,所以大家使用const時(shí)更多是傳遞一種信息,就是告訴編譯器、也告訴讀程序的人,這個(gè)變量是不應(yīng)該也不必被修改的。而且我的理解中,這個(gè)東西其實(shí)設(shè)置為了強(qiáng)制不可變?cè)谀撤N程度上不也就限制了C語言的靈活性嘛,c的奇淫巧技不就依靠C語言的靈活性實(shí)現(xiàn)的嘛,所謂bug變特性,我的猜測哈,不知道丹尼斯·里奇是不是也是這么想的。

二、const int(*p)/int const(*p)

其實(shí)標(biāo)題是很好理解的,我們修飾了*p,使得p的指向不能被改變了。

int main() {
    int a = 10;
    int const (*p) = &a;
    printf("%d\n",*p);
    return 0;
}

上面的程序很好理解,p指向了a,p被const修飾,指向的對(duì)象a已經(jīng)不能被修改了,下面的程序輸出20就說明出了問題,這個(gè)還是上面我們講到的那個(gè)問題,這是一個(gè)君子約定。

int main() {
    int a = 10;
    int const (*p) = &a;
    a = 20;
    printf("%d\n",*p);
    return 0;
}

下面的四種寫法等價(jià)

int const (*p)
const int (*p)
int const *p
const int *p

三、int*const p

那么如何聲明一個(gè)自身是常量指針呢?方法是讓const盡可能的靠近p,下面的這個(gè)就是

int main() {
    int a = 10;
    int b = 20;
    int* const p = &a;
    printf("%d\n",*p);
    return 0;
}

指針只能指向a,指向b就報(bào)錯(cuò)。地址只能賦值一次。

這里有一個(gè)簡便的區(qū)分方法:沿著*號(hào)劃一條線,如果const位于*的左側(cè),則const就是用來修飾指針?biāo)赶虻淖兞?,即指針指向?yàn)槌A?如果const位于*的右側(cè),const就是修飾指針本身,即指針本身是常量。

四、const用于函數(shù)的地址傳遞參數(shù)

void func(const int *p);

這種形式通常用于在數(shù)組形式的參數(shù)中模擬傳值調(diào)用。也就是相當(dāng)于函數(shù)調(diào)用者聲稱:"我給你一個(gè)指向它的指針,但你不能去修它。"如果函數(shù)編寫者遵循了這個(gè)約定,那么就相當(dāng)于模擬了值傳遞。這也是const最有用之處了:用來限定函數(shù)的形參,這樣該函數(shù)將不會(huì)修改實(shí)參指針?biāo)傅臄?shù)據(jù)。這里注意了,是函數(shù)不應(yīng)該去修改而不是不能修改,也就是說const不能阻止參數(shù)的修改(原因見上)。

到此這篇關(guān)于C語言詳細(xì)講解const的用法的文章就介紹到這了,更多相關(guān)C語言const內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++的輸入與輸出和格式化輸出

    C++的輸入與輸出和格式化輸出

    這篇文章主要介紹了詳解C++中的輸入與輸出和格式化輸出,是C++入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考,希望能夠給你帶來幫助
    2021-11-11
  • Matlab實(shí)現(xiàn)繪制玫瑰線的示例代碼

    Matlab實(shí)現(xiàn)繪制玫瑰線的示例代碼

    這篇文章主要為大家介紹了如何利用Matlab繪制3好看的玫瑰線,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Matlab有一定幫助,感興趣的小伙伴可以動(dòng)手試一試
    2022-08-08
  • C++智能指針之shared_ptr的具體使用

    C++智能指針之shared_ptr的具體使用

    本文主要介紹了C++智能指針之shared_ptr的具體使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧<BR>
    2022-05-05
  • C語言實(shí)現(xiàn)學(xué)生宿舍管理系統(tǒng)

    C語言實(shí)現(xiàn)學(xué)生宿舍管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)學(xué)生宿舍管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C++ const和指針詳情

    C++ const和指針詳情

    這篇文章主要介紹了C++ const和指針,關(guān)于使用const來修飾指針,有兩種不同的方式。第一種是讓指針指向一個(gè)常量對(duì)象,這樣可以防止使用該指針進(jìn)行修改指向的值。第二種則是將指針本身聲明為常量,可以防止改變指針指向的位置,下面來看看文章的詳細(xì)內(nèi)容
    2021-11-11
  • C語言實(shí)現(xiàn)獲取內(nèi)存信息并輸出的實(shí)例

    C語言實(shí)現(xiàn)獲取內(nèi)存信息并輸出的實(shí)例

    這篇文章主要介紹了C語言實(shí)現(xiàn)獲取內(nèi)存信息并輸出的實(shí)例的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • c語言左移和右移的示例詳解

    c語言左移和右移的示例詳解

    這篇文章主要介紹了c語言左移和右移的示例詳解,移位操作符的兩個(gè)操作數(shù)必須是整型的。整個(gè)移位表達(dá)式的值的類型也是整型的,而且,左移位操作符與右移位操作符的運(yùn)算并不對(duì)稱。
    2020-07-07
  • 詳解c語言中的 strcpy和strncpy字符串函數(shù)使用

    詳解c語言中的 strcpy和strncpy字符串函數(shù)使用

    strcpy 和strcnpy函數(shù)是字符串復(fù)制函數(shù)。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數(shù)使用,感興趣的朋友跟隨小編要求看看吧
    2018-10-10
  • C++泛型編程基本概念詳解

    C++泛型編程基本概念詳解

    這一篇介紹一下 C++ 編程中與面向?qū)ο蟛⒘械牧硪淮蠓种А盒途幊?,這一篇主要介紹函數(shù)模板、類模板和成員模板三大部分,需要的朋友可以參考下
    2021-08-08
  • C++回溯算法中子集問題分析探討

    C++回溯算法中子集問題分析探討

    回溯法是一種選優(yōu)搜索法,按選優(yōu)條件向前搜索,以達(dá)到目標(biāo)。但當(dāng)探索到某一步時(shí),發(fā)現(xiàn)原先選擇并不優(yōu)或達(dá)不到目標(biāo),就退回一步重新選擇,這種走不通就退回再走的技術(shù)為回溯法,而滿足回溯條件的某個(gè)狀態(tài)的點(diǎn)稱為回溯點(diǎn)
    2023-03-03

最新評(píng)論