深入淺出理解C語言初識(shí)結(jié)構(gòu)體
1.定義和使用結(jié)構(gòu)體變量
結(jié)構(gòu)體的基礎(chǔ)知識(shí)
結(jié)構(gòu)是一些值的集合,這些值稱為成員變量。結(jié)構(gòu)的每個(gè)成員可以是不同類型的變量。
自己建立結(jié)構(gòu)體類型
結(jié)構(gòu)的成員可以是標(biāo)量、數(shù)組、指針,甚至是其他結(jié)構(gòu)體。
struct 結(jié)構(gòu)體名
{成員表列}:↓
注意:結(jié)構(gòu)體類型的名字由一個(gè)關(guān)鍵字 struct 和結(jié)構(gòu)體名組合而成的(例如 struct Student)結(jié)構(gòu)體 名是由用戶指定的,又稱 "結(jié)構(gòu)體標(biāo)記"(structure tag),以區(qū)別于其他結(jié)構(gòu)體類型。上面的結(jié)構(gòu)體聲明中Student 就是結(jié)構(gòu)體名(結(jié)構(gòu)體標(biāo)記)
類型名 成員名:
"成員表列"也稱為"域表",每一個(gè)成員是結(jié)構(gòu)體中的一個(gè)域 。成員名命名規(guī)則與變量名相同
聲明結(jié)構(gòu)體的形式
結(jié)構(gòu)體的初始化
代碼詳解:
struct point { int x; int y; }; p1; //聲明類型的同時(shí)定義變量p1 struct point p2; //定義結(jié)構(gòu)體變量p2 struct stu { char name[20]; //名字 int age; //年齡 }; struct stu s = { "lisi",25 };//初始化 struct Node { int data; struct point p; struct Node* next; }; n = { 10,{4,5},NULL };//結(jié)構(gòu)體的嵌套初始化 struct Node n2 = { 20,{5,6},NULL };//結(jié)構(gòu)體嵌套初始化
2. 結(jié)構(gòu)體成員的訪問
結(jié)構(gòu)體變量訪問成員 結(jié)構(gòu)變量的成員是通過點(diǎn)操作符 訪問的。點(diǎn)操作符接受兩個(gè)操作數(shù)。 例如:
我們可以看到 s 里面有成員 name 和age
那我們?nèi)绾卧L問呢?
struct S s; strcpy(s.name, "zhangsan");//使用.訪問name成員 s.age = 20;//使用.訪問age成員
結(jié)構(gòu)體指針訪問指向變量的成員
有時(shí)候我們得到的不是一個(gè)結(jié)構(gòu)體變量,而是指向一個(gè)結(jié)構(gòu)體的指針。
那該如何訪問成員。
如下:
3.結(jié)構(gòu)體傳參
話不多說直接上代碼!
struct p { int data[900]; int n; }; struct p s = { {4,3,2,1},900 }; //結(jié)構(gòu)體傳參 void point1(struct p s) { printf("%d %d\n", s.data,s.n); } //結(jié)構(gòu)體地址傳參 void point2(struct p* s1) { printf("%d %d\n", s1->data, s1->n); } int main() { point1(s);//傳結(jié)構(gòu)體 point2(&s);//傳地址 return 0; }
對(duì)于上面的兩種函數(shù) point 1和 point2 哪種函數(shù)好一些呢?
首選 point2 函數(shù)
原因:
函數(shù)傳參的時(shí)候,參數(shù)是需要壓棧的。
如果傳遞一個(gè)結(jié)構(gòu)體對(duì)象的時(shí)候,結(jié)構(gòu)體過大,參數(shù)壓棧的的系統(tǒng)開銷比較大,所以會(huì)導(dǎo)致性能的
下降
結(jié)論: 結(jié)構(gòu)體傳參的時(shí)候,要傳結(jié)構(gòu)體的地址。 以上就是 小王同學(xué)給大家整理的一些初階版 認(rèn)識(shí)結(jié)構(gòu)體啦 后面會(huì)給大家 帶來進(jìn)階版的(肝疼.jpg)
到此這篇關(guān)于深入淺出理解C語言初識(shí)結(jié)構(gòu)體的文章就介紹到這了,更多相關(guān)C語言 結(jié)構(gòu)體內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C/C++中static,const,inline三種關(guān)鍵字詳細(xì)總結(jié)
以下是對(duì)C/C++中static,const,inline的三種關(guān)鍵字進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下2013-09-09VS2022連接sqlserver數(shù)據(jù)庫教程
本文主要介紹了VS2022連接sqlserver數(shù)據(jù)庫教程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07VC++中HTControl控件類的CHTSlider控制桿控件類簡(jiǎn)介
這篇文章主要介紹了VC++中HTControl控件類的CHTSlider控制桿控件類,需要的朋友可以參考下2014-08-08C++ DFS算法實(shí)現(xiàn)走迷宮自動(dòng)尋路
這篇文章主要為大家詳細(xì)介紹了C++ DFS算法實(shí)現(xiàn)走迷宮自動(dòng)尋路,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-05-05Matlab利用prim算法實(shí)現(xiàn)迷宮的生成
普里姆算法(Prim算法),圖論中的一種算法,可在加權(quán)連通圖里搜索最小生成樹。本文將利用prim算法迷宮生成及其藝術(shù)渲染,感興趣的可以了解一下2022-10-10C語言植物大戰(zhàn)數(shù)據(jù)結(jié)構(gòu)堆排序圖文示例
這篇文章主要為大家介紹了C語言植物大戰(zhàn)數(shù)據(jù)結(jié)構(gòu)堆排序的圖文示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05