C 的儲存類

2021-08-28 16:21:12 字數 3064 閱讀 9976

儲存類定義 c++ 程式中變數/函式的範圍(可見性)和生命週期。這些說明符放置在它們所修飾的型別之前。下面列出 c++ 程式中可用的儲存類:

從 c++ 11 開始,auto 關鍵字不再是 c++ 儲存類說明符,且 register 關鍵字被棄用。

自 c++ 11 以來,auto關鍵字用於兩種情況:宣告變數時根據初始化表示式自動推斷該變數的型別、宣告函式時函式返回值的佔位符。

c++98標準中auto關鍵字用於自動變數的宣告,但由於使用極少且多餘,在c++11中已刪除這一用法。

根據初始化表示式自動推斷被宣告的變數的型別,如:

auto f=3.14; //double

auto s("hello"); //const char*

auto z = new auto(9); // int*

auto x1 = 5, x2 = 5.0, x3='r';//錯誤,必須是初始化為同一型別

register儲存類用於定義儲存在暫存器中而不是 ram 中的區域性變數。這意味著變數的最大尺寸等於暫存器的大小(通常是乙個詞),且不能對它應用一元的 '&' 運算子(因為它沒有記憶體位置)。

暫存器只用於需要快速訪問的變數,比如計數器。還應注意的是,定義 'register' 並不意味著變數將被儲存在暫存器中,它意味著變數可能儲存在暫存器中,這取決於硬體和實現的限制。

static儲存類指示編譯器在程式的生命週期內保持區域性變數的存在,而不需要在每次它進入和離開作用域時進行建立和銷毀。因此,使用 static 修飾區域性變數可以在函式呼叫之間保持區域性變數的值。

static 修飾符也可以應用於全域性變數。當 static 修飾全域性變數時,會使變數的作用域限制在宣告它的檔案內。

在 c++ 中,當 static 用在類資料成員上時,會導致僅有乙個該成員的副本被類的所有物件共享。

#include // 函式宣告

void func(void);

static int count = 10; /* 全域性變數 */

int main()

while(count--)

func();

return 0;

// 函式定義

void func( void )

static int i = 5; // 區域性靜態變數

i++;

std::cout << "變數 i 為 " << i ;

std::cout << " , 變數 count 為 " << count << std::endl;

當上面的**被編譯和執行時,它會產生下列結果:

變數 i 為 6 , 變數 count 為 9

變數 i 為 7 , 變數 count 為 8

變數 i 為 8 , 變數 count 為 7

變數 i 為 9 , 變數 count 為 6

變數 i 為 10 , 變數 count 為 5

變數 i 為 11 , 變數 count 為 4

變數 i 為 12 , 變數 count 為 3

變數 i 為 13 , 變數 count 為 2

變數 i 為 14 , 變數 count 為 1

變數 i 為 15 , 變數 count 為 0

extern儲存類用於提供乙個全域性變數的引用,全域性變數對所有的程式檔案都是可見的。當您使用 'extern' 時,對於無法初始化的變數,會把變數名指向乙個之前定義過的儲存位置。

當您有多個檔案且定義了乙個可以在其他檔案中使用的全域性變數或函式時,可以在其他檔案中使用 extern 來得到已定義的變數或函式的引用。可以這麼理解,extern 是用來在另乙個檔案中宣告乙個全域性變數或函式。

extern 修飾符通常用於當有兩個或多個檔案共享相同的全域性變數或函式的時候,如下所示:

第乙個檔案:main.cpp

#include

int count ;

extern void write_extern();

int main()

count = 5;

write_extern();

第二個檔案:support.cpp

#include

extern int count;

void write_extern(void)

std::cout << "count is " << count << std::endl;

在這裡,第二個檔案中的 extern 關鍵字用於宣告已經在第乙個檔案 main.cpp 中定義的 count。現在 ,編譯這兩個檔案,如下所示:

$ g++ main.cpp support.cpp -o write
這會產生write可執行程式,嘗試執行write,它會產生下列結果:

$ ./write

count is 5

mutable說明符僅適用於類的物件,這將在本教程的最後進行講解。它允許物件的成員替代常量。也就是說,mutable 成員可以通過 const 成員函式修改。

使用 thread_local 說明符宣告的變數僅可在它在其上建立的執行緒上訪問。 變數在建立執行緒時建立,並在銷毀執行緒時銷毀。 每個執行緒都有其自己的變數副本。

thread_local 說明符可以與 static 或 extern 合併。

可以將 thread_local 僅應用於資料宣告和定義,thread_local 不能用於函式宣告或定義。

以下演示了可以被宣告為 thread_local 的變數:

thread_local int x; // 命名空間下的全域性變數 、

class x

static thread_local std::string s; // 類的static成員變數

static thread_local std::string x::s; // x::s 是需要定義的

void foo()

thread_local std::vectorv; // 本地變數

C 類的儲存結構

c 類的儲存 部分可用與c 的結構體 c 中最重要的就是類,那麼給你乙個類的物件,你知道它在記憶體中如何儲存的嗎?它佔 記憶體中多少個位元組?首先確定類的構成 1,資料成員 可以是內建型別,類型別。2,函式成員 虛函式,非虛函式 1 資料成員 內建型別對齊原則 內建型別就是常用的 char,shor...

C 類的儲存空間

1 空類的記憶體佔用量為1,這是因為c 要保證被乙個類的物件都有乙個特定的位址 因而賦予給他乙個位址作為標識 當有了成員變數了就不需要了。2 非虛函式不佔類空間.在編譯時是靜態繫結,類呼叫時就象呼叫庫函式一樣,所以類空 間中沒有為普通成員函式分配空間。3 虛函式佔4位元組空間,函式和純虛函式是動態繫...

C 中的儲存類

auto f 3.14 double auto s hello const char auto z new auto 9 int auto x1 5,x2 5.0,x3 r 錯誤,必須是同一型別 include iostream using namespace std static儲存類例項 sta...