zoukankan      html  css  js  c++  java
  • malloc函数分配失败处理的严重性

    本次在实际测试情况下,发现程序无缘无故的异常,导致看门狗超时复位,经过排查是malloc函数分配失败的时候,依然对指针进行了操作,导致异常。以前没重视这个问题是因为,总觉的malloc基本都会成功的,假如循环调用一个函数logOutput,里面有malloc和free,那么下次调用logOutput分配相同的空间应该也是成功的(实际上非我所愿)。问题函数如下,必须对pBuffer没有分配成功做处理,否则很容易出问题。

    static inline void logOutput(uint32_t level, const char *tag, const char* format, ...)
    {
        va_list va;
        int len, len2,space;
        char* pBuffer;
    pBuffer
    = (char*)malloc(512); /*space " "*/ if(pBuffer == NULL) return; space = gLogBufferLength - 2; len = utils_snprintf(pBuffer, LOG_PREFIX_SIZE_MAX, "#%s,%d:", tag,level); utils_snprintf( pBuffer, LOG_PREFIX_SIZE_MAX, "#%s,%d:", tag,level); space -= len; va_start(va, format); len2 = utils_vsnprintf( pBuffer+len, space ,format, va); va_end(va); len += (len2>0?len2:space); if(len < gLogBufferLength - 2){ pBuffer[len] = ' '; pBuffer[len+1] = ''; }else{ pBuffer[gLogBufferLength - 5] = '.'; pBuffer[gLogBufferLength - 4] = '.'; pBuffer[gLogBufferLength - 3] = '?'; pBuffer[gLogBufferLength - 2] = ' '; pBuffer[gLogBufferLength - 1] = ''; } logwrite((uint8_t*)pBuffer,utils_strlen(pBuffer)); free(pBuffer); };
  • 相关阅读:
    用于视频行为识别的双流卷积网络
    python更改默认版本
    ubuntu16安装ROS(包括win10子系统ubuntu同样能用)
    js中的new做了什么?
    Promise是什么?
    滚动轴 scroll
    什么是ES6?
    什么是token及怎样生成token
    mongodb 删库跑路
    css如何设置背景图片?background属性添加背景图片
  • 原文地址:https://www.cnblogs.com/429512065qhq/p/8573492.html
Copyright © 2011-2022 走看看