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



”返回在函数内malloc的内存是安全的,但是容易造成问题,最好的做法是返回传入的指针。“怎么理解? 第1页

  

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

这句话有两重含义:

  1. 比较大众比较传统的含义就是这么干容易让外部调用者忽略掉这块内存需要释放,从而导致泄露。
  2. 更深一层更隐蔽的问题是:函数内部的malloc和外部调用者后续的free,不一定是同一个库!尤其考虑到动态库或者有可能有一些hook的时候,这种情况会更复杂(当然,一般情况下,要动malloc/free,是应该成对动的,但也不能轻易保证)。

当然,这种风险一般只存在于库的API,或者跨库调用之中,一般其它函数不一定需要这么敏感。

多说一句:基于同样的原因,跨库使用模板类,包括几乎所有的STL对象都是同样危险的,甚至风险更大点:两个库共享一个类模板,但是分别编译环境不同,甚至可能因为STL版本实现不同而导致操作逻辑甚至内存布局都发生变化。




  

相关话题

  假如重新设计「验证码」,应该如何设计? 
  三本计算机真的比985生化环材土木水利工资高吗? 
  相对论刚提出时,号称全球能完全理解的人不超过十人,现在却成为理工科必修课程,是我们智商提高了吗? 
  为什么计算机采用补码而不是原码或反码? 
  数学对计算机专业重要吗? 
  晾一件刚洗的衣服,有可能计算出每滴水落地的时间间隔吗? 
  为什么C/C++要分为头文件和源文件? 
  中国的软件业落后美国 50 年吗? 
  libc 和 libstdc++ 一定是 backward compatible 的吗? 
  C++需要反射吗? 

前一个讨论
特斯拉车主都怎么看待韩潮案?
下一个讨论
羽毛球童子功究竟强在哪?





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