flutter实践:Isolate应用实例二

需求:尝试将Isolate封装一层便于直接使用

实现:

1.定义一个封装类

Dart 复制代码
class TdxIsolate {
  //创建一个isolate
  Isolate? newIsolate;
  //新isolate发送器
  SendPort? childSender;
  //存放结果集
  List results = [];

  //构造方法
  TdxIsolate() {
    //初始化isolate 
    createIsolate();
  }

  void dispose() {
    //界面销毁时一定要释放资源
    newIsolate?.kill(priority: Isolate.immediate);
  }
}

2.消息传递

在 Dart 中,Isolate 之间的消息传递是通过 SendPortReceivePort 来实现的。

SendPortReceivePort 是 Dart 中进行进程间通信的工具。

你可以通过 SendPort 发送消息,然后在对应的 ReceivePort 中接收消息。

当你创建一个 ReceivePort 时,它将自动生成一个与之关联的 SendPort。

Dart 复制代码
// 初始化,创建isolate
  Future<void> createIsolate() async {
    //主Isolate的ReceiverPort
    ReceivePort mainReceive = ReceivePort();
    newIsolate =
        await Isolate.spawn<SendPort>(childSearch, mainReceive.sendPort);//主Receive的sendPort传到新Isolate
    //返回的第一个消息
    childSender = await mainReceive.first;
    //关闭
    mainReceive.close();
  }
Dart 复制代码
// 新Isolate的方法,负责处理数据解析
  static childSearch(SendPort mainSendPort) {
    //新Isolate的ReceivePort
    ReceivePort childReceivePort = ReceivePort();
    //新Isolate的sendPort传回主Isolate
    mainSendPort.send(childReceivePort.sendPort);
    // 监听子Isolate的传送装置,等待主isolate叫子Isolate处理数据
    childReceivePort.listen((package) async {
      MessagePackage _msg = package as MessagePackage;
      var sStr = _msg.msg["keys"];
      var aData = _msg.msg["data"];
      _msg.sender.send(getSearchResults(sStr, aData));
    });
  }
Dart 复制代码
//耗时操作,遍历数据
static List getSearchResults(String searchStr, List data) {
    if (searchStr.isEmpty) {
      return [];
    }
    List<List<Map<int, int>>> results = [];
    for (var i = 0; i < data.length; i++) {
      var item = data[i];
      if (item is Map) {
        List<Map<int, int>> rowList = [];
        var j = 0;
        for (var key in item.keys) {
          var temp = item[key] is String ? item[key] : item[key].toString();
          if (temp.contains(searchStr)) {
            Map<int, int> row = {};
            row[i] = j;
            rowList.add(row);
          }
          j++;
        }
        if (rowList.isNotEmpty) {
          results.add(rowList);
        }
      }
    }
    return results;
  }
}

3.定义一个Message

Dart 复制代码
class MessagePackage {
  SendPort sender; // 临时发送器
  dynamic msg; // 消息
  MessagePackage(this.sender, this.msg);
}

4.开启isolate处理

Dart 复制代码
isolateSearch(String searchStr, List allData) async {
    results.clear();
    if (searchStr.isEmpty) {
      return;
    }
    var data = {"keys": searchStr, "data": allData};
    ReceivePort _temp = ReceivePort();
    //新Isolate的sendPort发送消息给listen监听
    childSender!.send(MessagePackage(_temp.sendPort, data));
    //监听里处理完后返回数据到_temp
    await _temp.first.then((value) {
      results = value;
    });
    _temp.close();
  }
相关推荐
problc7 小时前
Flutter中文字体设置指南:打造个性化的应用体验
android·javascript·flutter
lqj_本人15 小时前
鸿蒙next选择 Flutter 开发跨平台应用的原因
flutter·华为·harmonyos
lqj_本人18 小时前
Flutter&鸿蒙next 状态管理框架对比分析
flutter·华为·harmonyos
起司锅仔1 天前
Flutter启动流程(2)
flutter
hello world smile1 天前
最全的Flutter中pubspec.yaml及其yaml 语法的使用说明
android·前端·javascript·flutter·dart·yaml·pubspec.yaml
lqj_本人1 天前
Flutter 的 Widget 概述与常用 Widgets 与鸿蒙 Next 的对比
flutter·harmonyos
iFlyCai1 天前
极简实现酷炫动效:Flutter隐式动画指南第二篇之一些酷炫的隐式动画效果
flutter
lqj_本人1 天前
Flutter&鸿蒙next 中使用 MobX 进行状态管理
flutter·华为·harmonyos
lqj_本人1 天前
Flutter&鸿蒙next 中的 setState 使用场景与最佳实践
flutter·华为·harmonyos
hello world smile1 天前
Flutter常用命令整理
android·flutter·移动开发·android studio·安卓