一个 App 中运行了 4 个进程,包括主进程和 ABC 三个子进程。
主进程通知 ABC 同时去做一件写文件的任务,当 ABC 都做完时再回来告诉主进程,主进程对生成的文件进行压缩。
现在想到的笨方法无非就是一个变量去记录 ABC 是否已经完成,比如 000 表示都没完成,111 表示都完成了。
有没有老哥做过类似的案例,有什么奇思妙想吗?
1
luckyrayyy 2020 年 11 月 19 日
这...操作系统和 api 层面都有现成的,你搞些奇技淫巧干啥
|
2
ex1gtnim7d OP @luckyrayyy 啊,能举个例子吗
|
3
carlclone 2020 年 11 月 19 日
信号。。。
|
4
acmore 2020 年 11 月 19 日
|
5
Resource 2020 年 11 月 19 日
安卓可以用 CompletableFuture 吗?
|
6
jobsofchina 2020 年 11 月 19 日 via Android
不懂就问,安卓没有 join()吗
|
7
liian2019 2020 年 11 月 19 日
CompletionService
|
8
300 2020 年 11 月 19 日 via Android
|
9
0xZhangKe 2020 年 11 月 19 日
RxJava
|
10
tanranran 2020 年 11 月 19 日 坐等大佬回复,楼上的说实话,都是不看题目的,LZ 说的是进程,不是线程
|
11
ex1gtnim7d OP @acmore 可以用于进程吗
|
12
ex1gtnim7d OP @tanranran 哈哈,终于有个看明白的
|
13
gam2046 2020 年 11 月 19 日
自己利用 Binder 实现类似 ForkJoinPool 的机制或者共享内存( CPP )是比较低成本的方式。但如果不是因为 OOM,这样的工作,不建议使用多进程这样重量级的方式。
|
14
knowckx 2020 年 11 月 19 日
sync.waitgroup 的味道
|
15
mingl0280 2020 年 11 月 19 日 via Android
|
16
hm279 2020 年 11 月 19 日 via Android
正常人有开三个进程去写一个文件吗?线程吧
|
17
hongch 2020 年 11 月 19 日
一个 APP 只有一个进程啊,难道是开了多个 service 去写同一个文件?
又或者是开了多个线程去写同一个文件? |
19
hdfg159 2020 年 11 月 19 日 via Android
RxJava 做任务编排
|
20
acmore 2020 年 11 月 19 日
|
21
ysy950803 2020 年 11 月 20 日
个人认为这个还是很难避免 3 次跨进程通信,说白了还是需要某种计数的。要说最优雅,我觉得 ContentProvider 就能实现,主进程 observe 进行计数,其他进程任务完成后分别写标识。
此外,也可以利用类似 Handler 这种有消息队列的机制,但是原生 Handler 不是用来跨进程的,不过有人用 Binder 机制实现了跨进程的 Handler,可以谷歌一下。不过利用跨进程 Handler 的话,一样地需要在主进程计数,也避免不了 3 次跨进程通信。 我能想到的减少进程间通信次数办法,可能还是预估延时机制,你这里是写文件,如果可以提前知道写数据的大小,就能预测一个所有任务都完成的大概时间,到时候就不需要跨进程通信了,主进程在 timeout 之后直接去处理生成的文件,如果发现少了 1 个,就说明还有子进程没完成任务,这时候再降级成跨进程监听吧。这种办法对于及时性要求不高的场景我觉得还是可以的,想法可能不成熟。 |
22
ysy950803 2020 年 11 月 20 日
啊为什么 V 站还不支持编辑,我再补充一下吧。其实利用 ContentProvider 配合数据库就挺好,也是最快的实现方式。如果还使用 Room+LiveData 的话,更方便。
|
23
myCupOfTea 2020 年 11 月 20 日
rxjava?
|
24
zpxshl 2020 年 11 月 20 日 via Android
别做这种无聊的事,到线上就会发现,处理边缘 case 比核心代码还多。 子进程挂了咋办?
|
25
okaku 2020 年 11 月 20 日
子进程蛮独特的,还没接触过需要用进程去提高运算速度的案子
|
26
behanga 2020 年 11 月 20 日
FileObserver 了解一下
|
27
StrorageBox 2020 年 11 月 20 日
楼上回复的都什么啊。。。。 你这个情况直接 messager 去做通知,android 里最轻量级的进程间通信了。
|
28
cxxxxx 2020 年 11 月 20 日
kotlin coroutines async
|
29
b1iy 2020 年 11 月 20 日
📢广播.
我感觉题主有点小题大作。 |
30
RikkaW 2020 年 11 月 21 日
如果 ABC 是 Android 世界的进程用 Binder 是最好的
但是不管怎么样,主进程里做计数是跑不掉的( |
31
xierbenq 2020 年 12 月 4 日
建立一个文件夹,子进程做任务时就创建一个文件,做完删掉,主进程监控这个文件夹,不过考虑到子进程各种意外情况死掉,linux flock 也许更合适。
|