求教:动态数组问题

luckyso 2004-01-05 09:08:44
定义了一个结构体:
 struct str
{
CString name;
.......
}* pt;


在使用时,首先分配了一个地址空间:
   pt=(str *)malloc(sizeof(str));
但在给成员赋值时出错:
pt->name="aaaa";
怎样才能给它赋值呢?
多谢了!
...全文
88 16 打赏 收藏 转发到动态 举报
写回复
用AI写文章
16 条回复
切换为时间正序
请发表友善的回复…
发表回复
luckyso 2004-01-05
  • 打赏
  • 举报
回复
多谢各位的帮助!
luckyso 2004-01-05
  • 打赏
  • 举报
回复
只好用链表解决了。
DerryZhang 2004-01-05
  • 打赏
  • 举报
回复
关注
luckyso 2004-01-05
  • 打赏
  • 举报
回复
动态定义它的一个数组
luckyso 2004-01-05
  • 打赏
  • 举报
回复
如果这样写
typedef struct str
{
CString name;
.......
}pt;

pt pp;
pp.name="aaa";
这样可以,但是我要动态定义这个结构体,该如何做呢?
gameboy999 2004-01-05
  • 打赏
  • 举报
回复
new 肯定可以的,在c++ 里面 struct其实就是 public class

struct xxx
{
CString yyy;
int xxxx;
}

xxx * p = new xxx();
luckyso 2004-01-05
  • 打赏
  • 举报
回复
用new也无效,仍然报错.
lu_zi 2004-01-05
  • 打赏
  • 举报
回复
在调用malloc后再加上这句new pt str()
七伤拳 2004-01-05
  • 打赏
  • 举报
回复
呵呵,没发觉 malloc 是不会调用构造函数的
kof99th 2004-01-05
  • 打赏
  • 举报
回复
使用new 分配内存,new 和 Malloc的区别在于new会调用结构的构造函数,这样就会构造CString对象。
checkyvc6 2004-01-05
  • 打赏
  • 举报
回复
dddd8888() 说得没有错,用new就行了,他会自动调用name CString得构造函数
如果用malloc得话则不会调用构造函数
七伤拳 2004-01-05
  • 打赏
  • 举报
回复
我认为楼上的分析是错误的。
CString确实只是保存一个字符串指针,但是它能够自己管理所需要的内存空间。给CString赋值时如果当前的字符串缓冲区空间不足则会申请一块新的内存空间,的CString的析构函数里面会自动释放这块内存空间。
不管CString对象是分配在栈上还是堆上都是自己管理所需内存空间的。

你报的错是什么错?编译错还是运行时错?
vcforever 2004-01-05
  • 打赏
  • 举报
回复
结构体在定义的时候并不分配内存,他只是一种数据结构,使用他之前必须对他进行实例化,也就是必须创建一个结构体对象,然后给这个结构体对象分配内存
例如:
typedef struct _STRUCTURE {
CString str;
} STRUCTURE;
STRUCTURE m_struct;
m_struct.str = "ppppppppppppp";

May you succeed !
typhoon20 2004-01-05
  • 打赏
  • 举报
回复
长见识了,收藏一下
kulukyo 2004-01-05
  • 打赏
  • 举报
回复
CString类事实上类似于一个指向字符串的指针,得出的CString的大小永远是4,所以sizeof(str)根本就不能得出正确的大小。

建议:
1.要么这样定义char[MAX_NAME_LENGTH] name,赋值用strcpy(pt->name,...,...);
2.要么就不要直接定义和使用结构体的指针,
 struct str
{
CString name;
.......
} pt;
pt var;
var.name = "aaaa";
dddd8888 2004-01-05
  • 打赏
  • 举报
回复
你用new试试

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧