小心C語言野指針

本博客C語言文章合集

指針是C語言一個很強大的功能。然而所謂成也蕭何,敗也蕭何,用好了指針會使程序大放異彩,用錯了指針輕者只是報個錯,重者可能整個系統都崩潰了。本篇我們來談談指針一種錯誤的使用方法”野指針“。
野指針一般是指定義時沒有給初值的指針變量。來看以下程序:
#include <stdio.h>
#include <string.h>

int main()
{
char source1 = "abc";
char
source2;
printf("source2的值是:%u\n", source2);
strcpy(source2 , source1);
printf("%s",source2);

return 0;
}

這段程序定義了一個指向字符的指針source2,但是沒有給它一個初始值。下面的代碼就是將字符串”abc“複製到source2中,編譯的結果如下:
--------------------Configuration: Test - Win32 Debug--------------------
Compiling...
demo.c
D:\CCode\Test\demo.c(8) : warning C4700: local variable 'source2' used without having been initialized
Linking...

Test.exe - 0 error(s), 1 warning(s)

編譯給出一個告警,說source2沒有初值就被使用了。你可以無視這個告警,並且運行程序,但是運行的結果可能是災難性的。

由於source2在定義時沒有給初值,程序運行時系統會默認給source2一個值,我們可以將程序中的
strcopy(source2 , source1);
printf("%s",source2);
這兩行代碼註釋掉,然後運行程序,看看source2輸出的值是多少。運行結果如下:

source2的值是:3435973836
Press any key to continue

可見source2被系統賦予一個值3435973836,而3435973836是一個內存的地址,至於是哪段內存地址,誰也不知道,可能是操作系統本身所在的內存地址,也可能是一個空的內存地址。如果是操作系統本身所在的內存地址,通過strcopy函數將”abc“複製給了這段內存地址,也就是修改了操作系統本身內存數據,你的計算機可能就崩掉了!所以指針在定義時一定要給一個初值,比如”NULL“。在本程序中,除了給source2賦初值外,還需使用malloc函數分配一塊存儲空間,使得source2指向這塊存儲空間。修改的程序如下:
#include <stdio.h>
#include <string.h>
#include<malloc.h>

int main()
{
char source1 = "abc";
char
source2 = NULL;
printf("source2的初始值是:%u\n", source2);
source2 = (char *)malloc(100);
printf("source2的分配值是:%u\n", source2);
strcpy(source2 , source1);
printf("%s",source2);

free(source2);
source2 = NULL;

return 0;
}

在定義source2時賦初值NULL,在使用source2時分配一段內存空間,不用source2時釋放內存空間,並且重新賦值NULL。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章