vlang
  • 目录
    • V语言学习笔记
    • 目录
    • 安装
    • 开发工具
    • 快速总览
    • 模块
    • 基本类型
    • 变量
    • 常量
    • 枚举
    • 数组
    • 字典
    • 流程控制
    • 函数
    • 结构体
    • 访问控制
    • 方法
    • 注解
    • 接口
    • 泛型
    • 类型别名
    • 联合类型
    • 联合体
    • 错误处理
    • 运算符重载
    • 内置json支持
    • 内置sql支持
    • 并发
    • 内存管理
    • 代码测试
    • 文档生成
    • 编译时代码
    • 包管理器
    • 单个V文件
    • V shell script
    • 不安全代码
    • 集成C代码库
    • 集成汇编代码
    • 裸机环境
    • 生成wasm
    • GUI开发
    • web开发
    • 数据库开发
  • builtin
  • strings
  • arrays
  • maps
  • datatypes
  • strconv
  • os
  • runtime
  • time
  • math
  • json
  • encoding
  • compress
  • toml
  • flag
  • term
  • log
  • io
  • readline
  • reflection
  • net
  • net.http
  • eventbus
  • regex
  • crypto
  • rand
  • sync
  • x
  • db.pg
  • db.mysql
  • db.mssql
  • db.sqlite
  • orm
  • ui
  • sokol
  • gg
  • gx
  • fontstash
  • stbi
  • clipboard
  • V抽象语法树
  • V语言服务
  • V编译器源代码
  • 生成C代码
  • 生成js代码
  • 生成go代码
  • 生成native代码
  • 解释器直接运行
  • 附录1 关键字
  • 附录2 运算符
  • 附录3 编码风格
  • 附录4 V编译器命令行使用
  • 附录5 V调试及错误定位
  • 附录6 V和Go基本语法参照
  • 附录7 V和Zig基本语法参照
由 GitBook 提供支持
在本页
  • 安装依赖
  • 编译目标系统

这有帮助吗?

  1. 目录

生成wasm

上一页裸机环境下一页GUI开发

最后更新于2年前

这有帮助吗?

V编译器支持wasm后端,将V源代码编译生成wasm代码。

安装依赖

当第一次运行 v -b wasm xxx.v时,编译器会提示,缺少外部依赖库,需要先执行脚本下载对应平台的预编译版本。安装脚本会下载并解压到path_to_v/thirdparty/binaryen目录中。

path_to_v/cmd/tools/install_binaryen.vsh

也可以直接下载binaryen源代码,自行编译,编译步骤如下:

git clone https://github.com/WebAssembly/binaryen.git
git submodule init
git submodule update
cmake . && make #需要提前安装好cmake
make install

编译目标系统

v -b wasm -os wasi #编译为符合wasi标准的代码,不特别指定-os选项值,默认是wasi
v -b wasm -os browser #编译为浏览器环境的代码

示例代码:

mandelbrot.v

fn JS.canvas_x() int
fn JS.canvas_y() int
fn JS.setpixel(x int, y int, c f64)

// `main` must be public!
pub fn main() {
	max_x := JS.canvas_x()
	max_y := JS.canvas_y()

	println('starting main.main!')

	mut y := 0
	for y < max_y {
		y += 1
		mut x := 0
		for x < max_x {
			x += 1

			e := (f64(y) / 50) - 1.5
			f := (f64(x) / 50) - 1.0

			mut a := 0.0
			mut b := 0.0
			mut i := 0.0
			mut j := 0.0
			mut c := 0.0

			for i * i + j * j < 4 && c < 255 {
				i = a * a - b * b + e
				j = 2 * a * b + f
				a = i
				b = j
				c += 1
			}

			JS.setpixel(x, y, c)
		}
	}

	panic('reached the end!')
}

mandelbrot.html

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<meta http-equiv="X-UA-Compatible" content="IE=edge">
	<meta name="viewport" content="width=device-width, initial-scale=1.0">
	<title>V Mandelbrot WebAssembly Example</title>
</head>
<body>
	<canvas id="canvas" width="200" height="200" style="width:100%;height:100%;image-rendering: crisp-edges;"></canvas>
	<script>
		var canvas = document.getElementById("canvas");
		var ctx = canvas.getContext("2d");
		var memory;

		function get_string(ptr, len) {
			const buf = new Uint8Array(memory.buffer, ptr, len);
			const str = new TextDecoder("utf8").decode(buf);

			return str
		}

		const env = {
			canvas_x: () => canvas.width,
			canvas_y: () => canvas.height,
			setpixel: (x, y, c) => {
				ctx.fillStyle = "rgba(1,1,1,"+(c/255)+")";
				ctx.fillRect(x, y, 1, 1);
			},
			__writeln: (ptr, len) => {
				console.log(get_string(ptr, len))
			},
			__panic_abort: (ptr, len) => {
				throw get_string(ptr, len);
			}
		}

		WebAssembly.instantiateStreaming(fetch("mandelbrot.wasm"), {env: env}).then((res) => {
			memory = res.instance.exports['memory'];
			
			console.time('main.main')
			res.instance.exports['main.main']()
			console.timeEnd('main.main')
		});
	</script>
</body>
</html>

编译生成wasm文件:

v -b wasm -os browser mandelbrot.v

就可以打开mandelbrot.html运行wasm文件。

binaryen