Flutter for OpenHarmony:more 极致算法与数据结构工具集(Dart 官方推荐的高效扩展) 深度解析与鸿蒙适配指南

Flutter for OpenHarmony:more 极致算法与数据结构工具集(Dart 官方推荐的高效扩展) 深度解析与鸿蒙适配指南

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net

在这里插入图片描述

前言

Flutter 和 Dart 的标准库提供了 List, Map, Set 以及基本的 Math 库。这对于普通 APP 开发够用了。
但是,如果你要开发:

  • 一个高性能的游戏引擎(需要位运算、四叉树)。
  • 一个复杂的数据分析工具(需要统计学算法)。
  • 一个缓存系统(需要 LRU 策略)。
  • 一个自定义的解析器(需要字符集处理)。

标准库就显得捉襟见肘了。

more 是 Dart 社区中质量极高的一个工具库(作者是 Google 工程师)。它汇集了大量高效的数据结构、数学算法、迭代器扩展和缓存策略。它的座右铭是“更多功能,更少废话”。

对于 OpenHarmony 应用,尤其是涉及高性能计算或复杂逻辑处理的场景,more 是你不可或缺的军火库。

一、核心功能概览

这个库包含了几十个独立的模块,列举几个最常用的:

  1. Collections: BiMap (双向映射), Multiset (多集), IntegerRange
  2. Cache: LruCache, FifoCache, ExpiryCache
  3. Math: Fraction (分数), Complex (复数), Polynomial (多项式), BitList
  4. CharMatcher: 类似于 Java Guava 的字符匹配器,高效处理字符串。
  5. Printers: 强大的对象打印/格式化工具。

导入

数据结构

算法

工具

文本

Dart 应用

package:more

BiMap, Multiset...

Statistics, Digits...

LRU, Expiry...

字符串处理

二、集成与用法详解

2.1 添加依赖

dependencies:more: ^4.7.0 

2.2 高效缓存 (Caching)

在鸿蒙开发中,为了优化性能,我们经常需要缓存计算结果或网络图片。more 提供了多种策略。

import'package:more/cache.dart';voidmain()async{// 创建一个容量为 100 的 LRU (Least Recently Used) 缓存// 当缓存满时,最近最少使用的数据会被剔除final cache =Cache<String, int>.lru(maxSize:100);// 加载数据 (如果不存在则调用 loader)final value =await cache.get('key',()async{print('正在计算...');return42;});print(value);// 42}
在这里插入图片描述

2.3 双向映射 (BiMap)

有时候我们需要通过 ID 查 Name,也需要通过 Name 查 ID。标准的 Map 只能单向查,BiMap 支持双向。

import'package:more/collection.dart';voidmain(){final bimap =BiMap<int,String>(); bimap[1]='一'; bimap[2]='二';print(bimap[1]);// 一print(bimap.inverse['二']);// 2}
在这里插入图片描述

2.4 迭代器魔法 (Iterables)

moreIterable 添加了大量扩展方法,类似于 RxDart 但同步执行。

import'package:more/iterable.dart';voidmain(){final list =[1,2,3,4,5];// 排列组合print(list.permutations(2));// ((1, 2), (1, 3), ...)// 窗口滑动print(list.window(2));// ([1, 2], [2, 3], [3, 4], [4, 5])// 无限生成器final fib =iterate(0,(a)=> a +1);// 0, 1, 2, ...}
在这里插入图片描述

三、OpenHarmony 适配与实战:本地数据处理

在鸿蒙设备上,有时我们需要在本地处理大量传感器数据或日志,而不需要上传云端。

3.1 场景:数据去重与统计

假设我们从加速度传感器采集了一串数据,包含大量重复值,我们需要统计每个值出现的次数。

import'package:more/collection.dart';voidprocessSensorData(List<int> rawData){// Multiset (即 Bag) 能够记录元素出现的次数final histogram =Multiset<int>(); histogram.addAll(rawData);// 打印出现次数最多的前 3 个值for(final value in histogram.distinct.take(3)){// 需配合排序逻辑print('Value $value -> Count: ${histogram[value]}');}}
在这里插入图片描述

3.2 场景:位图操作 (BitList)

在处理嵌入式协议或图片像素掩码时,List<bool> 太浪费内存了(一个 bool 占一个字节甚至更多)。BitList 用一个 bit 存一个 bool,极致省内存。

import'package:more/collection.dart';voidbitOperations(){// 创建一个包含 1024 位(128 字节)的位图final bits =BitList(1024); bits[10]=true; bits[100]=true;// 高效的位运算print(bits.test(10));// true// bits.setAll(...)}
在这里插入图片描述

四、功能详解:Printer

Printer 是 toString 的替代方案,能够组合式地格式化输出。

import'package:more/printer.dart';voidmain(){final printer =Printer.ofType<int>().padLeft(4,'0')// 补零.around('(',')');// 包裹print(printer(42));// (0042)}
在这里插入图片描述

五、总结

more 库正如其名,给了你更多。它填补了 Dart 基本库在高级数据结构和算法方面的空白。

对于 OpenHarmony 开发者:

  • 如果你在移植 Java (Guava/Commons-Lang) 或 Python 的代码到 Dart,你会发现 more 里有很多熟悉的面孔。
  • 它纯 Dart 实现,无任何平台依赖,是提升代码质量和性能的通用利器。

最佳实践

  1. 按需引入:虽然库包含很多功能,但它模块化做得很好。了解你真正需要的模块(如只用 Cache)。
  2. 性能优先:在处理成千上万条数据时,优先考虑 more 提供的数据结构(如位图、特定集合),可能会带来数量级的性能提升。

六、完整实战示例

import'package:more/collection.dart';import'package:more/math.dart';voidmain(){print('=== 数据统计算法 ===');// 模拟一组实验数据final data =[10,12,10,14,12,10,15,20];// 1. 统计频率 (Multiset)// 能够快速计算众数、频次final counts =Multiset<int>.from(data);// 找出出现次数最多的数字final mode = counts.distinct.reduce((a, b)=> counts[a]> counts[b]? a : b);print('数据: $data');print('众数 (Mode): $mode');print('数字 10 出现了 ${counts[10]} 次');print('\n=== 位操作 (BitList) ===');// 场景:签到系统,一年 365 天,每天只占 1 bit,极致省内存final checkIns =BitList(365); checkIns[0]=true;// 第1天签到 checkIns[5]=true;// 第6天签到print('由于存储压缩,365天签到数据仅占用: ${checkIns.length ~/8+1} 字节');print('第6天是否签到: ${checkIns[5]}');print('总签到天数: ${checkIns.count(true)}');print('\n=== 排列组合 (Combinations) ===');final teams =['红队','绿队','蓝队','黄队'];// 生成所有可能的两两对战组合 (C(n, 2))final matches = teams.combinations(2);print('赛程表:');for(var match in matches){print('${match.first} vs ${match.last}');}}
在这里插入图片描述

Read more

前端大数据导出优化:解决Chrome内存崩溃的实战方案

前端大数据导出优化:解决Chrome内存崩溃的实战方案

个人名片 🎓作者简介:java领域优质创作者 🌐个人主页:码农阿豪 📞工作室:新空间代码工作室(提供各种软件服务) 💌个人邮箱:[[email protected]] 📱个人微信:15279484656 🌐个人导航网站:www.forff.top 💡座右铭:总有人要赢。为什么不能是我呢? * 专栏导航: 码农阿豪系列专栏导航 面试专栏:收集了java相关高频面试题,面试实战总结🍻🎉🖥️ Spring5系列专栏:整理了Spring5重要知识点与实战演练,有案例可直接使用🚀🔧💻 Redis专栏:Redis从零到一学习分享,经验总结,案例实战💐📝💡 全栈系列专栏:海纳百川有容乃大,可能你想要的东西里面都有🤸🌱🚀 目录 * 前端大数据导出优化:解决Chrome内存崩溃的实战方案 * 引言 * 问题分析 * 1. 为什么 Chrome 会崩溃,而 QQ 浏览器正常? * 2. 常见崩溃场景

By Ne0inhk

JavaWeb学习笔记:动静态Web、URL、HTTP

Web Web是在互联网上,用浏览器访问的一种信息服务。可以简单理解成,我们打开一个网络链接,展示的一个个网页,就是Web。 Web有动态Web和静态Web: * 静态Web:是指开发者提前写好Web网页(HTML),所有人看到的网页内容都是一样的Web。早期的Web是静态Web,是使用HTML将网页内容写好放在服务器中,所有人访问网页,都是看到这个HTML的内容。静态Web的特点是所有人看到相同的内容,网页内容、数据都是写在HTML里,不与数据库交互。静态Web的业务流程大致如下: * Web开发者编写好HTML,保存到服务器某目录。 * 用户从浏览器打开网页,比如www.xxxx.com/index.html。 * 服务器接受到请求,从文件目录中找到这个index.html文件,发送给用户。 * 用户浏览器接收到HTML,渲染成网页展示给用户。 * 动态Web:是指开发者并非提前写好Web网页,而是在用户访问时,动态生成网页HTML内容,每个人看到的网页内容都是不一样的Web。现代Web几乎都是动态Web,每个人看到的Web内容都可能不一样,比如有

By Ne0inhk

如何零成本实现Web实时推送?轻量级解决方案全解析

如何零成本实现Web实时推送?轻量级解决方案全解析 【免费下载链接】EventSourcea polyfill for http://www.w3.org/TR/eventsource/ 项目地址: https://gitcode.com/gh_mirrors/ev/EventSource 在现代Web开发中,实时数据更新已成为提升用户体验的关键需求。EventSource Polyfill作为一款基于W3C标准Server-Sent Events(SSE)技术的浏览器兼容库,通过提供统一接口解决了不同浏览器对原生EventSource支持不一致的问题,让开发者能以最小成本实现高效的服务器到客户端实时数据推送,兼顾浏览器兼容性与开发效率双重优势。 🔥 问题篇:传统实时推送方案的三大痛点 延迟问题:轮询技术的固有缺陷 传统轮询技术通过定期发送HTTP请求获取数据,存在明显的延迟问题。例如每30秒轮询一次的系统,用户最多可能等待30秒才能看到新数据,这种延迟在实时通讯场景中难以接受。 资源占用:无效请求的性能损耗 长轮询虽然比普通轮询有所改进,但仍然会产生大量无效请求。当

By Ne0inhk
【征文计划】玩转 Rokid JSAR:基于 Web 技术栈的 AR 开发环境搭建、核心 API 应用与 3D 时钟等创意项目全流程解析

【征文计划】玩转 Rokid JSAR:基于 Web 技术栈的 AR 开发环境搭建、核心 API 应用与 3D 时钟等创意项目全流程解析

【征文计划】玩转 Rokid JSAR:基于 Web 技术栈的 AR 开发环境搭建、核心 API 应用与 3D 时钟等创意项目全流程解析 前言 随着 AR 技术在消费级场景的普及,开发者对 “低门槛、高兼容” AR 开发工具需求愈发迫切,传统 AR 开发往往依赖专属引擎或复杂语法,导致 Web 开发者难以快速切入,而 Rokid 推出的 JSAR 技术,恰好打破了这一壁垒:以 “可嵌入空间的 Web 运行时” 为核心,让开发者无需学习新的开发范式,仅用 JavaScript/TypeScript 等熟悉的 Web 技术栈,就能快速开发出支持 3D 物体、

By Ne0inhk