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

  • 数组越界访问
  • 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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值