您的位置:首页 > 编程语言 > C语言/C++

【c++】内存泄漏常见状况

2019-08-26 21:41 1256 查看
版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。 本文链接:https://blog.csdn.net/C2681595858/article/details/100063585
  • 数组越界访问
  • malloc得到的内存不能用delete释放,要用free。
==3302== Mismatched free() / delete / delete []
==3302==    at 0x4C3173B: operator delete[](void*) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==3302==    by 0x109BCB: main (maine.cpp:126)
  • 野指针,不能把一个未释放的指针指向另一个地址。
  • new之后要先memset,不然strlen计算字符串长度时会出错。
  • valgrind 报错未初始化空间时,很有可能出现了指针new内存以后,没有memset,在new之后一定先memset一下,在使用,不要直接使用。
Use of uninitialised value of size 8
==3318==    at 0x4EB43DC: ??? (in /usr/lib/x86_64-linux-gnu/libcrypto.so.1.1)
==3318==    by 0x4EB546A: AES_cbc_encrypt (in /usr/lib/x86_64-linux-gnu/libcrypto.so.1.1)
==3318==    by 0x1FFEFFFDEF: ???
==3318==    by 0x1FFEFFFE8F: ???
  • aes-cbc加密是块加密算法,需要一个初始向量(iv)和一个加密密钥,两者共同组成对称密钥。向openssl的AES_cbc_encrypt传len参数时,最好传加密块的大小的整数倍,这样可以保证不出现太多bug。同时该API加密或者解密后的内容需要放在一个指针中,该指针申请空间时应该等于传进入的len+1。因为需要一个不能参与加密解密的字符串结束符。
  • valgrind 报如下错误
Conditional jump or move depends on uninitialised value(s)
==3766==    at 0x4C32D08: strlen (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==3766==    by 0x109E75: main (maine.cpp:114)

很有可能你strlen()里面的指针没有进行memset,所以strlen()在查找字符串结束符时查找不到,出现错误。也有可能你压根没有使用strlen,也会报这个错,此时应该检查是否使用了cout或者printf来打印某个字符串指针,因为打印的时候cout和printf也得知道这个字符串在什么位置结束,也就是说它会一直打印知道出现结束符

\0

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: