1、數(shù)據(jù)類型本質(zhì)分析
1.1 數(shù)據(jù)類型的概念
●“類型”是對數(shù)據(jù)的抽象●類型相同的數(shù)據(jù)有相同的表示形式、存儲格式以及相關(guān)的操作●程序中使用的所有數(shù)據(jù)都必定屬于某一種數(shù)據(jù)類型1.2 數(shù)據(jù)類型的本質(zhì)
●數(shù)據(jù)類型可理解為創(chuàng)建變量的模具:是固定內(nèi)存大小的別名。●數(shù)據(jù)類型的作用:編譯器預算對象(變量)分配的內(nèi)存空間大小。●注意:數(shù)據(jù)類型只是模具,編譯器并沒有分酤空間,只有根據(jù)類型(模具)●創(chuàng)建變量(實物),編譯器才會分配空間。2、變量的本質(zhì)分析
2.1 變量的概念
概念:既能讀又能寫的內(nèi)存對象,稱為變量;若一旦初始化后不能修改的對象則稱為常量。變量定義形式:類型標識符,標識符,…,標識符;2.2 變量的本質(zhì)
●程序通過變量來申請和命名內(nèi)存空間int a = 0●通過變量名訪問內(nèi)存空間。3、程序的內(nèi)存四區(qū)模型
流程說明:●操作系統(tǒng)把物理硬盤代碼load到內(nèi)存●操作系統(tǒng)把c代碼分成四個區(qū)棧區(qū)( stack):由編譯器自動分配釋放,存放函數(shù)的參數(shù)值,局部變量的值等 |
堆區(qū)(heap):一般由程序員分配釋放(動態(tài)內(nèi)存申請與釋放),若程序員不釋放程序結(jié)束時可能由操作系統(tǒng)回收 |
全局區(qū)(靜態(tài)區(qū))( statIc):全局變量和靜態(tài)變量的存儲是放在一塊的,初始化的全局變量和靜態(tài)變量在一塊區(qū)域,未初始化的全局變量和未初始化的靜態(tài)變量在相鄰的另一塊區(qū)域,該區(qū)域在程序結(jié)束后由操作系統(tǒng)釋放 |
常量區(qū):字符串常量和其他常量的存儲位置,程序結(jié)束后由操作系統(tǒng)釋放。 |
程序代碼區(qū):存放函數(shù)體的二進制代碼。 |
4、函數(shù)調(diào)用模型
5、函數(shù)調(diào)用變量傳遞分析
(1)
(2)
(3)
(4)
(5)
6、棧的生長方向和內(nèi)存存放方向
相關(guān)代碼:02_數(shù)據(jù)類型本質(zhì).c
#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
#include
int main()
{
int a;//告訴編譯器,分配4個字節(jié)
int b[10];//告訴編譯器,分配4*10個字節(jié)
/*
類型本質(zhì):固定內(nèi)存塊大小別名
可以通過sizeof()測試
*/
printf("sizeof(a)=%d,sizeof(b)=%d
", sizeof(a), sizeof(b));
//打印地址
//數(shù)組名稱,數(shù)組首元素地址,數(shù)組首地址
printf("b:%d,&b:%d
",b,&b);//地址相同
//b,&b數(shù)組類型不同
//b,數(shù)組首地址元素 一個元素4字節(jié),+1 地址+4
//&b,整個數(shù)組首地址 一個數(shù)組4*10=40字節(jié), +1 地址+40
printf("b+1:%d,&b+1:%d
", b + 1, &b + 1);//不同
//指針類型長度,32位機器32位系統(tǒng)下長度是 4字節(jié)
// 64 64 8
char********* p = NULL;
int* q = NULL;
printf("%d,%d
", sizeof(p), sizeof(q));//4 , 4
return 0;
}
03_給類型起別名.c
#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
#include
typedef unsigned int u32;
//typedef 和結(jié)構(gòu)體結(jié)合使用
struct Mystruct
{
int a;
int b;
};
typedef struct Mystruct2
{
int a;
int b;
}TMP;
/*
void 無類型
1.函數(shù)參數(shù)為空,定義函數(shù)時用void修飾 int fun(void)
2.函數(shù)沒有返回值:使用void void fun (void)
3.不能定義void類型的普通變量:void a;//err 無法確定是什么類型
4.可以定義 void* 變量 void* p;//ok 32位系統(tǒng)下永遠是4字節(jié)
5.數(shù)據(jù)類型本質(zhì):固定內(nèi)存塊大小別名
6.void *p萬能指針,函數(shù)返回值,函數(shù)參數(shù)
*/
int main()
{
u32 t;//unsigned int
//定義結(jié)構(gòu)體變量,一定要加上struct 關(guān)鍵字
struct Mystruct m1;
//Mystruct m2;//err
TMP m3;//typedef配合結(jié)構(gòu)體使用
struct Mystruct2 m4;
printf("
");
return 0;
}
04_變量的賦值.c
#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
#include
int main()
{
//變量本質(zhì):一段連續(xù)內(nèi)存空間別名
//變量相當于門牌號,內(nèi)存相當于房間
int a;
int* p;
//直接賦值
a = 10;
printf("a=%d
", a);
//間接賦值
printf("&a:%d
", &a);
p = &a;
printf("p=%d
", p);
*p = 22;
printf("*p=%d,a=%d
", *p, a);
return 0;
}
05_全局區(qū)分析.c
#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
#include
int main()
{
//變量本質(zhì):一段連續(xù)內(nèi)存空間別名
//變量相當于門牌號,內(nèi)存相當于房間
int a;
int* p;
//直接賦值
a = 10;
printf("a=%d
", a);
//間接賦值
printf("&a:%d
", &a);
p = &a;
printf("p=%d
", p);
*p = 22;
printf("*p=%d,a=%d
", *p, a);
return 0;
}
06_堆棧區(qū)分析.c
#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
#include
char* get_str()
{
char str[] = "abcdef";//內(nèi)容分配在棧區(qū),函數(shù)運行完畢后內(nèi)存釋放
printf("%s
", str);
return str;
}
char* get_str2()
{
char* temp = (char*)malloc(100);
if (temp == NULL)
{
return NULL;
}
strcpy(temp, "abcdefg");
return temp;
}
int main()
{
char buf[128] = { 0 };
//strcpy(buf,get_str());
//printf("buf = %s
", buf);//亂碼,不確定內(nèi)容
char* p = NULL;
p = get_str2();
if (p != NULL)
{
printf("p=%s
", p);
free(p);
p = NULL;
}
return 0;
}
07_靜態(tài)局部變量.c
#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
#include
int* getA()
{
static int a = 10;//在靜態(tài)區(qū),靜態(tài)區(qū)在全局區(qū)
return &a;
}
int main()
{
int* p = getA();
*p = 5;
printf("%d
",);
return 0;
}
08_棧的生長方向.c
#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
#include
int* getA()
{
static int a = 10;//在靜態(tài)區(qū),靜態(tài)區(qū)在全局區(qū)
return &a;
}
int main()
{
int* p = getA();
*p = 5;
printf("%d
",);
return 0;
}
審核編輯:郭婷
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
-
C語言
+關(guān)注
關(guān)注
180文章
7598瀏覽量
136191 -
編譯器
+關(guān)注
關(guān)注
1文章
1618瀏覽量
49051
原文標題:C語言中內(nèi)存四區(qū)的本質(zhì)分析
文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
C語言中的socket編程基礎(chǔ)
Socket編程簡介 Socket是一種通信機制,允許程序之間進行通信。在C語言中,socket編程是網(wǎng)絡編程的基礎(chǔ)。通過使用socket,程序可以發(fā)送和接收數(shù)據(jù),實現(xiàn)不同計算機之間的通信
數(shù)字信號與模擬信號的本質(zhì)區(qū)別是什么
數(shù)字信號與模擬信號是信息傳輸和處理領(lǐng)域的兩種基本信號類型。它們在許多方面存在本質(zhì)區(qū)別,包括信號表示、信號處理、抗干擾能力、傳輸效率等。本文將詳細探討這兩種信號類型的本質(zhì)區(qū)別。 一、信號表示 數(shù)字信號
FPGA與ARM的本質(zhì)區(qū)別
FPGA(Field-Programmable Gate Array)與ARM在多個方面存在本質(zhì)區(qū)別。
首先,從它們的定義和結(jié)構(gòu)上來看,F(xiàn)PGA是一種現(xiàn)場可編程門陣列,屬于可編程器件的一種。它的內(nèi)部
發(fā)表于 04-28 09:00
FPGA與ARM的本質(zhì)區(qū)別是什么?
FPGA(Field-Programmable Gate Array)與ARM在多個方面存在本質(zhì)區(qū)別。
首先,從它們的定義和結(jié)構(gòu)上來看,F(xiàn)PGA是一種現(xiàn)場可編程門陣列,屬于可編程器件的一種。它的內(nèi)部
發(fā)表于 04-28 08:56
C語言內(nèi)存泄漏問題原理
內(nèi)存泄漏問題只有在使用堆內(nèi)存的時候才會出現(xiàn),棧內(nèi)存不存在內(nèi)存泄漏問題,因為棧內(nèi)存會自動分配和釋放。C
發(fā)表于 03-19 11:38
?482次閱讀
C語言中的動態(tài)內(nèi)存管理講解
本章將講解 C 中的動態(tài)內(nèi)存管理。C 語言為內(nèi)存的分配和管理提供了幾個函數(shù)。這些函數(shù)可以在 頭文件中找到。
線程是什么的基本單位 進程與線程的本質(zhì)區(qū)別
的代碼、數(shù)據(jù)以及用于執(zhí)行這些代碼的上下文信息。一個進程可以由一個或多個線程組成,從而并發(fā)執(zhí)行多個任務。 本質(zhì)區(qū)別: 資源擁有方式:進程是資源分配的基本單位,每個進程擁有獨立的內(nèi)存空間、
什么是模擬信號,什么是數(shù)字信號,本質(zhì)區(qū)別是什么?
模擬信號和數(shù)字信號的定義、特點和本質(zhì)區(qū)別。 首先,我們來看一下模擬信號。模擬信號是以連續(xù)變化的模式表示的信號,其值和時間之間呈現(xiàn)出一個連續(xù)的關(guān)系。模擬信號可以通過物理量的連續(xù)變化來表示,例如音頻信號、視頻信號
如何解決C語言中的“訪問權(quán)限沖突”異常?C語言引發(fā)異常原因分析
如何解決C語言中的“訪問權(quán)限沖突”異常?C語言引發(fā)異常原因分析? 在C
c語言中邏輯真等價于什么
語言中,條件表達式的結(jié)果只能是真(非零)或假(零)。如果條件滿足,即條件結(jié)果為真,則可以執(zhí)行相應的代碼塊或完成特定的操作。相反,如果條件不滿足,則執(zhí)行其他代碼塊或采取其他操作。 在C
c語言中decimal的含義
C語言中的“decimal”是一種數(shù)據(jù)類型,用于表示十進制數(shù)字。在C語言中,常用的數(shù)據(jù)類型有整數(shù)類型(int)、浮點類型(float和double)、字符類型(char)等,而deci
c語言a++和++a的區(qū)別舉例
使用"++"運算符。相應地,"--"運算符也有類似的行為。 在C語言中,"++"運算符的作用是將變量的值增加1,而"--"運算符的作用是將變量的值減少1。這兩個運算符可以用于任何可以修改的整數(shù)類型變量,如int、char等。 那么,a++和++a有什么
評論