怎么跨进程传递大图片
跨进程传大图,有哪些方案?
给图片保存到固定地方,传key给对方
两次IO操作,进程1将图片写到磁盘上,进程2从磁盘读取。大图的话,性能是很差的
通过IPC的方式转发图片数据
Binder:性能很好,方便使用,但是有大小限制
Socket,管道:存在多次copy问题,性能差,也有大小限制
共享内存:性能好
主要看两个指标
1. 性能,减少copy次数
2. 内存泄露,资源及时关闭
跨进程通信是需要buffer的,发送数据需要buffer,返回数据也需要buffer,buffer只有整个transaction结束时才释放,发送数据占用太多buffer的话,留给返回数据的buffer就很少了。事情buffer是吧就会跑TransactionTooLargeException
进程在启动binder机制时会映射一块内存,大小是1M,也就是说跨进程通信时申请缓冲区大小不大于1M,一个事务用太多的话,其他事务可用空间就变少。甚至事情100K都会跑TransactiionToolargeException。
第三条是官方推荐
binder_alloc_buffer: 分配data_size(parcel)大小的内存空间
Bitmap 是如何传输的
上面代码块,如果使用那个intent启动另外一个进程的Activity,会抛出TransactionTooLargeException, 是因为这个bitmap直接copy到缓冲区了,没有里有ashmem机制,因为allowFd机制没有打开
下面代码块不会抛出TransactionTooLargeException
bitmap超过16K时,使用的是匿名共享内存的方式
setAllowFds(false): 禁用了bundle的fd机制,bundle写入parcel时也会禁用parcel的allowFd机制
这两个底层都用到了共享内存 , 适合跨进程大数据传输
网友评论