热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

内部会分配内存的vxworks函数|vxworksAPIwhoallocatesmemoryinside

必须写到知识库里来方便以后查找,同时供大家参考少走弯路了。前面参加的一个vxWorks项目,已经处理过realloc的问题,新的项目也同样存在,但由于没有记录和整理,重新犯了1次错,再次调了这个
必须写到知识库里来方便以后查找,同时供大家参考少走弯路了。
前面参加的一个vxWorks项目,已经处理过realloc的问题,新的项目也同样存在,但由于没有记录和整理,重新犯了1次错,再次调了这个错,这就是不注意知识整理的后果
realloc有时等于free:
void *ptr = malloc(10);
if(ptr!=NULL)
    realloc(ptr,0);

有时等于malloc:
void *ptr = realloc(NULL,100);

其他就是它自己。所以用realloc代替free不可靠;
void* ptr = malloc(0);

返回的ptr不是null,实际上vxworks为你分配了当前最小的内存块,用memShow 1可看空闲内存块的情况,可能是32字节,也可能是40字节。
memShow 1

LIST OF FREE BLOCKS:
         number      size
        --------  ----------
               1          72
               1          80
               1        1208
               1        8424
               1       13584
               1       43704
               1       65384
               1       65440
              14       65520
               1      253600
               1      271008
               1     5865920


OPTIONS:
        ALLOC_ERROR_EDR_WARN
        ALLOC_ERROR_LOG
        BLOCK_ERROR_EDR_WARN
        BLOCK_ERROR_LOG
        BLOCK_ERROR_SUSPEND

SUMMARY:
  status       bytes       blocks    avg block  max block
 -------- -------------- ---------- ---------- ----------
current
 free            7505704         25     300228    5865904
 alloc          12023096      20513        586          -
 internal            824          4        206          -
cumulative
 alloc          18902232      75472        250          -
peak
 alloc          12912784          -          -          -
value = 0 = 0x0

realloc可能失败,失败时参数的指针不会被free,如果realloc的返回直接覆盖了这个指针,内存泄漏发生了,正确的处理是让realloc返回到一个临时变量ret,如果ret不是null,再将ret赋给目标指针。失败时的处理,一般是释放原来的指针,这样不用在出错时仍然占用内存资源。
void* reallocRet = realloc(ptr, 1000);
if(reallocRet != NULL)
    ptr = reallocRet;
else {
    free(ptr);
    ptr = NULL;
}

新项目中出现的新问题,前一个项目比较小,出现过的问题比较少,动态分配内存的函数除了malloc, calloc和realloc外,只用了inet_ntoa,这个函数在vxworks5.5中会动态分配内存,返回该地址,在vxworks6.8中已经变为返回静态数组的地址了,所以不会忘记释放造成内存泄漏了。
新项目中发现的内存泄漏,是由于自定义的一个数据结构队列中,为同步添加了信号量成员,但释放时未semDelete它,导致每次处理都使内存减少200多字节。这类问题难以发现,除非有人提供vxworks的所有可能占用内存的API,我在网上搜了一下,没找到,所以在这里发帖,也用于记录一下遇到的这类API。
顺便说一下,这么多论坛,内容大同小异,转帖多,原创少,也就是有价值的少,如果中国人能习惯于合作完成事情,而不是总另起炉灶同质化蜂拥而上,咱们的技术水平一定可以提高的更快!

2 个解决方案

#1


#2


在tony哪里也转一个吧!那里好像资源挺多

推荐阅读
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文介绍了C++中省略号类型和参数个数不确定函数参数的使用方法,并提供了一个范例。通过宏定义的方式,可以方便地处理不定参数的情况。文章中给出了具体的代码实现,并对代码进行了解释和说明。这对于需要处理不定参数的情况的程序员来说,是一个很有用的参考资料。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 判断数组是否全为0_连续子数组的最大和的解题思路及代码方法一_动态规划
    本文介绍了判断数组是否全为0以及求解连续子数组的最大和的解题思路及代码方法一,即动态规划。通过动态规划的方法,可以找出连续子数组的最大和,具体思路是尽量选择正数的部分,遇到负数则不选择进去,遇到正数则保留并继续考察。本文给出了状态定义和状态转移方程,并提供了具体的代码实现。 ... [详细]
author-avatar
乐土网6868
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有