MoonBit 本周新增类型标注语法、继续进行核心库 API 整理工作

MoonBit更新

  • 类型标注增加了新的语法T? 来表示Option[T]
struct Cell[T] {
  val: T
  next: Cell[T]?
}

fn f(x : Cell[T]?) -> Unit { ... }

相当于

struct Cell[T] {
  val: T
  next: Option[Cell[T]]
}

fn f(x : Option[Cell[T]]) -> Unit { ... }

旧的Option[T]仍然兼容,但是推荐使用更简短的新语法。moonfmt也会将Option[T]格式化为T?

  • 核心库 API 整理工作继续进行
    • Iter包被合入了builtin包。现在使用Iter[T]不需要@iter.前缀
pub fn any[T](xs : Iter[T], predicate : (T) -> Bool) -> Bool {
                // ^不需要@iter.
  match xs.find_first(predicate) {
    None => false
    Some(_) => true
  }
}
  • Stack包被移入moonbitlang/x
  • 移除了List包,以及各类数据结构的to_listfrom_list函数。对于数据结构间转换和中间的表示结构,推荐使用Iter[T]Array[T]
  • 性能提升
    • 编译器现在会在分离编译的阶段进行一部分的闭包转化,从而改进了编译性能,并且对 JavaScript 后端生成的代码在特定情况下也进行了闭包转化
    • Option[Bool], Option[Char], Option[Byte], Option[Unit] 这些类型使用32位整数表示,其中 None 对应的值为 -1, Some(x) 对应的值为 x; Option[Int] 类型在 wasm 后端使用 64 位整数表示,其中 None 对应的值为 0x1_0000_0000, Some(x) 对应的值为 x, Option[Int]在 JavaScript 后端使用 int | undefined 表示,其中 undefined 表示 None
  • abort行为变更
    • 为了解除Wasm程序对于非标准的spectest.print_char的依赖,正在重构错误输出功能。
    • abort将不会利用spectest.print_char打印错误信息,行为与panic相同,等待功能进一步完善。

插件更新

  • 【语言服务器】修复了内存泄露的问题

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-06-08 02:02:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-08 02:02:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-08 02:02:03       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-08 02:02:03       20 阅读

热门阅读

  1. 【Qt快速入门(二)】- Qt 整体目录结构

    2024-06-08 02:02:03       11 阅读
  2. 深入探讨Qt中的QVariant

    2024-06-08 02:02:03       9 阅读
  3. ChatGPT的基本原理

    2024-06-08 02:02:03       7 阅读
  4. 是时候让临床预测模型进入临床实践

    2024-06-08 02:02:03       9 阅读
  5. Elasticsearch搜索优化-自定义路由规划(routing)

    2024-06-08 02:02:03       9 阅读
  6. Linux系统管理磁盘管理004

    2024-06-08 02:02:03       10 阅读
  7. 【copy_dwg_files.bat】

    2024-06-08 02:02:03       10 阅读
  8. 奇思妙想02-高考

    2024-06-08 02:02:03       12 阅读
  9. 正则表达式入门与实践

    2024-06-08 02:02:03       10 阅读
  10. !力扣3. 无重复字符的最长子串

    2024-06-08 02:02:03       8 阅读
  11. SQL注入二次注入

    2024-06-08 02:02:03       8 阅读