1樓:
a是一個結構體陣列,已經有100個節點了。不需要再分配空間了。
b是一個結構體變數,也已經有空間了,就和int b;已經有空間了一樣。
c是一個指標陣列,c也已經有空間了,有3個元素,但是這三個元素是還沒有分配空間的指標,所以要用malloc分別為他們分配記憶體。
d是一個結構體指標,和int *d;一樣還要為他分配記憶體空間;
其實結構體就可以理解為是一種和int這些一樣的資料型別,它在定義變數和指標這方面的操作和基本資料型別是一樣的。
比如:struct name na;
int ia;
這裡的na是型別struct name;的一個變數。而ia是int型別的一個變數。
struct name* np;
int* ip;
這裡的兩個指標也是一樣的,只是型別不同。
可以這樣分配記憶體。
1. np = &na; ip = &ia;
2, np = (struct name*)malloc(sizeof(struct name));
ip = (int*)malloc(sizeof(int));
宣告陣列也是一樣的。
比如:struct name narray[100];
int iarray[100];
iarray就是有100個int型的變數。
narray也是一樣的有100個struct name 這種型別的變數。
指標陣列也是一樣的。
struct name* nparray[10];
int* iparray[10];
iparray表示有10個整型的指標。
nparray表示有10個struct name型別的指標。
宣告動態陣列的方式也是一樣的。
struct name* dynarry;
int* dyiarray;
比如我們要申請100個節點的陣列
dynarray = (struct name*)malloc(100 * sizeof(struct name));
dyiarray = (int *)malloc(100 * sizeof(int));
其實資料結構就是我們自己定義的一種型別。所以在宣告變數的時候和基本資料型別(比如:int)是沒有什麼分別。
如果你覺得struct name的型別名稱太長了。你可以用typedef來定義
例如: typedef struct name name;
以後就直接用name做型別名稱就可以了
2樓:資料之路
a 是結構體陣列,a[100]等於 開闢了100個 該結構體的 空間b 是結構體 等於開闢了一個結構體的空間
c 是指向該結構體的指標陣列,開闢了三個空間,每個空間裡存放一個指向該結構體的指標。
d 為指向結構體的指標。
malloc 為動態分配陣列的時候用,具體用法如int* p;
p = (int *) malloc (sizeof(int));
3樓:匿名使用者
結構體指標其實是一個指標,它儲存的是指向某個結構體的“地址”,所以結構體指標陣列儲存的其實是指向一組結構體的“地址”陣列,它本身並不包含結構體的具體內容(沒有被分配記憶體)
所以當用到他們時,要麼重定向,比如:
d=&b; //讓d指向b,d儲存的是b的地址,這樣就能通過d來呼叫b了
要麼用malloc為他們分配記憶體:
d=(struct h *)malloc(sizeof(struct h));
這樣d就指向系統為其分配的一塊記憶體,其內容就是struct h中的東西
問下呢,結構體陣列裡有陣列成員怎麼寫入檔案呢,C語言
直接按結構大小寫進去 使用fwrite這個函式 具體如下 include stdio.h include conio.h include stdlib.h struct node main 輸入結構體陣列 for i 0 i 2 i 檢查是否輸入成功 if stu 0 a stu 0 a print...
c語言 為結構體指標的指標開闢空間
struct stu 丟失逗號 int main p a malloc 10 sizeof int 不知道成功沒 對於struct,對齊的大小也是最大的基本元素的對齊大小,物件的大小需要考慮元素的對齊,並且需要是最大基本元素的整數倍。參考下struct和union的記憶體對齊方式 所以不必再為結構體...
有以下結構體說明和變數定義,並如圖所示指標P指向a,指標q指
有以下結bai構體說明和變數定義,並如du圖所示指標p指向zhia,指標daoq指向b變數,懸賞分 10 離問內 題結束還有 14 天 20 小時 容則不能把節點b連線到節點a之後的語句是 struct node a,b,p a,q b a,b,p a,q b nest b d.p nest q 答...