第六篇说我遇到的一个问题吧,在写这篇文章的时候并没有找到怎么解决,如果有大佬看到了也希望大佬看看给我点意见或者问题处在哪里,先谢过大佬们了。首先说问题吧,板子是s3c2440,内存只有64M,然后跑我这个程序,只能跑20分钟不到就会出现OOM,一开始我其实很蒙蔽的,不知道怎么办,然后用其他大佬说的查内存泄漏软件valgrind查了,然后出现了这样的结果:
我看到这些消息,居然有点蒙,矛头指向了jpeg库文件里面,因为send_picture里直接调用的是rgb_to_jpeg了,然后rgb_to_jpeg里面是这样的:
基本是按部就班的操作,然后是send_picture里面是这样的:
感觉问题也不大呀,然后照着valgrind给出的那些文件去查,行数也给了,直接跳去看,然后就跟valgrind说的一样的最后找到了jdatadst.c这个源文件里的131行,具体情况是这样的:
然后我就不知所措了,不知道从何处入手,然后我又换了一个jpeg9c的库,发现也是这个问题,源文件上面那一行只是加了个malloc的返回类型,然后问题就是这个了,我也不知道是不是我的程序其他部分的问题,但是valgrind是这样报的,我也不知道改怎样改,我也看了我其他部分的代码,我感觉是没有内存泄漏的地方,代码在第三篇,希望有大佬看到的话帮我解惑一下,虽然说能跑10多分钟对毕设演示影响不大,但是这个问题我觉得我不能逃避,有大佬帮忙的话就很感谢了,如果我解决了我会继续分享给大家,这篇先到这里吧。
前段时间一直在忙着写论文,论文基本写完了,今天突然想起了这个问题,然后又重复看我的代码以及jpeg库操作的步骤,终于发现了问题,嗯,很幸运,就一句代码的问题,问题解决了,在上面源代码中jpeg_mem_dest上面我想到我空了一行,我在想我当初为什么空了这一行,然后又看了下操作步骤,没错,这里少写了一行,就是给jpeg_size赋一个初始的值,大小是分辨率乘以位数除以3 相比较我的就是jpeg_size = 320*240*24/3 ;然后我重新用valgrind检测了下,问题解决了,在板子上运行还没试,这是测试结果:
从结果来看,问题已经解决了,很幸运,今天灵感突然来了,可能是当时比较迷糊吧。希望大家不要和我有一样的情况出现(哭),也只有我这么马虎然后出问题,hah,就到这里。