Android Jni 调用 Poco SharedPtr 阻塞
最近有个项目需求 要在Android Jni层 处理http消息,于是 尝试将Poco库移植到Android利用
PocoNet接收发送http消息。Poco库移植到Android出现一个问题:定义类型为Poco::JSON::Parser
的变量后发生了阻塞(后面的日志不打印了)。这个问题排查很久,最后定位到 SharedPtr 出了故障。
Poco库实现了自己的SharedPtr (共享指针),源代码实现比c++11标准库shared_ptr要复杂,功能也
更丰富。起初怀疑 是SharedPtr 构造发生了阻塞,阅读源码后发现构造方法只是简单new了一个对象,
进一步跟进到这个对象的Class没发现特殊的地方(只是一个简单count计数)。于是在构造方法后面
增加日志验证SharedPtr对象 构造方法是否阻塞,验证结果是SharedPtr 对象的构造方法已经完成(紧
跟的日志可以打印)。验证至此得到的结论是 SharedPtr 对象本身构造已经完成,但包含 SharedPtr 对
象的 Poco::JSON::Parser对象阻塞了。这时猜测可能是SharedPtr 对象析构出问题了,于是进一步阅读
SharedPtr析构部分代码 发现 SharedPtr析构方法定义了AtomicCounter类型的成员变量,而AtomicCounter
有个成员变量类型ImplType 需要区分平台。看到这里基本上猜到问题所在,于是将ImplType 强制定制为
std::atomic<int>(可以通过增加宏定义)重新编译后再次验证问题得以解决。
如需交流可加QQ群766718184,1038388075 或者QQ3501870,
视频下载地址:http://www.chungen90.com/?list_53/
Demo下载地址: http://www.chungen90.com/?list_52