本文主要是介绍MoonBit 本周有超多重磅更新:零开销迭代,动态数组模式匹配完美支持,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
MoonBit更新
- 标准库里添加了 Iter 类型,该类型可以高效地对容器中的元素的进行访问,并且将访问过程优化成循环,使用方式比如:
test "iter" {let sum = Iter::[1, 2, 3, 4, 5, 6].filter(fn { x => x % 2 == 1 }).take(2).map(fn { x => x * x}).reduce(fn (x, y) { x + y }, 0)inspect(sum, content="10")?
}
- 标准库里添加了VecView类型,可以使用如下方式对
Vec[T]类型的值取它的VecView[T]。
test "view" {let v = Vec::[1, 2, 3, 4, 5]let vv1 = v[..]let vv2 = v[1..]let vv3 = v[..4]let vv4 = v[1..4]inspect(vv1, content="VecView::[1, 2, 3, 4, 5]")?inspect(vv2, content="VecView::[2, 3, 4, 5]")?inspect(vv3, content="VecView::[1, 2, 3, 4]")?inspect(vv4, content="VecView::[2, 3, 4]")?
}
- array pattern支持
[a, .. as rest, b]形式,其中rest会绑定到一个VecView,例如:
test "view_pattern" {fn is_palindrome(s: VecView[Int]) -> Bool {match s {[] => true[_] => true[x, .. as rest, y] => x == y && is_palindrome(rest)}}let v1 = Vec::[1, 2, 3, 4, 5]@assertion.assert_false(is_palindrome(v1[..]))?let v2 = Vec::[1, 2, 3, 2, 1]@assertion.assert_true(is_palindrome(v2[..]))?
}
- 标签参数调用时允许省略标签里的波浪线
~,例如:
inspect(1, content="1")
- 构造器支持带标签的参数:
pub enum Tree[X] {NilBranch(X, ~left : Tree[X], ~right : Tree[X])
}pub fn leftmost[X](self : Tree[X]) -> Option[X] {loop self {Nil => None// 使用 `label=pattern` 来匹配构造器的带标签参数Branch(top, left=Nil, right=Nil) => Some(top)// `label=label` 可以简写成 `~label`Branch(_, left=Nil, ~right) => continue right// 可以用 `..` 来忽略所有剩余的带标签参数Branch(_, ~left, ..) => continue left}
}fn init {// 创建带标签的构造器的语法和调用带标签的函数一样let t: Tree[Int] = Branch(0, right=Nil, left=Branch(1, left=Nil, right=Nil))println(t.leftmost()) // `Some(1)`
}
- 可选参数的默认值可以依赖前面的参数,例如:
fn f(~x: Int = 1, ~y: Int = x) -> Int {x + y
}
- Byte字面量支持八进制转义。

IDE更新
-
IDE 支持本地环境的 test codelens;支持expect test的自动更新。

-
修复在线 IDE 在 Windows 上找不到 core 的问题。
-
支持识别
test_import和*_test.mbt文件。
工具链更新
-
moonfmt
- 修复了
String和Char字面量中的转义序列没有被正确格式化的问题; - 调整针对
{ ..record }的格式化。
- 修复了
-
moon info和moon coverage现已支持 Windows。 -
moon info支持在不引起歧义时缩短类型名称,使得生成结果更加干净:- 在没有同名类型定义的时候隐藏 builtin 的包名前缀;
- 在没有歧义时使用包名的最后一部分代替完整的包名。
更新前:
package moonbitlang/core/map// -- snip --type Map
fn Map::debug_write[K : @moonbitlang/core/builtin.Debug, V : @moonbitlang/core/builtin.Debug](Map[K, V], @moonbitlang/core/builtin.Buffer) -> Unit
fn Map::keys_set[K : @moonbitlang/core/builtin.Compare + @moonbitlang/core/builtin.Eq, V](Map[K, V]) -> @moonbitlang/core/immutable_set.ImmutableSet[K]
fn Map::lookup[K : @moonbitlang/core/builtin.Compare + @moonbitlang/core/builtin.Eq, V](Map[K, V], K) -> Option[V]
fn Map::to_vec[K, V](Map[K, V]) -> @moonbitlang/core/vec.Vec[Tuple[K, V]]
更新后:
package moonbitlang/core/mapalias @moonbitlang/core/immutable_set as @immutable_set
alias @moonbitlang/core/vec as @vec// -- snip --type Map
fn Map::debug_write[K : Debug, V : Debug](Map[K, V], Buffer) -> Unit
fn Map::keys_set[K : Compare + Eq, V](Map[K, V]) -> @immutable_set.ImmutableSet[K]
fn Map::lookup[K : Compare + Eq, V](Map[K, V], K) -> Option[V]
fn Map::to_vec[K, V](Map[K, V]) -> @vec.Vec[Tuple[K, V]]
构建系统更新
moon test添加测试过滤相关选项:
-p, --package <PACKAGE_NAME> Run test in the specified package
-f, --file <FILE> Run test in the specified file, only valid when --package is specified
-i, --index <INDEX> Run the index-nth test in the specified file, only valid when --file is specified
命令示例:moon test -p username/hello/A -f hello.mbt -i 0 (运行 username/hello/A 包中 hello.mbt 文件中的第 0 个 test block);-f 和 -i 分别在指定 -p 和 -f 时才有效;如果不指定 -f 则运行 -p 指定包中所有测试,不指定 -i 则运行 -f 指定文件中所有测试。
-
moon check|build|test添加--sort-input选项,用于生成稳定的构建顺序。 -
expect test 生成的
~content=省略~,变更为content=。
这篇关于MoonBit 本周有超多重磅更新:零开销迭代,动态数组模式匹配完美支持的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!