struct student *p, *q, *head;
10年積累的成都網(wǎng)站設計、網(wǎng)站制作經(jīng)驗,可以快速應對客戶對網(wǎng)站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡服務。我雖然不認識你,你也不認識我。但先網(wǎng)站設計后付款的網(wǎng)站建設流程,更有宜黃免費網(wǎng)站建設讓你可以放心的選擇與我們合作。
這里head不就是 struct student 類型的指針么。
這要看你返回的指針指向的是不是局部變量,你的問題很可以是返回的是一個局部變量的指針。當那個函數(shù)返回時,內(nèi)存被回收,在主函數(shù)里打印時,是因為那塊內(nèi)在沒被別的函數(shù)覆蓋,當你再調(diào)用別人函數(shù)的時候,那個地址的內(nèi)容已經(jīng)改變。這就是你的錯誤原因。
這種方式叫做“用指針函數(shù)*creat()的返回值來傳遞動態(tài)內(nèi)存”,這是一個C語法
首先你要注意,子函數(shù)*creat()用了malloc動態(tài)申請內(nèi)存,而return返回的是指針變量所指向的地址,而不是指針!相當于將你所申請的動態(tài)內(nèi)存返回給主函數(shù)
int
*fun(void)//這里是指針函數(shù)
{
int
*p
=
(int
*)
malloc
(int);//動態(tài)申請內(nèi)存//p在這里指向了一塊合法內(nèi)存的地址
return
p;
}
void
main(void)
{
int
*q
=
NULL;
q
=
fun();//fun()返回指針p所指向的地址,(指針p是在棧上創(chuàng)建的,所以*fun()函數(shù)運行完,指針所分配的內(nèi)存被系統(tǒng)自動釋放)這時q指向p,得到了malloc所申請到的內(nèi)存
free(q);//釋放動態(tài)內(nèi)存
}
C語言指向函數(shù)的指針承載的信息比較復雜,組織起來要素要寫全。根據(jù)指向函數(shù)的指針的書寫語法,下面的代碼就是一個返回函數(shù)指針的函數(shù):int (*f(void))(int){//f是函數(shù),沒有參數(shù),返回指向一個函數(shù)的指針;這個被指向的函數(shù)有一個int型形參,且返回一個int值 return fun;//fun是個函數(shù)名,必須具備一個int形參、返回int值的要求}以下代碼可以驗證上述函數(shù)的正確性:pre t="code" l="cpp"http://#include "stdafx.h"http://If the vc++6.0, with this line.
#include "stdio.h"
int fun(int n){
printf("abcdef\n");
return n;
}
int (*f(void))(int){
return fun;
}
int main(void){
printf("%d\n",f()(100));//調(diào)用函數(shù)f,通過f返回的指針用100調(diào)用函數(shù)fun
return 0;
}輸出是:abcdef100