百科问答小站 logo
百科问答小站 font logo



C++ 的智能指针不就基本解决了野指针问题了吗?为什么还要吹捧rust的内存安全? 第1页

  

user avatar   haozhi-yang-41 网友的相关建议: 
      

极端理想的情况是这样的。

然而现实中:

1:你需要维护大量c++03甚至更老的代码,给它fix或者叠加功能……

2:你需要引用到很多已完成的代码库,而这些库的接口甚至是纯c的。

3:在以前,有时候会有一些逻辑/技巧会把裸指针转为整形进行运算和处理:例如说我见过一个rbt实现,把指针的最低bit拿来指示颜色(因为内存对齐的缘故,从堆里申请出来的内存,最低bit一般都为0)。还有本机多进程服务,把在共享内存的指针当做整形传给对方(双方在mmap时指定同一个基址)。

遇到了这些,你连改写都不一定那么容易改写。


user avatar   yu-hang-58 网友的相关建议: 
      

Rust 我不太了解,但 Smart Pointer 并没有从根本上解决 C++ 的内存安全问题。说白了,程序员用不好、不会用,依然轻轻松松造成内存安全问题,随手就来几个例子:

1、std::shared_ptr 被提前释放:

       void process(std::shared_ptr<int> svp) {} int main(int argc, char** argv) {   int* vp = new int(10);   process(std::shared_ptr<int>(vp));   std::cout << *vp << std::endl;  // pointer "vp" has already been released.   return 0; }      

2、使用栈对象初始化智能指针,造成悬挂指针:

       auto process() {   int v = 10;   int* vp = &v;   return std::shared_ptr<int>(vp); } int main(int argc, char** argv) {   std::cout << *process() << std::endl;  // dangling pointer.   return 0; }      

3、std::shared_ptr 造成的循环引用:

       struct C {   ~C() { std::cerr << "destructor
"; }   std::shared_ptr<C> sp; }; int main(int argc, char **argv) {   auto p = std::make_shared<C>(), q = std::make_shared<C>();   p->sp = q;   q->sp = p;   return 0; }      

4、不当用法造成的潜在内存泄露:

       bool complicatedCompute() { /* ... */ return true; }  // potential memory leak; auto process(std::shared_ptr<int>, bool) {} int main(int argc, char** argv) {   process(std::shared_ptr<int>(new int(10)), complicatedCompute());   return 0; }      

BTW. 除了上述想到的几种场景,其他的还包括 std::shared_ptr 与 std::weak_ptr 联合使用不当所可能导致的潜在内存问题:比如,使用 std::make_shared 方式构造的 std::shared_ptr 对象,其控制块内存只会在对应 std::weak_ptr 引用计数完全清零时,才会将堆内一次性分配的整块内存完全释放。因此这就可能造成内存释放的不连续性,中间产生的 time gap 在某些应用场景下可能会带来潜在问题。另外,new + std::shared_ptr 构造方式虽然不存在上述问题,并且支持自定义 deleter,但却可能导致潜的在内存泄露以及智能指针对象构造效率的问题。因此,在 C++ 中至少暂时还没有特别完美的方案来真正“智能地”管理内存和指针,并同时兼顾性能、安全、使用成本、维护成本等诸多方面问题。

最后补充一句:C++11 曾经有过标准以支持“最小垃圾回收及安全派生指针”,但很可惜,据我所知,从 GUN 到 Clang 目前还没有任何一款编译器支持。

Update:

贴下上图链接:zh.cppreference.com/w/c




  

相关话题

  C++中delete this是对象先析构还是delete语句先返回? 
  c语言0xFFFF换成十进制不应该是65535吗? 
  怎能给孩子讲用c++解决鸡兔同笼问题,百钱买百鸡等问题,也就是c++的for循环嵌套枚举? 
  如何解决 C++ 代码不能打开提示有一个错误的问题? 
  如何评价 C++ 11 auto 关键字? 
  c++ 程序运行时异常处理,怎么定位到出错代码行? 
  C++ 中,如果指针换了被指向的东西,那被指向的原来的东西(是被 new 出来的)所占的内存会立刻被释放吗? 
  C++ 需要 restrict 关键字吗? 
  编译器生成的汇编语句执行顺序为什么与C代码顺序不同? 
  C 语言和 C++、C# 的区别在什么地方? 

前一个讨论
为什么新国标要求电动自行车必须有脚蹬?
下一个讨论
孩子大一,用的是叔叔送给他的旧电脑,他一直说很卡想换,我觉得没有必要怎么办?





© 2025-01-18 - tinynew.org. All Rights Reserved.
© 2025-01-18 - tinynew.org. 保留所有权利