- 在flutter使用tcp请求服务器的时候,在listen中对tcp流进行解析,解析过程包含拆包和拼包,正常情况下都没有问题,但是当服务器推送的流过快的时候,导致UI卡死,有人有好的建议吗?
- 代码如下:
Future<Socket> _connect(String ip, int port) async{ if(!isConnect()) { try { _socket = await Socket.connect(ip, port, timeout: Duration(seconds: 20),); _socket.listen(_onData, onError: _onError, onDone: _onDone); }catch(e){ if(e is SocketException){ _onTimeout(); }else{ print("error : $e"); } } } return _socket; }
_onData中是一些拼包拆包的业务逻辑,当tcp流包含多个业务报文的时候,onData中会循环拆分包直至拆分完成,每个包都会回调到具体的业务逻辑。。现在问题是,如果服务器发送的是base64图片的话,系统就会卡死,请问 下这个问题怎么解决?
flutter中使用socket导致UI卡顿?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- Hirabbit_jaden 2019-04-04 08:46关注
问题解决了,我发现在release模式下才会卡顿,在debug模式下不会卡顿。
因为服务器那边会通过tcp一直推送图片,然后每个tcp报文在release模式下大概为1800000个长度的List,而debug模式下每个报文为500000的List长度,图片大概是150000的长度,因此,每次要对报文进行拆包操作
,用到List.sbulist和addall这两个api,如果报文太大的话,这两个会耗时较长,导致下一个包没有及时收取,会导致卡顿。。
我的解法是,对每个数据list进行拆分处理,拆分成static const int SOCKET_LENGTH = 1024 * 256这么长的小段,然后对小段进行拆包拼包处理。
总结就是sublist 和 addall在list长度较长的时候效率极低,我的优化是不直接处理原始包,先把原始包拆分为中包,然后在依次拼接这些中包来读取图片数据。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 能给我一些人生建议吗
- ¥15 mac电脑,安装charles后无法正常抓包
- ¥18 visio打开文件一直显示文件未找到
- ¥15 请教一下,openwrt如何让同一usb储存设备拔插后设备符号不变?
- ¥30 使用quartz框架进行分布式任务定时调度,启动了两个实例,但是只有一个实例参与调度,另外一个实例没有参与调度,不知道是为什么?请各位帮助看一下原因!!
- ¥50 怎么获取Ace Editor中的python代码后怎么调用Skulpt执行代码
- ¥30 fpga基于dds生成幅值相位频率和波形可调的容易信号发生器。
- ¥15 R语言shiny包和ncdf4包报错
- ¥15 origin绘制有显著差异的柱状图和聚类热图
- ¥20 simulink实现滑模控制和pid控制对比,提现前者优势