我同一台手机两个 APP,A 和 B,他们通过 SOCKET 通信,A 是客服端,B 是服务端
A 要发送一个长度为 90,0000 的 int[] 给 B
SOCKET 不能直接发送 int[],要转成 byte[]才能发送。
由于数据量大,把长度为 90,0000 的 int[]转成 byte[]大概要 35ms
由于特殊原因我不想浪费这 35ms 。
另外,B 端因为最终需要使用的是 int[],A 把 int[]转成 byte[]再发送
B 接收到 byte[]还得转回 int[],也是需要 35ms
等于白白浪费了 70ms 。
有没有什么办法,能让 B 快速获取到 A 的 int[]呢?
也不是非得用 SOCKET 不可,只要能让 B 快速获取到 A 的 int[]就行了
A 的 int[]是不固定的
各位 V 友有办法吗?
1
wellwell 2020-05-20 10:00:56 +08:00
蛤 还能不用 socket 通信的办法?
|
3
hyperion1 2020-05-20 10:04:56 +08:00 via iPhone
共享内存
|
4
optional 2020-05-20 10:05:29 +08:00 via Android
压缩一下,如果你的 int 高位很多 0,转成 byte 之后压缩空间巨大
|
5
pursuer 2020-05-20 10:12:03 +08:00 via Android
bytebuffer 设置小端字节序试试
|
6
islxyqwe 2020-05-20 10:13:09 +08:00
按流发啊,一边转换一边发,而不是一次全转了,等转完再发。找找对应的 API 吧
|
7
Kamiyu0087 2020-05-20 10:22:43 +08:00
int[] 内的值都是在 byte 范围内的还是有有超过一个 byte 大小的?
如果有超过一个 byte 大小的,那只能先转 byte[] 啊 |
8
windplume 2020-05-20 10:30:25 +08:00
共享内存
|
9
Rheinmetal 2020-05-20 10:30:48 +08:00
同一台手机的话倒是可以 不过不能用 socket 了 不清楚性能如何 应该快一点把
https://devarea.com/android-creating-shared-memory-using-ashmem/ |
10
atfeel OP @Kamiyu0087 int[]里面保存的是图片的颜色,A 通过
int[] rgbdata = new int[screenWidth * screenHeight]; bitmap.getPixels(rgbdata, 0, screenWidth, 0, 0, screenWidth, screenHeight); 取到的 |
12
resist 2020-05-20 10:39:56 +08:00
难道不是转换一点发一点吗?
|
13
atfeel OP @windplume 内存共享是指 MemoryFile ?这个方法,还是要将 intt[]转成 byte[]才行,这个还是避免不了 浪费 70ms 的时间
|
14
atfeel OP @resist 现在不是发的问题,socket 发 90,0000 的长度,在本地是很快的,但是我要发的是 int[],把它转成 byte[]费时,接收端还要还原成 int[]
|
15
movistar 2020-05-20 10:50:55 +08:00 via iPhone
如果你确定耗时是在 int 转 byte 这个流程里
而不是创建 byte 数组的流程里 那是有解决方案的 通过 unsafe 获取到数组的指针,然后根据长度直接把整段数据 copy 到 byte 数组里面即可,可以不转换就是整块 copy 。 可以节省转换的时间。但是创建数组的开销还是有的,还有一次 copy 开销。 |
16
xiangyuecn 2020-05-20 10:55:09 +08:00
负优化? 4 字节*900_000≈3M 数据量,你折腾这几十毫秒,还不如用 gzip 压缩一下,压到 1M,网络传输节省的时间瞬间少 2/3
|
17
tanranran 2020-05-20 11:02:15 +08:00
Cap'n Proto ?
|
18
guchengyehai1 2020-05-20 13:11:00 +08:00 via Android
getPixels 获取到的颜色信息是存在一块内存中,Bitmap 里面应该有指针信息,你可以把这块内存东西用共享内存传输,参照 Linux mmap API
|
19
aguesuka 2020-05-20 13:12:10 +08:00 via Android
不要使用数组,自定义一个 IntArray 接口,实现 get(int) set(int, int)操作。用 ByteBuffer 作为实现
|
20
imkujio 2020-05-20 15:02:07 +08:00
我能想到的两种解决思路:
1.数据优化,使用其他体积更小处理速度更快的形式存储。可以在 S 端数据边产生边转换。 2.分段传输,将数据拆分,具体看 A 端对数据的处理顺序合理进行分段,边传输边转换 |
21
miaoxia 2020-05-20 16:13:52 +08:00
1. AIDL 直接传 int[]
2. 分包传 |
24
LLaMA2 2020-05-29 09:43:00 +08:00
我有个疑惑,int -> byte 难道不会有精度丢失?
楼上有很多套路都是好套路, 想简单点就用文件,两边同时操作,一边只读一边只写。 |