我有以下C程序。
#include<stdio.h>
#include<stdlib.h>
enum country_name
{
Germany, France, Spain
};
int main()
{
struct employee
{
char *name;
int age;
float bs;
enum country_name country;
};
typedef struct employee EMPLOYEE;
EMPLOYEE e;
//e.name = malloc(30);
e.name = "Manuel";
e.age = 25;
e.bs = 25000;
e.country = Germany;
printf("Name: %s\n",e.name);
printf("Age: %d\n",e.age);
printf("Salary: %f\n",e.bs);
printf("Country: %d\n",e.country);
return 0;
}
正如您所看到的,我评论了malloc()。我期待某种类型的警告或错误。
然而,当我运行该程序时,它会给出预期的输出。
-bash-4.1$ ./a.out
Name: Manuel
Age: 25
Salary: 25000.000000
Country: 0
-bash-4.1$
我在想我需要使用malloc()来分配内存。在这种情况下真的不需要malloc()吗?
编辑:阅读下面的答案后。
好的,所以我想我正在尝试这样做,看看注释掉malloc()是否会导致任何错误。
char nameHold[30] = "Manuel";
e.name = malloc(30);
strcpy(e.name, namoHold );
在这种情况下,如果我不使用malloc(),我会得到“分段错误”。
答案 0 :(得分:4)
只需在源代码中使用"Manuel"
就足以让编译器分配包含字符串"Manuel"
的只读内存块。您的代码将此内存块的地址分配给e.name
。
如果未将malloc
调用注释掉,则代码不存储字符串&#34; Manuel&#34;进入分配有malloc
的内存;相反,它分配100个字节(并使e.name
指向100字节块),然后使e.name
指向只读字符串&#34; Manuel&#34; (所以你现在没有指向100字节块的指针)。