通过Process 遇到的坑
2016-08-08 23:48
176 查看
之前在这篇博客讲到了process,我们知道Android的组件默认是运行在一个进程里面,名称与包名相同;在Android的清单文件里面我们可以指定组件运行在指定的process里面,process以‘:’开头,应用程序会为组件创建一个私有的进程,process以小写字母开头,则会创建一个全局的进程。
遇到的问题
在项目中有一个DialerProvider用来处理打电话的逻辑,这个组件是运行在remote的进程当中,然后为在DialerProvider的一个方法里面初始化了一个类CallDataClient,调用了initObject(在里面做了一些初始化)是一个单例模式的类;在收到一个回应以后,为发送了一个广播用来更新聊天界面,在聊天室获取到CallDataClient对象后调用其方法做一些操作,感觉逻辑并没有什么问题,然后就和写底层的哥们调试,但是一直调试不通,CallDataClient收集到的数据一直不能写到底层去,导致底层不能与服务器交互,经过不断的排查,服务器端那哥们通过日志发现CallDataClient初始化(在DialerProvider里面,运行在remote进程中)与CallDataClient调用native方法(在聊天室,运行在UI进程中)写入数据到底层并不是在一个进程,数据不能共享,服务器日志显示没有初始化,导致数据一直调不通。解决
后来将聊天室里面的CallDataClient操作放到了DialerProvider里面,数据能写到底层去了,问题就解决!相关文章推荐
- 通过继承HystrixCommand来创建请求命令遇到的问题
- 今天遇到IMP-00013: 只有 DBA 才能导入由其他 DBA 导出的文件,通过网上找到解决方案,因此转载,并对另外一种情况进行注释。
- 在Visual studio 2013环境中通过ODBC实现数据库互连时遇到的问题
- 自定义控件通过属性设置TextSize时遇到的一些问题
- 开发过程中遇到的问题Error:Execution failed for task ':app:processDebugManifest'
- Android 开发过程中遇到的问题Error:Execution failed for task ':app:processDebugManifest'
- Dynamics CRM2011 通过DeveloperToolkit在VS中部署遇到的问题
- C#监控-通过PerformanceCounter实现Process的Cpu占用率以及GC占用监控
- ,遇到某个类中有很多相似的方法,区别只是后缀不同,可以通过这个方法,实现拼接方法名而调用方法
- iOS 制作自己的FrameWork遇到的一些问题 以及FrameWork通过包合并支持arm64 armv7 i386 架构
- 解压deb包时遇到 “dpkg status database is locked by another process”问题
- 通过源码安装部署keystone环境遇到的一些问题
- java通过JDBC连接SQL Server2017遇到的一些问题
- API 通过HOOK OpenProcess() 实现进程防杀
- ARM9通过nfs启动遇到的问题以及解决
- windows环境下通过Eclipse下载hdfs中的文件中遇到的问题
- 在使用validate时遇到的问题,不通过Submit提交数据
- Android通过goToSleep休眠后,CountDownTimer遇到的问题
- 通过mysql show processlist 命令检查mysql锁的方法
- Android通过Gradle发布多渠道版本遇到的Gradle版本问题解决