當前位置

首頁 > 商務英語 > 計算機英語 > c語言中const的用法

c語言中const的用法

推薦人: 來源: 閱讀: 2.24W 次

C語言作爲一門新型高級編程語言,在計算機軟件編程中具有較爲廣泛的應用和實現。下面小編就跟你們詳細介紹下c語言中const的用法,希望對你們有用。

ing-bottom: 52.5%;">c語言中const的用法

  c語言中const的用法如下:

  const的基本解釋

const是一個C語言的關鍵字,它限定一個變量不允許被改變。使用const在一定程度上可以提高程序的健壯性,另外,在觀看別人代碼的時候,清晰理解const所起的作用,對理解對方的程序也有一些幫助。

雖然這聽起來很簡單,但實際上,const的使用也是c語言中一個比較微妙的地方,微妙在何處呢?請看下面幾個問題。

問題:const變量 & 常量

爲什麼我象下面的例子一樣用一個const變量來初始化數組,ANSI C的編譯器會報告一個錯誤呢?

const int n = 5;

int a[n];

答案與分析:

1)、這個問題討論的是“常量”與“只讀變量”的區別。常量肯定是隻讀的,例如5, “abc”,等,肯定是隻讀的,因爲程序中根本沒有地方存放它的值,當然也就不能夠去修改它。而“只讀變量”則是在內存中開闢一個地方來存放它的值,只不過這個值由編譯器限定不允許被修改。C語言關鍵字const就是用來限定一個變量不允許被改變的修飾符(Qualifier)。上述代碼中變量n被修飾爲只讀變量,可惜再怎麼修飾也不是常量。而ANSI C規定數組定義時維度必須是“常量”,“只讀變量”也是不可以的。

2)、注意:在ANSI C中,這種寫法是錯誤的,因爲數組的大小應該是個常量,而const int n,n只是一個變量(常量 != 不可變的變量,但在標準C++中,這樣定義的是一個常量,這種寫法是對的),實際上,根據編譯過程及內存分配來看,這種用法本來就應該是合理的,只是 ANSI C對數組的規定限制了它。

3)、那麼,在ANSI C 語言中用什麼來定義常量呢?答案是enum類型和#define宏,這兩個都可以用來定義常量。

問題:const變量 & const 限定的內容

下面的代碼編譯器會報一個錯誤,請問,哪一個語句是錯誤的呢?

Typedef char * pStr;

char string[4] = "abc";

const char *p1 = string;

const pStr p2 = string;

p1++;

p2++;

答案與分析:

問題出在p2++上。

1)、const使用的基本形式: const char m; 限定m不可變。

2)、替換1式中的m, const char *pm; 限定*pm不可變,當然pm是可變的,因此問題中p1++是對的。

3)、替換1式char, const newType m; 限定m不可變,問題中的charptr就是一種新類型,因此問題中p2不可變,p2++是錯誤的。

問題:const變量 & 字符串常量

請問下面的代碼有什麼問題?

char *p = "i'm hungry!";

p[0]= 'I';

答案與分析:

上面的代碼可能會造成內存的非法寫操作。分析如下, “i'm hungry”實質上是字符串常量,而常量往往被編譯器放在只讀的內存區,不可寫。p初始指向這個只讀的內存區,而p[0] = 'I'則企圖去寫這個地方,編譯器當然不會答應。

問題:const變量 & 字符串常量2

請問char a[3] = "abc" 合法嗎?使用它有什麼隱患?

答案與分析:

在標準C中這是合法的,但是它的生存環境非常狹小;它定義一個大小爲3的數組,初始化爲“abc”。注意,它沒有通常的字符串終止符'