istream & operator>>(istream & is,mystring & s)//重载>>
{
int n = 10;
int group=1;
int i=0;
char ch;
delete [] s.pstr;
s.pstr = new char[n];
ch = is.get();
while(ch!='\n')
{
s.pstr[i] = ch;
i++;
ch = is.get();
if(i==group*n-1)
{
group++;
s.pstr = (char *)realloc(s.pstr,group*n);
}
}
s.pstr[i] = '\0';
return is;
}
这样去分配内存会不会有内存泄漏呢
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- programing菜鸟 2022-01-07 00:18关注
new应该和delete成对出现。realloc底层调用free,而非delete。强烈不推荐你这样写。你可以将new换成malloc。而且realloc完后不能直接用,应该判断一下返回值是否有效。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥16 Qphython 用xlrd读取excel报错
- ¥15 单片机学习顺序问题!!
- ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
- ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
- ¥15 相敏解调 matlab
- ¥15 求lingo代码和思路
- ¥15 公交车和无人机协同运输
- ¥15 stm32代码移植没反应
- ¥15 matlab基于pde算法图像修复,为什么只能对示例图像有效
- ¥100 连续两帧图像高速减法