【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。
相关文章推荐
- C/C++ extended python时一种常见的内存泄漏
- C/C++ extended python时一种常见的内存泄漏
- c++内存泄露(一):理解内存泄漏及内存泄漏常见情况
- 内存泄漏2——C++中常见内存泄漏情形总结
- Android中常见的内存泄漏及解决方案
- C++常见问题
- C++面试常见问题总结(不断更新中......)
- c++常见面试题30道
- [C/C++] 常见错误汇总(1)
- C++中int、string等常见类型转换
- C++英文面试常见问题
- C/C++的内存泄漏检测工具Valgrind memcheck的使用经历
- C++常见注意点和面试题
- C/C++笔试面试题-04(常见)
- c/c++常见面试题,希望能给找工作的朋友一点帮助
- Android内存泄漏常见情况
- C++常见面试题
- 7种常见排序算法的c++实现
- C++中的指针悬挂问题(内存泄漏)
- C++中内存泄漏的检测