欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

brew编译成mod以后 运行出错

更新时间: 2014-01-05 02:45:49 责任编辑: Author_N1

 

Brew编译成mod之后 运行出错
先看一下伪代码:
int XXXXXX_create(void* pMe)
{
    //此处代码省略 .....
    DBGPRINTF("*********Log 01********");
    DBGPRINTF("*********Log 02********");
    DBGPRINTF("*********Log 03********");
    //此处代码省略 .....
}

编译成mod文件,然后再真机上运行,用BREWLogger查看Log信息,
发现 输出了
*********Log 01********
*********Log 02********

Log 03还没输出来程序就挂掉了 报Data abort错误,不知道是什么原因,按道理Log 01,Log 02都能打印出来 为什么Log 03打印不出来,而且还报错呢?! ....

------最佳解决方案--------------------
引用:
引用:
你用Brew多线程了没有


没有 就是普通调用一个函数 只调用了一次

那就是你DBGPRINTF("*********Log 03********");之后有语句导致死机了,声明一下打印函数不是同步的。
------其他解决方案--------------------
你用Brew多线程了没有
------其他解决方案--------------------
引用:
你用Brew多线程了没有


没有 就是普通调用一个函数 只调用了一次 
------其他解决方案--------------------
顶一下~
------其他解决方案--------------------
现象是这样,不过感觉上问题应该出在其他地方。可以把这3条DBGPRINTF注释掉,再试试。
------其他解决方案--------------------
DBGPRINTF("*********Log 01********");
DBGPRINTF("*********Log 02********");
DBGPRINTF("*********Log 03********");
实际上面这3条语句都已经正常执行过去,只是后面出现了问题,导致CPU挂起,LOG还没有来得及从缓冲区出来。

------其他解决方案--------------------
楼上正解~
------其他解决方案--------------------
引用:
引用:

引用:
你用Brew多线程了没有


没有 就是普通调用一个函数 只调用了一次

那就是你DBGPRINTF("*********Log 03********");之后有语句导致死机了,声明一下打印函数不是同步的。



对就是这样,解决上面LOG打印问题可以将要打印的LOG写入文件中。
------其他解决方案--------------------
建议自己写个文件来打log
这种dbgprint有字符数的限制 还有buffered IO的优化
往往不准确
------其他解决方案--------------------
基本上都是函数内,或者函数被调用周边代码出现不具合,和DBGPRINTF应该没啥关系
其log出力是非同期的
上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-01-05 02:45:49
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/14089/
本文WWW.DOC100.NET DOC100.NET版权所有。