<pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

          <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

          <p id="bbfd9"></p>

          <p id="bbfd9"><cite id="bbfd9"></cite></p>

            <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

            <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
            <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>

            C語言中野指針的深入解析

            時間:2025-11-05 15:11:21 C語言

            C語言中野指針的深入解析

              C語言中野指針這一塊是C語言的難點,下面小編為大家帶來了C語言中野指針的深入解析,歡迎大家閱讀!

              “野指針”的成因主要有兩種:

              (1)指針變量沒有被初始化。任何指針變量剛被創建時不會自動成為NULL指針,它的缺省值是隨機的,它會亂指一氣。所以,指針變量在創建的同時應當被初始化,要么將指針設置為NULL,要么讓它指向合法的內存。例如

              復制代碼 代碼如下:

              char *p = NULL;

              char *str = (char *) malloc(100);

              (2)指針p被free或者之后,沒有置為NULL,讓人誤以為p是個合法的指針。參見7.5節。

              別看free和的名字惡狠狠的(尤其是),它們只是把指針所指的內存給釋放掉,但并沒有把指針本身干掉。

              用調試器跟蹤示例7-5,發現指針p被free以后其地址仍然不變(非NULL),只是該地址對應的內存是垃圾,p成了“野指針”。如果此時不把p設置為NULL,會讓人誤以為p是個合法的指針。

              如果程序比較長,我們有時記不住p所指的內存是否已經被釋放,在繼續使用p之前,通常會用語句if (p != NULL)進行防錯處理。很遺憾,此時if語句起不到防錯作用,因為即便p不是NULL指針,它也不指向合法的內存塊。

              復制代碼 代碼如下:

              char *p = (char *) malloc(100);

              strcpy(p, “hello”);

              free(p); /pic/p>

              …

              if(p != NULL) /pic/p>

              {

              strcpy(p, “world”); /pic/p>

              }

              示例7-5 p成為野指針

              (3)指針操作超越了變量的作用范圍。這種情況讓人防不勝防,示例程序如下:

              復制代碼 代碼如下:

              class A

              {

              public:

              void Func(void){ cout << “Func of class A” << endl; }

              };

              void Test(void)

              {

              A *p;

              {

              A a;

              p = &a; /pic/p>

              }

              p->Func(); /pic/p>

              }

              函數Test在執行語句p->Func()時,對象a已經消失,而p是指向a的,所以p就成了“野指針”。但奇怪的是我運行這個程序時居然沒有出錯,這可能與編譯器有關。

              實例程序:

              復制代碼 代碼如下:

              #include

              #include

              int main(int argc, char *argv[])

              {

              char *p = NULL;

              p = (char*)malloc(sizeof(char)*100);

              printf("指針p的地址是:%pn", p);

              strcpy(p, "Hello");

              printf("%sn", p);

              free(p);

              printf("指針p的地址是:%pn", p);

              system("PAUSE");

              return 0;

              }

              可以看出,雖然使用 free(p) ,釋放了p指向的地址空間,但是這個指針還是存在的,只是指向的是“垃圾”內存。

              此時p的狀態就被稱為是“野指針”


            【C語言中野指針的深入解析】相關文章:

            對C語言中遞歸算法的深入解析02-27

            深入解析C語言中的數值與真假02-02

            C語言中的指針解讀12-31

            C語言中的指針是什么02-22

            什么是C語言中指針 C語言指針的基礎使用12-17

            C語言中的指針指什么12-04

            C語言中指針的概念09-23

            C語言的指針類型解析12-25

            C語言中指針與數組的區別03-11

                    <pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

                    <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

                    <p id="bbfd9"></p>

                    <p id="bbfd9"><cite id="bbfd9"></cite></p>

                      <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

                      <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
                      <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
                      飘沙影院