社区
Android
帖子详情
关于service启动和广播接收的问题求帮助,较急
t03330130
2015-01-31 07:51:42
如图,logca中可以看到,启动activity后就发送广播但是这个时候service类还没有启动,broadcastreceiver 还没有注册。所以导致了service类没有接收到广播,请坛友帮忙看看咋回事,
痛苦中!
...全文
119
4
打赏
收藏
关于service启动和广播接收的问题求帮助,较急
如图,logca中可以看到,启动activity后就发送广播但是这个时候service类还没有启动,broadcastreceiver 还没有注册。所以导致了service类没有接收到广播,请坛友帮忙看看咋回事,痛苦中!
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
4 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
t03330130
2015-01-31
打赏
举报
回复
再补充一点。我在service类中定义了一个BluetoothReceiver类,用于接收从activity 传来的BluetoothDevice 的address。如果得到了address之后在一个新thread的run方法中进行mbluetoothsocket连接,如果成功就ok了,但是要是失败了,thread 的run方法不能重复调用只能调用一次,在这种情况下怎样才能让这个线程在socket.connect没有成功的情况下循环进行connect直到连接成功。
t03330130
2015-01-31
打赏
举报
回复
亲们,帮帮忙,比较急,痛苦好久了
t03330130
2015-01-31
打赏
举报
回复
非常感谢,我试一下。确认一下,while循环是写在thread 的run方法中吗?就是那个有socket.connect()的那个run()方法? 我的startservice是写在activity的oncreate中。sendbroadcast是写在activity的onSart中。
爱coding的卖油翁
2015-01-31
打赏
举报
回复
这个关于socket通信的吗?如果是这样的话,可以写成while循环,给个标志位,如果断开连接了,就让它每多少秒在发送请求来连接,这个你自己控制。上面的那个service没启动。我不知道你要的service是在后台驻留的,还是和activity同生共死的,给你一个通用的方法,在activity创建的时候就启动或者绑定service,然后在操作发送广播..
《Android系统源代码情景分析》
《Android系统源代码情景分析》随书光盘内容(源代码) 目录如下: 第1篇 初识Android系统 第1章 准备知识 1.1 Linux内核参考书籍 1.2 Android应用程序参考书籍 1.3 下载、编译和运行Android源代码 1.3.1 下载Android源代码 1.3.2 编译Android源代码 1.3.3 运行Android模拟器 1.4 下载、编译和运行Android内核源代码 1.4.1 下载Android内核源代码 1.4.2 编译Android内核源代码 1.4.3 运行Android模拟器 1.5 开发第一个Android应用程序 1.6 单独编译和打包Android应用程序模块 1.6.1 导入单独编译模块的mmm命令 1.6.2 单独编译Android应用程序模块 1.6.3 重新打包Android系统镜像文件 第2章 硬件抽象层 2.1 开发Android硬件驱动程序 2.1.1 实现内核驱动程序模块 2.1.2 修改内核Kconfig文件 2.1.3 修改内核Makefile文件 2.1.4 编译内核驱动程序模块 2.1.5 验证内核驱动程序模块 2.2 开发C可执行程序验证Android硬件驱动程序 2.3 开发Android硬件抽象层模块 2.3.1 硬件抽象层模块编写规范 2.3.2 编写硬件抽象层模块接口 2.3.3 硬件抽象层模块的加载过程 2.3.4 处理硬件设备访问权限
问题
2.4 开发Android硬件访问服务 2.4.1 定义硬件访问服务接口 2.4.2 实现硬件访问服务 2.4.3 实现硬件访问服务的JNI方法 2.4.4
启动
硬件访问服务 2.5 开发Android应用程序来使用硬件访问服务 第3章 智能指针 3.1 轻量级指针 3.1.1 实现原理分析 3.1.2 应用实例分析 3.2 强指针和弱指针 3.2.1 强指针的实现原理分析 3.2.2 弱指针的实现原理分析 3.2.3 应用实例分析 第2篇 Android专用驱动系统 第4章 Logger日志系统 4.1 Logger日志格式 4.2 Logger日志驱动程序 4.2.1 基础数据结构 4.2.2 日志设备的初始化过程 4.2.3 日志设备文件的打开过程 4.2.4 日志记录的读取过程 4.2.5 日志记录的写入过程 4.3 运行时库层日志库 4.4 C/C++日志写入接口 4.5 Java日志写入接口 4.6 Logcat工具分析 4.6.1 相关数据结构 4.6.2 初始化过程 4.6.3 日志记录的读取过程 4.6.4 日志记录的输出过程 第5章 Binder进程间通信系统 5.1 Binder驱动程序 5.1.1 基础数据结构 5.1.2 Binder设备的初始化过程 5.1.3 Binder设备文件的打开过程 5.1.4 Binder设备文件的内存映射过程 5.1.5 内核缓冲区管理 5.2 Binder进程间通信库 5.3 Binder进程间通信应用实例 5.4 Binder对象引用计数技术 5.4.1 Binder本地对象的生命周期 5.4.2 Binder实体对象的生命周期 5.4.3 Binder引用对象的生命周期 5.4.4 Binder代理对象的生命周期 5.5 Binder对象死亡通知机制 5.5.1 注册死亡
接收
通知 5.5.2 发送死亡
接收
通知 5.5.3 注销死亡
接收
通知 5.6
Service
Manager的
启动
过程 5.6.1 打开和映射Binder设备文件 5.6.2 注册为Binder上下文管理者 5.6.3 循环等待Client进程请
求
5.7
Service
Manager代理对象的获取过程 5.8
Service
组件的
启动
过程 5.8.1 注册
Service
组件 5.8.2
启动
Binder线程池 5.9
Service
代理对象的获取过程 5.10 Binder进程间通信机制的Java接口 5.10.1
Service
Manager的Java代理对象的获取过程 5.10.2 Java服务接口的定义和解析 5.10.3 Java服务的
启动
过程 5.10.4 Java服务代理对象的获取过程 5.10.5 Java服务的调用过程 第6章 Ashmem匿名共享内存系统 6.1 Ashmem驱动程序 6.1.1 基础数据结构 6.1.2 匿名共享内存设备的初始化过程 6.1.3 匿名共享内存设备文件的打开过程 6.1.4 匿名共享内存设备文件的内存映射过程 6.1.5 匿名共享内存块的锁定和解锁过程 6.1.6 匿名共享内存块的回收过程 6.2 运行时库cutils的匿名共享内存访问接口 6.3 匿名共享内存的C++访问接口 6.3.1 MemoryHeapBase 6.3.2 MemoryBase 6.3.3 应用实例 6.4 匿名共享内存的Java访问接口 6.4.1 MemoryFile 6.4.2 应用实例 6.5 匿名共享内存的共享原理 第3篇 Android应用程序框架 第7章 Activity组件的
启动
过程 7.1 Activity组件应用实例 7.2 根Activity组件的
启动
过程 7.3 子Activity组件在进程内的
启动
过程 7.4 子Activity组件在新进程中的
启动
过程 第8章
Service
组件的
启动
过程 8.1
Service
组件应用实例 8.2
Service
组件在新进程中的
启动
过程 8.3
Service
组件在进程内的绑定过程 第9章 Android系统
广播
机制 9.1
广播
机制应用实例 9.2
广播
接收
者的注册过程 9.3
广播
的发送过程 第10章 Content Provider组件的实现原理 10.1 Content Provider组件应用实例 10.1.1 ArticlesProvider 10.1.2 Article 10.2 Content Provider组件的
启动
过程 10.3 Content Provider组件的数据共享原理 10.3.1 数据共享模型 10.3.2 数据传输过程 10.4 Content Provider组件的数据更新通知机制 10.4.1 注册内容观察者 10.4.2 发送数据更新通知 第11章 Zygote和System进程的
启动
过程 11.1 Zygote进程的
启动
脚本 11.2 Zygote进程的
启动
过程 11.3 System进程的
启动
过程 第12章 Android应用程序进程的
启动
过程 12.1 应用程序进程的创建过程 12.2 Binder线程池的
启动
过程 12.3 消息循环的创建过程 第13章 Android应用程序的消息处理机制 13.1 创建线程消息队列 13.2 线程消息循环过程 13.3 线程消息发送过程 13.4 线程消息处理过程 第14章 Android应用程序的键盘消息处理机制 14.1 键盘消息处理模型 14.2 InputManager的
启动
过程 14.2.1 创建InputManager 14.2.2
启动
InputManager 14.2.3
启动
InputDispatcher 14.2.4
启动
InputReader 14.3 InputChannel的注册过程 14.3.1 创建InputChannel 14.3.2 注册Server端InputChannel 14.3.3 注册系统当前激活的应用程序窗口 14.3.4 注册Client端InputChannel 14.4 键盘消息的分发过程 14.4.1 InputReader获得键盘事件 14.4.2 InputDispatcher分发键盘事件 14.4.3 系统当前激活的应用程序窗口获得键盘消息 14.4.4 InputDispatcher获得键盘事件处理完成通知 14.5 InputChannel的注销过程 14.5.1 销毁应用程序窗口 14.5.2 注销Client端InputChannel 14.5.3 注销Server端InputChannel 第15章 Android应用程序线程的消息循环模型 15.1 应用程序主线程消息循环模型 15.2 与界面无关的应用程序子线程消息循环模型 15.3 与界面相关的应用程序子线程消息循环模型 第16章 Android应用程序的安装和显示过程 16.1 应用程序的安装过程 16.2 应用程序的显示过程
Android
接收
开机
广播
启动
service
/activity
Android
接收
开机
广播
启动
service
/activity 前言: 此文章针对于普通手机APP,在没有限制之前直接可以通过
接收
开机
广播
,然后通过intent即可实现开机
启动
service
/activity。 Intent intent = new Intent(context,XXXXX.class); intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); context.startActivity(intent);//
启动
activity context.s
Android在
Service
中注册动态
广播
接收
者
广播
接收
器注册一共有两种形式 : 静态注册和动态注册. 两者及其
接收
广播
的区别: 1.动态注册的
广播
永远要快于 静态注册的
广播
,不管静态注册的优先级设置的多高,不管动态注册的优先级有多低>\ 2.动态注册
广播
不是 常驻型
广播
,也就是说
广播
跟随activity的生命周期。注意: 在activity结束前,移除
广播
接收
器。 静态注册是常驻型 ,也就是说当应用程序关闭后,如果有信息
广播
来,程序也会被系统调用自动运行。 3.同种
广播
如果在同一个优先级下,谁先
启动
的快,谁将先
接收
到
广播
。
android
接收
开机
广播
启动
service
项目用到了一点相关的东西,记录备忘 android系统
启动
完成会发出
广播
,action为"android.intent.action.BOOT_COMPLETED"
接收
这个
广播
启动
service
就可以了。 这里需要注意,这个
广播
接收
也是需要权限的。在Manifest中添加权限如下: 项目中
service
是利用aidl 创建的,
service
在Menifes
47.android服务
service
-代码注册
广播
接收
者
广播
可以在代码中注册 使用代码注册
广播
接收
者 1.使用清单文件配置:
广播
一旦发出,系统会去所有的清单文件中寻找,哪一个
广播
接收
者的action和
广播
的action是匹配的,如果找到了,就把
广播
接收
者的进程
启动
启动
起来, 2.使用代码注册:需要使用
广播
接收
者时,执行注册的代码,不需要的时候,执行解除注册的代码。 特殊的
广播
接收
者 安卓中有一些
广播
接收
者,必须使用代码注册,清单文件注册是无效...
Android
80,351
社区成员
91,288
社区内容
发帖
与我相关
我的任务
Android
移动平台 Android
复制链接
扫一扫
分享
社区描述
移动平台 Android
android
android-studio
androidx
技术论坛(原bbs)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章