資料結構 學習筆記之:關於順序棧中給結構體類型指標分配記憶體時,使用malloc和不使用malloc的疑惑!求高手解答……

來源:互聯網
上載者:User

////////////////////////////////////////////////////////////////////////////////
更多原創“uC/OS-II學習筆記之:系列”基礎及嵌入式相關知識詳解,請訪問可樂虎部落格:
http://blog.csdn.net/dcx1205
相信不會讓您失望!!////////////////////////////////////////////////////////////////////////////////
//順序棧的C語言實現//大家請看最後用兩種方式實現的main函數#include <stdio.h>#include <math.h>#include <stdlib.h> #define TRUE  1#define FALSE 0#define STACK_SIZE 5typedef int ElementType; //定義結構體typedef struct SeqStack {    ElementType array[STACK_SIZE];    ElementType top;}SEQSTACK; //……與問題無關的函數代碼均已省略……//情況1int main(void){    SEQSTACK *pS;//定義一個指向結構體變數的指標    pS = (SEQSTACK *)malloc(sizeof(SEQSTACK));    if (pS == NULL)    {        return FALSE;    }    InitStack(pS);//初始化    PushStack(pS, 1);//壓棧    PushStack(pS, 2);    PushStack(pS, 3);    PushStack(pS, 4);    PushStack(pS, 5);    TraStack(pS);//遍曆棧    free(pS);//釋放pS所佔記憶體空間    return 0;}/*//情況2int main(void){    SEQSTACK STK;//定義一個結構體類型的變數    SEQSTACK *pS;//定義一個指向結構體變數的指標    pS = &STK;//將結構體變數的地址賦給指標    //下面函數的參數使用pS和&STK是等效的    InitStack(pS);//初始化      PushStack(&STK, 1);//壓棧    PushStack(pS, 2);    PushStack(&STK, 3);    PushStack(pS, 4);    PushStack(&STK, 5);    TraStack(pS);//遍曆棧    return 0;}*///請問情況1和2有什麼區別啊?//是情況1好還是2好?為什麼呢?//註:情況1和2的運行結果是一樣的。 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.