新聞中心
首先話不多說,直接給您去介紹咯。

創(chuàng)新互聯(lián)專注于網(wǎng)站建設,為客戶提供成都網(wǎng)站設計、成都網(wǎng)站制作、網(wǎng)頁設計開發(fā)服務,多年建網(wǎng)站服務經(jīng)驗,各類網(wǎng)站都可以開發(fā),成都品牌網(wǎng)站建設,公司官網(wǎng),公司展示網(wǎng)站,網(wǎng)站設計,建網(wǎng)站費用,建網(wǎng)站多少錢,價格優(yōu)惠,收費合理。
在C語言中,您可以在類型轉換中,運算符內(nèi)部,函數(shù)聲明中聲明新類型。sizeof
- int a = sizeof(enum E { A, B, C }) + (enum X { D, E, F }) 0;
- enum E e = B;
- int b = e + F;
在C循環(huán)中,“頭”和循環(huán)體是兩個單獨的(嵌套的)作用域
- for (int i = 0; i < 10; ++i)
- { int i = 42; // <-C語言中的OK,聲明其他局部變量
- }
這不同于C ++,后者兩者都形成一個范圍。
可以在C中進行[遞歸]調(diào)用main
在C語言中,可以在聲明中顯式地重復cv限定詞
- const const const const int i = 42;
在C中,您可以在相同的翻譯單元中一次又一次地定義相同的文件作用域對象,只要這些定義仍然是暫定的即可(不要多次包含初始化器)
- int i;
- int i;
- int i, i, i, i;
與流行的看法相反,C不支持不同指針類型之間以及整數(shù)和指針類型之間的隱式轉換
- int *p = 0;
- double *pd = p; //<-在C中不允許
- char *pc = 123;// <-在C中不允許
但是支持隱式的指針往返轉換void *。
將運算符應用于可變修改后的類型時,將sizeof在運行時對其進行評估
- int i = 0;
- sizeof(int [++ i]); //運行時`sizeof`將使`i`遞增
- int a [20];
- sizeof(a [++ i]); //編譯時`sizeof`不會使`i`遞增
typedef用C -declaration實際上可以生成可執(zhí)行代碼,如果聲明為可變類型(一個VLA)。因此,繞過該聲明進入該聲明的范圍是非法的typedef
- goto skip;
- int n = 42;
- typedef int A[n];
- skip:;
即使main應該聲明為返回int,也不需要顯式地return從中進行任何操作int main()。如果控制從末尾流出main,則其行為就像return 0;
運算符sizeof有兩種獨立的語法:一種用于類型,另一種用于表達式。后者沒有()圍繞其論點
- int a;
- sizeof a; // 不需要在`a`附近使用`()`
從C99語句(如if,等)開始for,while創(chuàng)建自己的隱式塊。在C99塊之前,僅由的顯式對創(chuàng)建{}。
標準C從未允許人們在聲明中完全省略decl-specifier-seq 。即使在具有“隱式int”規(guī)則的C89 / 90中,也無法將函數(shù)聲明為foo()。你可以做extern foo()或者const foo(),例如,而不是只foo()。
帶空的函數(shù)聲明()是K&R樣式的聲明。不建議使用K&R樣式的聲明。如果您的函數(shù)沒有參數(shù),則將其聲明為(void),而不是()。
函數(shù)聲明和函數(shù)原型不是一回事。在現(xiàn)代C語言中,需要使用函數(shù)聲明。但是功能原型不是。
即使在函數(shù)參數(shù)列表中,諸如int *array和的聲明int array[]通常是“等效的”,后一種形式仍要求數(shù)組元素類型完整,而前一種則不需要
- struct Incomplete;
- void foo(struct Incomplete *array);
- void bar(struct Incomplete array[]);
在函數(shù)參數(shù)列表中聲明指針時,可以將指針本身聲明為 const
- void foo(int *const array);
在C89 / 90中,使用參數(shù)聲明的“等效”數(shù)組形式時,以前不可能聲明相同類型的常數(shù)。但是,由于C99,可以通過const在[]
- void bar(int array[const]); // 與?int * const array`相同
使用函數(shù)參數(shù)聲明的數(shù)組形式時,數(shù)組的大小通常無關緊要
- void foo(int array[5]); //等同于`int array []`。`5`被忽略。
但是,當size帶有關鍵字時,static它充當編譯器的提示。它說實際的數(shù)組至少會那么大。它可能/將改善編譯器優(yōu)化
- void foo(int array [static 5]);
- //從類型上講,它仍然等效于`int array []`
- //但是編譯器會提示
聲明為的位字段int不一定是帶符號的。這是C語言中的一個上下文,其中plainint不一定與相同signed int。一個int位字段可能被符號或無符號-這個行為應該是實現(xiàn)定義的。因此,始終明確指定您的意圖始終是一個好習慣:將位字段明確聲明為signedor unsigned,而不是簡單聲明int。
do … while是唯一以。結尾的迭代語句形式;。
在C語言中可以對類型為Object的對象進行非定義聲明 void
- extern void v;
但是,由于類型不完整,因此無法為該聲明提供匹配的定義void。
函數(shù)參數(shù)列表中提到的未知結構類型被視為新類型的聲明。但是,此類型的范圍僅限于該函數(shù)聲明。同一功能的下一個聲明將不可見或不知道它。例如,以下聲明序列乍一看“看起來不錯”,但實際上是無效的
- // 此時未聲明“ struct S”類型
- void foo(struct S *p);
- void foo(struct S *p)
- {
- }
struct S第一個聲明提到的類型是原型的局部變量,與第二個聲明完全無關struct S。因此,這些函數(shù)聲明是沖突的。
文章題目:關于C編程語言,幾乎沒有人知道的事
網(wǎng)頁URL:http://www.5511xx.com/article/dphdogc.html


咨詢
建站咨詢
