(1)記憶體中儲存區域不同。
全域性和靜態存在靜態區中,區域性儲存在堆疊中。
(2)作用域不同
全域性變數的作用域是整個源程式, 當乙個源程式由多個原始檔組成時,非靜態的全域性變數在各個原始檔中都是有效的。 而靜態全域性變數則限制了其作用域, 即只在定義該變數的原始檔內有效, 在同一源程式的其它原始檔中不能使用它。由於靜態全域性變數的作用域侷限於乙個原始檔內,只能為該原始檔內的函式公用, 因此可以避免在其它原始檔中引起錯誤;區域性變數也稱為內部變數,區域性變數是在函式內作定義說明的,其作用域僅限於函式內, 離開該函式後再使用這種變數是非法的。
(3)其他
static全域性變數與普通的全域性變數有什麼區別:static全域性變數只初使化一次,防止在其他檔案單元中被引用;
static函式與普通函式有什麼區別:static函式在記憶體中只有乙份,普通函式在每個被呼叫中維持乙份拷貝。 -----所以常用的公共函式最好定義為static
程式的區域性變數存在於(堆疊)中,全域性變數存在於(靜態區 )中,動態申請資料存在於( 堆)中。extern全域性變數、static全域性變數和static區域性變數的生存期都是「永久」,區別只是可見域不同,extern全域性變數可見區域是工程,static全域性變數可見區域是檔案,而static區域性變數的可見區域是塊。 從**維護角度來看,對extern變數的修改可能會影響所有**,對static全域性變數的修改可能影響乙個檔案中的**,而對static變數的修改可能影響乙個塊的**;因此在選擇變數型別時,優先順序是static區域性》static全域性》extern全域性。但它們有著共同的缺點:使用了這些型別變數的函式將是不可重入的,不是執行緒安全的。在c/c++標準庫中有很多函式都使用了static區域性變數,目前的實現中都為它們提供了兩套**,單執行緒版本使用static變數而多執行緒版本使用「執行緒全域性變數」,比如rand,strtok等。乙個程序可用記憶體空間為4g,可分在存放靜態資料,**,系統記憶體,堆,棧等。.活動記錄一般存放呼叫引數、返回位址等內容。堆和棧最大的區別在於堆是由低位址向高位址分配記憶體,而棧是由高向低。全域性和靜態資料存放在全域性資料區,其餘的在棧中,用malloc 或 new 分配的記憶體位於堆中。一般來說棧在低位址,堆位於高位址。
#ifdef __cplusplus
extern "c"
#endif
為什麼要加extern "c" :解決編譯器編譯後庫中函式的名字匹配問題,如void foo(int x,int y),c編譯器_foo,c++編譯器_foo_int_int。
詳見:char * const p : 定義乙個指向字元的指標常數,即const指標;
const char* p : 定義乙個指向字元常數的指標;
const char*p或者char const *p(因為沒有const*p運算,因此const修飾的還是前面的char):可以對任意位置(非系統敏感區域)進行「唯讀」 操作。(「唯讀」是相對於char *p來說所限定的內容)
char *const p(const 修飾的是p):只能對「某個固定的位置」 進行讀寫操作,並且在定義p時就必須初始化(因為在後面不能執行「p=..」的操作,因此就不能在後面初始化,因此只能在定義時初始化)。(「某個固定的位 置」是相對於char *p來說所限定的內容)
char const* p : 等同於const char* p
const char* const p:只能對「某個固定的位置」 進行讀操作,指標const,指標內容const。
參考:4.1sizeof
sizeof(...)
是運算子,在標頭檔案中
typedef
為unsigned int
,其值在編譯時即計算好了,引數可以是陣列、指標、型別、物件、函式等。
它的功能是:獲得保證能容納實現所建立的最大物件的位元組大小。
由於在編譯時計算,因此sizeof不能用來返回動態分配的記憶體空間的大小。實際上,用sizeof來返回型別以及靜態分配的物件、結構或陣列所佔的空間,返回值跟物件、結構、陣列所儲存的內容沒有關係。
具體而言,當引數分別如下時,
sizeof
返回的值表示的含義如下:
陣列——
編譯時分配的陣列空間大小;
指標——
儲存該指標所用的空間大小(儲存該指標的位址的長度,是長整型,應該為4);
型別——
該型別所佔的空間大小;
物件——
物件的實際占用空間大小;
函式——
函式的返回型別所佔的空間大小。函式的返回型別不能是
void
。4.2
strlen
strlen(...)
是函式,要在執行時才能計算。引數必須是字元型指標(
char*
)。當陣列名作為引數傳入時,實際上陣列就退化成指標了。
null
。返回的長度大小不包括
null
。4.3區別聯絡
(1)sizeof操作符的結果型別是size_t,它在標頭檔案中typedef為unsigned int型別。該型別保證能容納實現所建立的最大物件的位元組大小。
(2)性質不同:sizeof是運算子,strlen是函式。
(3)引數不同:sizeof可以用型別做引數,strlen只能用char*做引數,且必須是以''\0''結尾的。
sizeof還可以用函式做引數,比如: short f(); printf("%d\n", sizeof(f())); 輸出的結果是sizeof(short),即2。 陣列做sizeof的引數不退化,傳遞給strlen就退化為指標了。
(4)計算階段不同:大部分編譯程式在編譯的時候就把sizeof計算過了 是型別或是變數的長度這就是sizeof(x)可以用來定義陣列維數的原因
char str[20]="0123456789";
int a=strlen(str); //a=10;
int b=sizeof(str); //而b=20;
strlen的結果要在執行的時候才能計算出來,時用來計算字串的長度,不是型別佔記憶體的大小。
(5)格式不同:sizeof後如果是型別必須加括弧,如果是變數名可以不加括弧。這是因為sizeof是個操作符不是個函式。
(6)適用範圍不同:當適用了於乙個結構型別時或變數, sizeof 返回實際的大小, 當適用一靜態地空間陣列, sizeof 歸還全部陣列的尺寸。 sizeof 操作符不能返回動態地被分派了的陣列或外部的陣列的尺寸。
參考:(1)預設繼承許可權。如果不明確指定,來自class的繼承按照private繼承處理,來自struct的繼承按照public繼承處理;
(2)成員的預設訪問許可權。class的成員預設是private許可權,struct預設是public許可權。
除了這兩點,class和struct基本就是乙個東西。語法上沒有任何其它區別。
c 簡答題題庫 C 簡答題集錦
c 簡答題集錦 問題1 什麼是演算法?演算法應包括哪兩部分?答 所謂演算法,是指為解決乙個問題而採取的方法和步驟,或者說是解題步驟的精確描述。演算法應包括設計演算法和執行演算法兩部分。問題2 結構化程式設計的特徵是什麼?答 結構化程式設計方法從程式設計思想上要求自頂向下,逐步求精 從程式的具體結構上...
JAVA面試題 簡答題
1.和 的區別 1 和 都可以用作邏輯與的運算子,表示邏輯與 and 當運算子兩邊表示式結果都為true時,整個運算結果才為true 否則,只要有一邊表示式為false,則運算結果為false。2 具有短路功能,即如果第乙個表示式結果為false,則不會計算第二個表示式,直接返回false 3 可以...
還是幾道簡答題
今天和昨天一樣,又找了幾道簡答題,鞏固一下前一段時間學習的成果,也對一些名詞有了更深入的了解 1.makefile的作用 makefile檔案儲存了編譯器和聯結器的引數選項,還表述了所有原始檔之間的關係。建立程式 make程式 首先讀取makefile檔案,然後再啟用編譯器,彙編器,資源編譯器 和聯...