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();
  }
相关推荐
ujainu1 小时前
Flutter + OpenHarmony 实现经典打砖块游戏开发实战—— 物理反弹、碰撞检测与关卡系统
flutter·游戏·openharmony·arkanoid·breakout
微祎_1 小时前
构建一个 Flutter 点击速度测试器:深入解析实时交互、性能度量与响应式 UI 设计
flutter·ui·交互
王码码20351 小时前
Flutter for OpenHarmony 实战之基础组件:第二十七篇 BottomSheet — 动态底部弹窗与底部栏菜单
android·flutter·harmonyos
ZH15455891312 小时前
Flutter for OpenHarmony Python学习助手实战:Web开发框架应用的实现
python·学习·flutter
晚霞的不甘2 小时前
Flutter for OpenHarmony 构建简洁高效的待办事项应用 实战解析
flutter·ui·前端框架·交互·鸿蒙
百锦再2 小时前
Vue高阶知识:利用 defineModel 特性开发搜索组件组合
前端·vue.js·学习·flutter·typescript·前端框架
廖松洋(Alina)3 小时前
【收尾以及复盘】flutter开发鸿蒙APP之成就徽章页面
flutter·华为·开源·harmonyos·鸿蒙
ZH15455891313 小时前
Flutter for OpenHarmony Python学习助手实战:机器学习算法实现的实现
python·学习·flutter
廖松洋(Alina)3 小时前
【收尾以及复盘】flutter开发鸿蒙APP之打卡日历页面
flutter·华为·开源·harmonyos·鸿蒙
廖松洋(Alina)3 小时前
【收尾以及复盘】flutter开发鸿蒙APP之本月数据统计页面
flutter·华为·开源·harmonyos·鸿蒙