筆試題 Multicore簡答題(上)

2022-03-23 19:22:11 字數 3440 閱讀 4376

(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 pconst 修飾的是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檔案,然後再啟用編譯器,彙編器,資源編譯器 和聯...