Linux環境下使用memcpy函數遇到段錯誤問題

Linux 環境下編寫以下程序,會出現段錯誤:
#include "stdio.h"
#include <stdlib.h>
#include "string.h"
void main()
{

    char Data[] = "qwertyuiop";
    char *data ;

    memcpy (data,Data,sizeof(Data) );
    printf ("data is %s.\nand sizeof(Data) is %d.\n", data, sizeof(Data) );
}

錯誤爲:Segmentation fault (core dumped)

百度一下,發現CSDN上面也有人(關注嵌入式)遇到這種問題,在UNIX下,能正常編譯。因爲在unix上,系統對內存管的比較鬆,而在linux下,指針data可能是指向了一個只讀的內存。用malloc函數申請一個地址可以解決這個問題。
我把程序改成如下:
#include "stdio.h"
#include <stdlib.h>
#include "string.h"
void main()
{

    char Data[] = "qwertyuiop";
    char *data ;
    data = (char *) malloc(12);

    memcpy (data,Data,sizeof(Data) );
    printf ("data is %s.\nand sizeof(Data) is %d.\n", data, sizeof(Data) );
    free(data);
}


錯誤消失。輸出結果爲:
data is qwertyuiop.
and sizeof(Data) is 11.




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