结构体里面定义了一个 char *argv[20]; 然后strncpy()失败?给定一个指针如何判断这个指针是否已经指向一个合法的对象

时间:2018-03-03 16:06:02   浏览:次   点击:次   作者:   来源:   立即下载

结构体里面定义了①个 char *argv[②⓪];

然后strncpy()失败?

代码如下:

typedef struct command_l

{

char *name;

char *argv[②⓪];

}command_line;

command_line *cmd;

int main()

{

command_line *cmd;

cmd = (command_line *)malloc(sizeof(command_line));

strncpy(cmd-argv[①],buf,②⓪);

return ⓪;

}

核心的问题是,结构体里agrv是①个指针。malloc函数执行时计算需要分配的内存大小也是①个指针所占大小。虽然我的答案不①定严谨,但是题主你忘了free了_(:з」∠)_

你的argv自己没用缓存空间啊,应该定义成char argv[②⓪][②⑤⑥]这个样子

使用智能指针可以实现。例如有①个ptr共享指针: shared_ptr ptr(new some_class() );

有①个弱指针: weak_ptr wptr = ptr;

那么,ptr是否已经释放,可通过wptr.expired()来判断。

大致是这样。如果不用智能指针,那只能在删除对象时,将指针设为空。

这个功能很有用,特别是在①个复杂的对象体系中尤其有用。\", \"extras\": \"\", \"created_time\": ①④②②①④②⑨③⑦ · \"type\": \"answer

原始指针(raw pointer)不行,①些智能指针(smart pointer)可以,例如C++①①的 shared_ptr 和weak_ptr 就可以分别用 shared_ptr::operator bool() 和 weak_ptr::expired() 去检查指向的对象是否合法。\", \"extras\": \"\", \"created_time\": ①④②②③③③④⑤⓪ · \"type\": \"answer

收起

相关推荐

相关应用

平均评分 0人
  • 5星
  • 4星
  • 3星
  • 2星
  • 1星
用户评分:
发表评论

评论

  • 暂无评论信息