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();
  }
相关推荐
xmdy58662 小时前
Flutter+开源鸿蒙实战|校园易生活Day1 项目初始化搭建+开发环境校验+工程目录规范+第三方库集成+多端屏幕适配+全局底部导航
flutter·开源·harmonyos
MonkeyKing3 小时前
Flutter国际化与多主题实战:多场景示例,一键适配多语言+多风格
flutter
MonkeyKing3 小时前
iOS设计模式
flutter
xmdy58663 小时前
Flutter+开源鸿蒙实战|校园易生活Day2 第三方库批量集成+全局Toast提示+网络状态监听+首页轮播图+资讯卡片布局
flutter·开源·harmonyos
恋猫de小郭4 小时前
Flutter 3.44 发布前夕,官方宣布 SwiftPM 将完全取代 CocoaPods
android·前端·flutter
张风捷特烈4 小时前
状态管理大乱斗#06 | Riverpod 源码评析 (下) - 外功心法
android·前端·flutter
神奇的程序员13 小时前
开发了一个管理本地开发环境的软件
前端·flutter
xmdy586614 小时前
Flutter+开源鸿蒙实战|智联邻里Day9 系统权限适配+应用全局分享+缓存深度优化+版本更新弹窗
flutter·开源·harmonyos
maaath18 小时前
【maaath】Flutter for OpenHarmony 乐器学习应用开发实战
flutter·华为·harmonyos
maaath1 天前
【maaath】 Flutter for OpenHarmony 实战:电池优化应用开发指南
flutter·华为·harmonyos