C++中結(jié)構(gòu)體的的慨念和使用方法
結(jié)構(gòu)體(struct)是由一系列具有相同類型或不同類型的數(shù)據(jù)構(gòu)成的數(shù)據(jù)集合,也叫結(jié)構(gòu)。建議大家可以和這篇文章結(jié)合著來看,C++的中的結(jié)構(gòu)體和枚舉
什么是結(jié)構(gòu)體?
簡單的來說,結(jié)構(gòu)體就是一個可以包含不同數(shù)據(jù)類型的一個結(jié)構(gòu),它是一種可以自己定義的數(shù)據(jù)類型,它的特點和數(shù)組主要有兩點不同,首先結(jié)構(gòu)體可以在一個結(jié)構(gòu)中聲明不同的數(shù)據(jù)類型,第二相同結(jié)構(gòu)的結(jié)構(gòu)體變量是可以相互賦值的,而數(shù)組是做不到的,因為數(shù)組是單一數(shù)據(jù)類型的數(shù)據(jù)集合,它本身不是數(shù)據(jù)類型(而結(jié)構(gòu)體是),數(shù)組名稱是常量指針,所以不可以做為左值進行運算,所以數(shù)組之間就不能通過數(shù)組名稱相互復制了,即使數(shù)據(jù)類型和數(shù)組大小完全相同。
定義結(jié)構(gòu)體使用struct修飾符,例如:
C++ 代碼:
- struct test
- {
- float a;
- int b;
- };
上面的代碼就定義了一個名為test的結(jié)構(gòu)體,它的數(shù)據(jù)類型就是test,它包含兩個成員a和b,成員a的數(shù)據(jù)類型為浮點型,成員b的數(shù)據(jù)類型為整型。
由于結(jié)構(gòu)體本身就是自定義的數(shù)據(jù)類型,定義結(jié)構(gòu)體變量的方法和定義普通變量的方法一樣。
- test pn1;
這樣就定義了一test結(jié)構(gòu)體數(shù)據(jù)類型的結(jié)構(gòu)體變量pn1,結(jié)構(gòu)體成員的訪問通過點操作符進行,pn1.a=10 就對結(jié)構(gòu)體變量pn1的成員a進行了賦值操作,
注意:結(jié)構(gòu)體生命的時候本身不占用任何內(nèi)存空間,只有當你用你定義的結(jié)構(gòu)體類型定義結(jié)構(gòu)體變量的時候計算機才會分配內(nèi)存。
結(jié)構(gòu)體,同樣是可以定義指針的,那么結(jié)構(gòu)體指針就叫做結(jié)構(gòu)指針。
結(jié)構(gòu)指針通過->符號來訪問成員,下面我們就以上所說的看一個完整的例子:
C++ 代碼:
- //程序作者:管寧
- //所有稿件均有版權(quán),如要轉(zhuǎn)載,請務(wù)必注明出處和作者
- #include<iostream>
- #include<string>
- usingnamespacestd;
- structtest//定義一個名為test的結(jié)構(gòu)體
- {
- inta;//定義結(jié)構(gòu)體成員a
- intb;//定義結(jié)構(gòu)體成員b
- };
- voidmain()
- {
- testpn1;//定義結(jié)構(gòu)體變量pn1
- testpn2;//定義結(jié)構(gòu)體變量pn2
- pn2.a=10;//通過成員操作符.給結(jié)構(gòu)體變量pn2中的成員a賦值
- pn2.b=3;//通過成員操作符.給結(jié)構(gòu)體變量pn2中的成員b賦值
- pn1=pn2;//把pn2中所有的成員值復制給具有相同結(jié)構(gòu)的結(jié)構(gòu)體變量pn1
- cout<<pn1.a<<"|"<<pn1.b<<endl;
- cout<<pn2.a<<"|"<<pn2.b<<endl;
- test*point;//定義結(jié)構(gòu)指針
- point=&pn2;//指針指向結(jié)構(gòu)體變量pn2的內(nèi)存地址
- cout<<pn2.a<<"|"<<pn2.b<<endl;
- point->a=99;//通過結(jié)構(gòu)指針修改結(jié)構(gòu)體變量pn2成員a的值
- cout<<pn2.a<<"|"<<pn2.b<<endl;
- cout<<point->a<<"|"<<point->b<<endl;
- cin.get();
- }
總之,結(jié)構(gòu)體可以描述數(shù)組不能夠清晰描述的結(jié)構(gòu),它具有數(shù)組所不具備的一些功能特性。