一、定義數(shù)據(jù)結(jié)構(gòu)中重復(fù)定義結(jié)構(gòu)體類型的作用
定義數(shù)據(jù)結(jié)構(gòu)中重復(fù)定義結(jié)構(gòu)體類型的作用是為了更加直觀的表達(dá)數(shù)據(jù)類型。比如Position FindMin(SearchTree T),完全可以寫成TreeNode* FindMin(TreeNode* T),只是名列前茅種方法更為直觀一些,表示傳入的是一顆樹,而返回的是最小值所在的位置結(jié)點(diǎn)。
結(jié)構(gòu)體的定義
結(jié)構(gòu)體(struct)是由一系列具有相同類型或不同類型的數(shù)據(jù)構(gòu)成的數(shù)據(jù)集合,也叫結(jié)構(gòu)。
結(jié)構(gòu)體和其他類型基礎(chǔ)數(shù)據(jù)類型一樣,例如int類型,char類型只不過結(jié)構(gòu)體可以做成你想要的數(shù)據(jù)類型。以方便日后的使用。
在實(shí)際項(xiàng)目中,結(jié)構(gòu)體是大量存在的。研發(fā)人員常使用結(jié)構(gòu)體來封裝一些屬性來組成新的類型。由于C語言無法操作數(shù)據(jù)庫,所以在項(xiàng)目中通過對(duì)結(jié)構(gòu)體內(nèi)部變量的操作將大量的數(shù)據(jù)存儲(chǔ)在內(nèi)存中,以完成對(duì)數(shù)據(jù)的存儲(chǔ)和操作。
在實(shí)際問題中有時(shí)候我們需要幾種數(shù)據(jù)類型一起來修飾某個(gè)變量。
例如一個(gè)學(xué)生的信息就需要學(xué)號(hào)(字符串),姓名(字符串),年齡(整形)等等。
這些數(shù)據(jù)類型都不同但是他們又是表示一個(gè)整體,要存在聯(lián)系,那么我們就需要一個(gè)新的數(shù)據(jù)類型。
——結(jié)構(gòu)體,它就將不同類型的數(shù)據(jù)存放在一起,作為一個(gè)整體進(jìn)行處理。
延伸閱讀:
二、結(jié)構(gòu)體規(guī)則
1、數(shù)據(jù)成員對(duì)齊規(guī)則:結(jié)構(gòu)(struct)(或聯(lián)合(union))的數(shù)據(jù)成員,名列前茅個(gè)數(shù)據(jù)成員放在offset為0的地方,以后每個(gè)數(shù)據(jù)成員的對(duì)齊按照#pragmapack指定的數(shù)值和這個(gè)數(shù)據(jù)成員自身長(zhǎng)度中,比較小的那個(gè)進(jìn)行。
2、結(jié)構(gòu)(或聯(lián)合)的整體對(duì)齊規(guī)則:在數(shù)據(jù)成員完成各自對(duì)齊之后,結(jié)構(gòu)(或聯(lián)合)本身也要進(jìn)行對(duì)齊,對(duì)齊將按照#pragmapack指定的數(shù)值和結(jié)構(gòu)(或聯(lián)合)最大數(shù)據(jù)成員長(zhǎng)度中,比較小的那個(gè)進(jìn)行。
3、結(jié)合1、2可推斷:當(dāng)#pragmapack的n值等于或超過所有數(shù)據(jù)成員長(zhǎng)度的時(shí)候,這個(gè)n值的大小將不產(chǎn)生任何效果。
在C語言中,可以定義結(jié)構(gòu)體類型,將多個(gè)相關(guān)的變量包裝成為一個(gè)整體使用。在結(jié)構(gòu)體中的變量,可以是相同、部分相同,或完全不同的數(shù)據(jù)類型。在C語言中,結(jié)構(gòu)體不能包含函數(shù)。在面向?qū)ο蟮某绦蛟O(shè)計(jì)中,對(duì)象具有狀態(tài)(屬性)和行為,狀態(tài)保存在成員變量中,行為通過成員方法(函數(shù))來實(shí)現(xiàn)。C語言中的結(jié)構(gòu)體只能描述一個(gè)對(duì)象的狀態(tài),不能描述一個(gè)對(duì)象的行為。在C++中,考慮到C語言到C++語言過渡的連續(xù)性,對(duì)結(jié)構(gòu)體進(jìn)行了擴(kuò)展,C++的結(jié)構(gòu)體可以包含函數(shù),這樣,C++的結(jié)構(gòu)體也具有類的功能,與class不同的是,結(jié)構(gòu)體包含的函數(shù)默認(rèn)為public,而不是private。