深入分析C語言存儲類型與用戶空間內(nèi)部分布
1、定義變量的格式
存儲類型 數(shù)據(jù)類型 變量名 = 初始值;
2、6個存儲類型
自動存儲區(qū):auto register
非自動存儲區(qū):const static extern volatile
3、auto存儲類型-自動存儲類型
自動類型:局部變量屬于自動類型,定義局部變量時,加auto或者不加auto都是一樣的,一般省略auto.
非自動類型:全局變量,使用static修飾的全局變量或者局部變量不可以使用auto進(jìn)行修飾。
#include <stdio.h>
int s; // 全局變量,屬于非自動類型,不可以使用auto修飾
// auto int k; // error
static int x; // 使用static修飾的靜態(tài)全局變量,屬于非自動類型,不可以使用auto修飾
// auto static int x; // error
int main(int argc, const char *argv[])
{
/*your code*/
int i; // 自動類型變量,省略auto
auto int j; // 自動類型變量,使用auto修飾
static int m; // 使用static修飾的靜態(tài)局部變量,屬于非自動類型,不可以使用auto修飾
// auto static int n; // error
return 0;
}
4、register存儲類型-寄存器存儲類型
定義寄存器存儲類型的變量,定義的變量分配一個寄存器的空間給變量使用。
盡量不要定義寄存器類型的變量,在CPU中寄存器的數(shù)量有限(空間有限)
寄存器變量不可以進(jìn)行去地址取運算(&),原因是寄存器沒有地址。
5、const存儲類型-常量存儲類型
1.只讀,初始化后不能修改;
2.使代碼更緊湊;
3.編譯器自然保護(hù)不希望改變的參數(shù),防止無意修改代碼
(例:const int * p=&a ,表示*p不能改變a的值
? int const * p=&a ,表示*p不能改變a的值
? int * const p=&a ,表示p指向的地址不能改變
? const int * const p=&a ,表示既不能改變指向的地址,又不能改變指向地址中的值)
6、static-靜態(tài)存儲類型
1.static修飾局部變量:延長生命周期到整個進(jìn)程結(jié)束,
? 只在第一次調(diào)用此函數(shù)時,對靜態(tài)局部變量進(jìn)行初始化,后面在此調(diào)用函數(shù),不在初始化
? 如果定義的靜態(tài)局部變量沒有進(jìn)行初始化,默認(rèn)初始化為0
2.static修飾全局變量:外部文件不可以使用,靜態(tài)全局變量的作用域在本文件內(nèi)。
3.static修飾函數(shù):外部文件不可以使用,靜態(tài)全局變量的作用域在本文件內(nèi)。
7、extern-修飾全局變量
1.externa修飾全局變量,表示這個全局變量在其他文件中定義的
2.externa修飾函數(shù),表示這個函數(shù)是在其他文件中定義的
3.聲明一個變量,extern聲明的變量沒有建立存儲空間。int a;//變量在定義的時候創(chuàng)建存儲空間
8、volatile-易變存儲類型
volatile關(guān)鍵字用來阻止編譯器認(rèn)為的無法“被代碼本身”改變的代碼進(jìn)行優(yōu)化。
如在C語言中,volatile關(guān)鍵字可以用來提醒編譯器它后面所定義的變量隨時有可能改變,
因此編譯后的程序每次需要存儲或讀取這個變量的時候,都會直接從變量地址中讀取數(shù)據(jù)。
如果沒有volatile關(guān)鍵字,則編譯器可能優(yōu)化讀取和存儲,可能暫時使用寄存器中的值,
如果這個變量由別的程序更新了的話,將出現(xiàn)不一致的現(xiàn)象。
在java并發(fā)編程中,volatile的作用
對于可見性,java提供了volatile關(guān)鍵字來保證可見性。
當(dāng)一個共享的變量被volatile修飾時,它會保證修改的值會立即被更新到主存當(dāng)中,當(dāng)其他線程需要讀取時,
它會去內(nèi)存中讀取新值。
9、用戶空間內(nèi)部分布圖


代碼解析:
#include <stdio.h>
int d; // 全局變量未初始化 值為0 .bss
int e=10; //全局變量初始化 .data
char *p = "hello"; //字符指針 p在.data "hello"在.rodata
char arr[] = "world"; //.字符數(shù)組 .data
static int f; //使用static修飾的未初始化的全局變量 值為0 .bss
static int g=20; //使用static修飾的初始化的全局變量 .data
int main(int argc, const char *argv[])
{
int a=10; //局部變量初始化 棧區(qū)
int b; //局部變量未初始化,隨機(jī)值 棧區(qū)
static int c; //使用static修飾的局部變量 未初始化 值為0 .bss
static int d=20; //使用static修飾的局部變量初始化 .data
char *p = "hello"; //字符指針 p:在棧區(qū) “hello”在 .rodata
char arr[] = "world"; //字符數(shù)組 棧
char *q = malloc(10); //q在棧區(qū),指向堆區(qū)的10字節(jié)的?地址
return 0;
}到此這篇關(guān)于深入分析C語言存儲類型與用戶空間內(nèi)部分布的文章就介紹到這了,更多相關(guān)C語言存儲類型內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++ for循環(huán)與nullptr的小知識點分享
這篇文章主要是來和大家介紹一些C++中的小知識點,本文分享的是for循環(huán)與nullptr,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下2023-05-05
C/C++ 中堆和棧及靜態(tài)數(shù)據(jù)區(qū)詳解
這篇文章主要介紹了C/C++ 中堆和棧及靜態(tài)數(shù)據(jù)區(qū)詳解的相關(guān)資料,需要的朋友可以參考下2017-04-04
MFC擴(kuò)展DLL中導(dǎo)出類和對話框的實現(xiàn)方法
這篇文章主要介紹了MFC擴(kuò)展DLL中導(dǎo)出類和對話框的實現(xiàn)方法,詳細(xì)講述了實現(xiàn)擴(kuò)展DLL中導(dǎo)出類和對話框的具體步驟與方法,具有不錯的實用價值,需要的朋友可以參考下2014-10-10

