不卡AV在线|网页在线观看无码高清|亚洲国产亚洲国产|国产伦精品一区二区三区免费视频

學(xué)習(xí)啦 > 學(xué)習(xí)英語 > 專業(yè)英語 > 計(jì)算機(jī)英語 > c語言中const的用法

c語言中const的用法

時(shí)間: 長(zhǎng)思709 分享

c語言中const的用法

  C語言作為一門新型高級(jí)編程語言,在計(jì)算機(jī)軟件編程中具有較為廣泛的應(yīng)用和實(shí)現(xiàn)。下面小編就跟你們?cè)敿?xì)介紹下c語言中const的用法,希望對(duì)你們有用。

  c語言中const的用法如下:

  const的基本解釋

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

  雖然這聽起來很簡(jiǎn)單,但實(shí)際上,const的使用也是c語言中一個(gè)比較微妙的地方,微妙在何處呢?請(qǐng)看下面幾個(gè)問題。

  問題:const變量 & 常量

  為什么我象下面的例子一樣用一個(gè)const變量來初始化數(shù)組,ANSI C的編譯器會(huì)報(bào)告一個(gè)錯(cuò)誤呢?

  const int n = 5;

  int a[n];

  答案與分析:

  1)、這個(gè)問題討論的是“常量”與“只讀變量”的區(qū)別。常量肯定是只讀的,例如5, “abc”,等,肯定是只讀的,因?yàn)槌绦蛑懈緵]有地方存放它的值,當(dāng)然也就不能夠去修改它。而“只讀變量”則是在內(nèi)存中開辟一個(gè)地方來存放它的值,只不過這個(gè)值由編譯器限定不允許被修改。C語言關(guān)鍵字const就是用來限定一個(gè)變量不允許被改變的修飾符(Qualifier)。上述代碼中變量n被修飾為只讀變量,可惜再怎么修飾也不是常量。而ANSI C規(guī)定數(shù)組定義時(shí)維度必須是“常量”,“只讀變量”也是不可以的。

  2)、注意:在ANSI C中,這種寫法是錯(cuò)誤的,因?yàn)閿?shù)組的大小應(yīng)該是個(gè)常量,而const int n,n只是一個(gè)變量(常量 != 不可變的變量,但在標(biāo)準(zhǔn)C++中,這樣定義的是一個(gè)常量,這種寫法是對(duì)的),實(shí)際上,根據(jù)編譯過程及內(nèi)存分配來看,這種用法本來就應(yīng)該是合理的,只是 ANSI C對(duì)數(shù)組的規(guī)定限制了它。

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

  問題:const變量 & const 限定的內(nèi)容

  下面的代碼編譯器會(huì)報(bào)一個(gè)錯(cuò)誤,請(qǐng)問,哪一個(gè)語句是錯(cuò)誤的呢?

  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不可變,當(dāng)然pm是可變的,因此問題中p1++是對(duì)的。

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

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

  請(qǐng)問下面的代碼有什么問題?

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

  p[0]= 'I';

  答案與分析:

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

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

  請(qǐng)問char a[3] = "abc" 合法嗎?使用它有什么隱患?

  答案與分析:

  在標(biāo)準(zhǔn)C中這是合法的,但是它的生存環(huán)境非常狹?。凰x一個(gè)大小為3的數(shù)組,初始化為“abc”。注意,它沒有通常的字符串終止符'

c語言中const的用法

時(shí)間: 長(zhǎng)思709 分享

c語言中const的用法

  C語言作為一門新型高級(jí)編程語言,在計(jì)算機(jī)軟件編程中具有較為廣泛的應(yīng)用和實(shí)現(xiàn)。下面小編就跟你們?cè)敿?xì)介紹下c語言中const的用法,希望對(duì)你們有用。

  c語言中const的用法如下:

  const的基本解釋

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

  雖然這聽起來很簡(jiǎn)單,但實(shí)際上,const的使用也是c語言中一個(gè)比較微妙的地方,微妙在何處呢?請(qǐng)看下面幾個(gè)問題。

  問題:const變量 & 常量

  為什么我象下面的例子一樣用一個(gè)const變量來初始化數(shù)組,ANSI C的編譯器會(huì)報(bào)告一個(gè)錯(cuò)誤呢?

  const int n = 5;

  int a[n];

  答案與分析:

  1)、這個(gè)問題討論的是“常量”與“只讀變量”的區(qū)別。常量肯定是只讀的,例如5, “abc”,等,肯定是只讀的,因?yàn)槌绦蛑懈緵]有地方存放它的值,當(dāng)然也就不能夠去修改它。而“只讀變量”則是在內(nèi)存中開辟一個(gè)地方來存放它的值,只不過這個(gè)值由編譯器限定不允許被修改。C語言關(guān)鍵字const就是用來限定一個(gè)變量不允許被改變的修飾符(Qualifier)。上述代碼中變量n被修飾為只讀變量,可惜再怎么修飾也不是常量。而ANSI C規(guī)定數(shù)組定義時(shí)維度必須是“常量”,“只讀變量”也是不可以的。

  2)、注意:在ANSI C中,這種寫法是錯(cuò)誤的,因?yàn)閿?shù)組的大小應(yīng)該是個(gè)常量,而const int n,n只是一個(gè)變量(常量 != 不可變的變量,但在標(biāo)準(zhǔn)C++中,這樣定義的是一個(gè)常量,這種寫法是對(duì)的),實(shí)際上,根據(jù)編譯過程及內(nèi)存分配來看,這種用法本來就應(yīng)該是合理的,只是 ANSI C對(duì)數(shù)組的規(guī)定限制了它。

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

  問題:const變量 & const 限定的內(nèi)容

  下面的代碼編譯器會(huì)報(bào)一個(gè)錯(cuò)誤,請(qǐng)問,哪一個(gè)語句是錯(cuò)誤的呢?

  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不可變,當(dāng)然pm是可變的,因此問題中p1++是對(duì)的。

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

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

  請(qǐng)問下面的代碼有什么問題?

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

  p[0]= 'I';

  答案與分析:

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

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

  請(qǐng)問char a[3] = "abc" 合法嗎?使用它有什么隱患?

  答案與分析:

  在標(biāo)準(zhǔn)C中這是合法的,但是它的生存環(huán)境非常狹??;它定義一個(gè)大小為3的數(shù)組,初始化為“abc”。注意,它沒有通常的字符串終止符'\0',因此這個(gè)數(shù)組只是看起來像C語言中的字符串,實(shí)質(zhì)上卻不是,因此所有對(duì)字符串進(jìn)行處理的函數(shù),比如strcpy、printf等,都不能夠被使用在這個(gè)假字符串上。

  問題5:const & 指針

  類型聲明中const用來修飾一個(gè)常量,有如下兩種寫法,那么,請(qǐng)問,下面分別用const限定不可變的內(nèi)容是什么?

  1)、const在前面

  const int nValue; //nValue是const

  const char *pContent; //*pContent是const, pContent可變

  const (char *) pContent;//pContent是const,*pContent可變

  char* const pContent; //pContent是const,*pContent可變

  const char* const pContent; //pContent和*pContent都是const

  2)、const在后面,與上面的聲明對(duì)等

  int const nValue; // nValue是const

  char const * pContent;// *pContent是const, pContent可變

  (char *) const pContent;//pContent是const,*pContent可變

  char* const pContent;// pContent是const,*pContent可變

  char const* const pContent;// pContent和*pContent都是const

  答案與分析:

  const和指針一起使用是C語言中一個(gè)很常見的困惑之處,在實(shí)際開發(fā)中,特別是在看別人代碼的時(shí)候,常常會(huì)因?yàn)檫@樣而不好判斷作者的意圖,下面講一下我的判斷原則:

  沿著*號(hào)劃一條線,如果const位于*的左側(cè),則const就是用來修飾指針?biāo)赶虻淖兞?,即指針指向?yàn)槌A?;如果const位于*的右側(cè),const就是修飾指針本身,即指針本身是常量。你可以根據(jù)這個(gè)規(guī)則來看上面聲明的實(shí)際意義,相信定會(huì)一目了然。

  另外,需要注意:對(duì)于const (char *) ; 因?yàn)閏har *是一個(gè)整體,相當(dāng)于一個(gè)類型(如 char),因此,這是限定指針是const。

  另=======

  const用于函數(shù)時(shí)出現(xiàn)三個(gè)位置:

  例如:

  const returnVal function (const list_array)const;

  第一個(gè)const意思是:返回值是常量

  第二個(gè)const意思是:函數(shù)過程中不能修改list_array的值

  第三個(gè)const意思是:函數(shù)過程不能隱式的修改function參數(shù)的值

 ?。剑剑?/p>

  zzhttp://publishblog.blogchina.com/blog/tb.b?diaryID=3217823

  const char*, char const*, char*const的區(qū)別問題幾乎是C++面試中每次都會(huì)有的題目。

  Bjarne在他的The C++ Programming Language里面給出過一個(gè)助記的方法:把一個(gè)聲明從右向左讀。

  char * const cp; ( * 讀成 pointer to ) :cp is a const pointer to char

  const char * p; :p is a pointer to const char;

  char const * p;

  同上因?yàn)镃++里面沒有const*的運(yùn)算符,所以const只能屬于前面的類型。

  另:下面定義的一個(gè)指向字符串的常量指針:

  char * const prt1 = stringprt1;

  其中,ptr1是一個(gè)常量指針。因此,下面賦值是非法的。 ptr1 = stringprt2;

  而下面的賦值是合法的: *ptr1 = "m";

  因?yàn)橹羔榩tr1所指向的變量是可以更新的,不可更新的是常量指針ptr1所指的方向(別的字符串)。

  下面定義了一個(gè)指向字符串常量的指針:

  const * ptr2 = stringprt1;

  其中,ptr2是一個(gè)指向字符串常量的指針。ptr2所指向的字符串不能更新的,而ptr2是可以更新的。因此,

  *ptr2 = "x"; 是非法的,而: ptr2 = stringptr2; 是合法的。

  所以,在使用const修飾指針時(shí),應(yīng)該注意const的位置。定義一個(gè)指向字符串的指針常量和定義一個(gè)指向字符串常量的指針時(shí),const修飾符的位置不同,前者const放在*和指針名之間,后者const放在類型說明符前。

',因此這個(gè)數(shù)組只是看起來像C語言中的字符串,實(shí)質(zhì)上卻不是,因此所有對(duì)字符串進(jìn)行處理的函數(shù),比如strcpy、printf等,都不能夠被使用在這個(gè)假字符串上。

  問題5:const & 指針

  類型聲明中const用來修飾一個(gè)常量,有如下兩種寫法,那么,請(qǐng)問,下面分別用const限定不可變的內(nèi)容是什么?

  1)、const在前面

  const int nValue; //nValue是const

  const char *pContent; //*pContent是const, pContent可變

  const (char *) pContent;//pContent是const,*pContent可變

  char* const pContent; //pContent是const,*pContent可變

  const char* const pContent; //pContent和*pContent都是const

  2)、const在后面,與上面的聲明對(duì)等

  int const nValue; // nValue是const

  char const * pContent;// *pContent是const, pContent可變

  (char *) const pContent;//pContent是const,*pContent可變

  char* const pContent;// pContent是const,*pContent可變

  char const* const pContent;// pContent和*pContent都是const

  答案與分析:

  const和指針一起使用是C語言中一個(gè)很常見的困惑之處,在實(shí)際開發(fā)中,特別是在看別人代碼的時(shí)候,常常會(huì)因?yàn)檫@樣而不好判斷作者的意圖,下面講一下我的判斷原則:

  沿著*號(hào)劃一條線,如果const位于*的左側(cè),則const就是用來修飾指針?biāo)赶虻淖兞?,即指針指向?yàn)槌A?;如果const位于*的右側(cè),const就是修飾指針本身,即指針本身是常量。你可以根據(jù)這個(gè)規(guī)則來看上面聲明的實(shí)際意義,相信定會(huì)一目了然。

  另外,需要注意:對(duì)于const (char *) ; 因?yàn)閏har *是一個(gè)整體,相當(dāng)于一個(gè)類型(如 char),因此,這是限定指針是const。

  另=======

  const用于函數(shù)時(shí)出現(xiàn)三個(gè)位置:

  例如:

  const returnVal function (const list_array)const;

  第一個(gè)const意思是:返回值是常量

  第二個(gè)const意思是:函數(shù)過程中不能修改list_array的值

  第三個(gè)const意思是:函數(shù)過程不能隱式的修改function參數(shù)的值

  ===

  zzhttp://publishblog.blogchina.com/blog/tb.b?diaryID=3217823

  const char*, char const*, char*const的區(qū)別問題幾乎是C++面試中每次都會(huì)有的題目。

  Bjarne在他的The C++ Programming Language里面給出過一個(gè)助記的方法:把一個(gè)聲明從右向左讀。

  char * const cp; ( * 讀成 pointer to ) :cp is a const pointer to char

  const char * p; :p is a pointer to const char;

  char const * p;

  同上因?yàn)镃++里面沒有const*的運(yùn)算符,所以const只能屬于前面的類型。

  另:下面定義的一個(gè)指向字符串的常量指針:

  char * const prt1 = stringprt1;

  其中,ptr1是一個(gè)常量指針。因此,下面賦值是非法的。 ptr1 = stringprt2;

  而下面的賦值是合法的: *ptr1 = "m";

  因?yàn)橹羔榩tr1所指向的變量是可以更新的,不可更新的是常量指針ptr1所指的方向(別的字符串)。

  下面定義了一個(gè)指向字符串常量的指針:

  const * ptr2 = stringprt1;

  其中,ptr2是一個(gè)指向字符串常量的指針。ptr2所指向的字符串不能更新的,而ptr2是可以更新的。因此,

  *ptr2 = "x"; 是非法的,而: ptr2 = stringptr2; 是合法的。

  所以,在使用const修飾指針時(shí),應(yīng)該注意const的位置。定義一個(gè)指向字符串的指針常量和定義一個(gè)指向字符串常量的指針時(shí),const修飾符的位置不同,前者const放在*和指針名之間,后者const放在類型說明符前。

522675