欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言 結(jié)構(gòu)體和指針詳解及簡(jiǎn)單示例

 更新時(shí)間:2016年08月24日 09:52:08   投稿:lqh  
本文主要介紹C語(yǔ)言 結(jié)構(gòu)體和指針,這里整理了相關(guān)資料,并附示例代碼和實(shí)現(xiàn)結(jié)果,以便大家學(xué)習(xí)參考,希望能幫助學(xué)習(xí)C語(yǔ)言的朋友

指針也可以指向一個(gè)結(jié)構(gòu)體,定義的形式一般為:

struct 結(jié)構(gòu)體名 *變量名;

下面是一個(gè)定義結(jié)構(gòu)體指針的實(shí)例:

struct stu{
 char *name; //姓名
 int num; //學(xué)號(hào)
 int age; //年齡
 char group; //所在小組
 float score; //成績(jī)
} stu1 = { "Tom", 12, 18, 'A', 136.5 };
//結(jié)構(gòu)體指針
struct stu *pstu = &stu1;

也可以在定義結(jié)構(gòu)體的同時(shí)定義結(jié)構(gòu)體指針:

struct stu{
 char *name; //姓名
 int num; //學(xué)號(hào)
 int age; //年齡
 char group; //所在小組
 float score; //成績(jī)
} stu1 = { "Tom", 12, 18, 'A', 136.5 }, *pstu = &stu1;

注意,結(jié)構(gòu)體變量名和數(shù)組名不同,數(shù)組名在表達(dá)式中會(huì)被轉(zhuǎn)換為數(shù)組指針,而結(jié)構(gòu)體變量名不會(huì),無(wú)論在任何表達(dá)式中它表示的都是整個(gè)集合本身,要想取得結(jié)構(gòu)體變量的地址,必須在前面加&,所以給 pstu 賦值只能寫(xiě)作:

struct stu *pstu = &stu1;

而不能寫(xiě)作:

struct stu *pstu = stu1;

還應(yīng)該注意,結(jié)構(gòu)體和結(jié)構(gòu)體變量是兩個(gè)不同的概念:結(jié)構(gòu)體是一種數(shù)據(jù)類(lèi)型,是一種創(chuàng)建變量的模板,編譯器不會(huì)為它分配內(nèi)存空間,就像 int、float、char 這些關(guān)鍵字本身不占用內(nèi)存一樣;結(jié)構(gòu)體變量才包含實(shí)實(shí)在在的數(shù)據(jù),才需要內(nèi)存來(lái)存儲(chǔ)。下面的寫(xiě)法是錯(cuò)誤的,不可能去取一個(gè)結(jié)構(gòu)體名的地址,也不能將它賦值給其他變量:

struct stu *pstu = &stu;
struct stu *pstu = stu;

獲取結(jié)構(gòu)體成員

通過(guò)結(jié)構(gòu)體指針可以獲取結(jié)構(gòu)體成員,一般形式為:

(*pointer).memberName

或者:

pointer->memberName

第一種寫(xiě)法中,.的優(yōu)先級(jí)高于*,(*pointer)兩邊的括號(hào)不能少。如果去掉括號(hào)寫(xiě)作*pointer.memberName,那么就等效于*(pointer.numberName),這樣意義就完全不對(duì)了。

第二種寫(xiě)法中,->是一個(gè)新的運(yùn)算符,習(xí)慣稱(chēng)它為“箭頭”,有了它,可以通過(guò)結(jié)構(gòu)體指針直接取得結(jié)構(gòu)體成員;這也是->在C語(yǔ)言中的唯一用途。

上面的兩種寫(xiě)法是等效的,我們通常采用后面的寫(xiě)法,這樣更加直觀。

【示例】結(jié)構(gòu)體指針的使用。

#include <stdio.h>
int main(){
 struct{
 char *name; //姓名
 int num; //學(xué)號(hào)
 int age; //年齡
 char group; //所在小組
 float score; //成績(jī)
 } stu1 = { "Tom", 12, 18, 'A', 136.5 }, *pstu = &stu1;
    //讀取結(jié)構(gòu)體成員的值
    printf("%s的學(xué)號(hào)是%d,年齡是%d,在%c組,今年的成績(jī)是%.1f!\n", (*pstu).name, (*pstu).num, (*pstu).age, (*pstu).group, (*pstu).score);
    printf("%s的學(xué)號(hào)是%d,年齡是%d,在%c組,今年的成績(jī)是%.1f!\n", pstu->name, pstu->num, pstu->age, pstu->group, pstu->score);
    return 0;
}

運(yùn)行結(jié)果:

Tom的學(xué)號(hào)是12,年齡是18,在A組,今年的成績(jī)是136.5!
Tom的學(xué)號(hào)是12,年齡是18,在A組,今年的成績(jī)是136.5!

【示例】結(jié)構(gòu)體數(shù)組指針的使用。

#include <stdio.h>
struct stu{
 char *name; //姓名
 int num; //學(xué)號(hào)
 int age; //年齡
 char group; //所在小組
 float score; //成績(jī)
}stus[] = {
 {"Zhou ping", 5, 18, 'C', 145.0},
 {"Zhang ping", 4, 19, 'A', 130.5},
 {"Liu fang", 1, 18, 'A', 148.5},
 {"Cheng ling", 2, 17, 'F', 139.0},
 {"Wang ming", 3, 17, 'B', 144.5}
}, *ps;
int main(){
 //求數(shù)組長(zhǎng)度
 int len = sizeof(stus) / sizeof(struct stu);
 printf("Name\t\tNum\tAge\tGroup\tScore\t\n");
 for(ps=stus; ps<stus+len; ps++){
 printf("%s\t%d\t%d\t%c\t%.1f\n", ps->name, ps->num, ps->age, ps->group, ps->score);
 }
 return 0;
}

運(yùn)行結(jié)果:

Name            Num     Age     Group   Score
Zhou ping       5       18      C       145.0
Zhang ping      4       19      A       130.5
Liu fang        1       18      A       148.5
Cheng ling      2       17      F       139.0
Wang ming       3       17      B       144.5

結(jié)構(gòu)體指針作為函數(shù)參數(shù)

結(jié)構(gòu)體變量名代表的是整個(gè)集合本身,作為函數(shù)參數(shù)時(shí)傳遞的整個(gè)集合,也就是所有成員,而不是像數(shù)組一樣被編譯器轉(zhuǎn)換成一個(gè)指針。如果結(jié)構(gòu)體成員較多,尤其是成員為數(shù)組時(shí),傳送的時(shí)間和空間開(kāi)銷(xiāo)會(huì)很大,影響程序的運(yùn)行效率。所以最好的辦法就是使用結(jié)構(gòu)體指針,這時(shí)由實(shí)參傳向形參的只是一個(gè)地址,非??焖佟?/p>

【示例】計(jì)算全班學(xué)生的總成績(jī)、平均成績(jī)和以及 140 分以下的人數(shù)。

#include <stdio.h>
struct stu{
 char *name; //姓名
 int num; //學(xué)號(hào)
 int age; //年齡
 char group; //所在小組
 float score; //成績(jī)
}stus[] = {
 {"Li ping", 5, 18, 'C', 145.0},
 {"Zhang ping", 4, 19, 'A', 130.5},
 {"He fang", 1, 18, 'A', 148.5},
 {"Cheng ling", 2, 17, 'F', 139.0},
 {"Wang ming", 3, 17, 'B', 144.5}
};
void average(struct stu *ps, int len);
int main(){
 int len = sizeof(stus) / sizeof(struct stu);
 average(stus, len);
 return 0;
}
void average(struct stu *ps, int len){
 int i, num_140 = 0;
 float average, sum = 0;
 for(i=0; i<len; i++){
 sum += (ps + i) -> score;
 if((ps + i)->score < 140) num_140++;
 }
 printf("sum=%.2f\naverage=%.2f\nnum_140=%d\n", sum, sum/5, num_140);
}

運(yùn)行結(jié)果:

sum=707.50
average=141.50
num_140=2

以上就是對(duì)結(jié)構(gòu)體和指針的資料整理,后續(xù)繼續(xù)補(bǔ)充相關(guān)資料,謝謝大家對(duì)本站的支持!

相關(guān)文章

  • C語(yǔ)言中`||`的短路機(jī)制詳解

    C語(yǔ)言中`||`的短路機(jī)制詳解

    在C語(yǔ)言中,邏輯或運(yùn)算符(||)是一種常用的邏輯運(yùn)算符,用于組合多個(gè)條件表達(dá)式,C語(yǔ)言中的邏輯或運(yùn)算符具有短路機(jī)制,這是一種非常重要的概念,本文將深入解釋C語(yǔ)言中的||短路機(jī)制以及其在編程中的應(yīng)用,感興趣的朋友跟隨小編一起看看吧
    2024-01-01
  • c語(yǔ)言snprintf函數(shù)的用法詳解

    c語(yǔ)言snprintf函數(shù)的用法詳解

    這篇文章主要給大家介紹了關(guān)于c語(yǔ)言snprintf函數(shù)用法的相關(guān)資料,snprintf()函數(shù)用于將格式化的數(shù)據(jù)寫(xiě)入字符串,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-09-09
  • 用VScode編寫(xiě)C++大型項(xiàng)目的方法步驟

    用VScode編寫(xiě)C++大型項(xiàng)目的方法步驟

    本文主要介紹了用VScode編寫(xiě)C++大型項(xiàng)目的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • C++高級(jí)數(shù)據(jù)結(jié)構(gòu)之二叉查找樹(shù)

    C++高級(jí)數(shù)據(jù)結(jié)構(gòu)之二叉查找樹(shù)

    這篇文章主要介紹了C++高級(jí)數(shù)據(jù)結(jié)構(gòu)之二叉查找樹(shù),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-05-05
  • C++訪(fǎng)問(wèn)者模式模板函數(shù)無(wú)法重載的問(wèn)題解決

    C++訪(fǎng)問(wèn)者模式模板函數(shù)無(wú)法重載的問(wèn)題解決

    本文主要介紹了C++訪(fǎng)問(wèn)者模式模板函數(shù)無(wú)法重載的問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • C++實(shí)現(xiàn)路口交通燈模擬系統(tǒng)

    C++實(shí)現(xiàn)路口交通燈模擬系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)路口交通燈模擬系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C語(yǔ)言浮點(diǎn)型數(shù)據(jù)在內(nèi)存中的存儲(chǔ)方式詳解

    C語(yǔ)言浮點(diǎn)型數(shù)據(jù)在內(nèi)存中的存儲(chǔ)方式詳解

    任何數(shù)據(jù)在內(nèi)存中都是以二進(jìn)制的形式存儲(chǔ)的,例如一個(gè)short型數(shù)據(jù)1156,其二進(jìn)制表示形式為00000100 10000100,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言浮點(diǎn)型數(shù)據(jù)在內(nèi)存中的存儲(chǔ)方式,需要的朋友可以參考下
    2023-03-03
  • 基于linux下獲取時(shí)間函數(shù)的詳解

    基于linux下獲取時(shí)間函數(shù)的詳解

    本篇文章是對(duì)linux下獲取時(shí)間的函數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C語(yǔ)言中的結(jié)構(gòu)體快排算法

    C語(yǔ)言中的結(jié)構(gòu)體快排算法

    這篇文章主要介紹了C語(yǔ)言中的結(jié)構(gòu)體快排算法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • C語(yǔ)言鏈表與單鏈表詳解

    C語(yǔ)言鏈表與單鏈表詳解

    鏈表是一種物理存儲(chǔ)結(jié)構(gòu)上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過(guò)鏈表中的指針鏈接次序?qū)崿F(xiàn)的,本章帶你詳細(xì)了解鏈表與單鏈表
    2022-02-02

最新評(píng)論