结构体注意事项

#include <stdio.h>

struct stu

{

char *name;


};


int main(void)

{

struct stu student;

struct stu *student1;

strcpy(student1->name,"zhangsan");//编译能通过但会出现断错误。

       strcpy(student->name,"zhangsan")//编译能通过但会出现断错误。

return 0;

}

1 错误原因是因为没有为name 开辟空间char *name只是一个指针占4个字节储存的是地址,想使用需要开辟空间 如:name = (char *)(malloc)(10);

2 还有一个容易犯错的地方 如:struct stu *student  直接使用 printf("%s\n",student->name); 

3 如果开辟空间像这样开辟  struct stu  *student = (struct stu* )malloc(sizeof(struct stu)),还是不行因为没有为name 开辟空间。 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在将 `void*` 转换为结构体指针时,需要注意以下几个事项: 1. 确保 `void*` 指针指向的实际对象类型与结构体类型兼容。 在进行类型转换之前,需要确保 `void*` 指针指向的内存区域实际上是结构体对象的内存表示。否则,进行转换可能导致错误的结果或访问非法内存。 2. 使用适当的类型转换符进行转换。 在将 `void*` 转换为结构体指针时,需要使用适当的类型转换符,以确保类型的正确性。 例如,将 `void*` 转换为特定结构体类型的指针,可以使用类似以下的语法: ```c struct MyStruct* ptr = (struct MyStruct*)void_ptr; ``` 在这个示例中,`void_ptr` 是一个 `void*` 类型的指针,我们将其转换为 `struct MyStruct*` 类型的指针,并将结果赋值给 `ptr` 变量。 3. 考虑内存对齐和数据布局的问题。 结构体在内存中通常会按照特定的对齐要求进行布局。在进行 `void*` 到结构体指针的转换时,需要确保结构体指针的地址满足对齐要求。否则,访问结构体成员可能会导致未定义的行为。 在一些特定的情况下,可能需要手动进行对齐操作,以确保结构体指针的正确性。 4. 谨慎使用转换后的结构体指针。 一旦将 `void*` 转换为结构体指针,就可以使用该指针来访问结构体中的成员。但是,需要注意确保结构体指针指向的内存区域是有效的,并且结构体的成员访问不会导致越界或其他错误。 在使用转换后的结构体指针时,建议进行必要的验证和边界检查,以确保程序的正确性和安全性。 总之,在将 `void*` 转换为结构体指针时,需要确保类型的兼容性、正确的类型转换、正确的内存布局和访问安全。合理使用类型转换和进行必要的验证,能够避免潜在的错误和问题。 希望这些注意事项对你有所帮助!如果你还有其他问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值