PDX Utopia区块链协议栈已正式支持eWASM智能合约

PDX Utopia区块链协议栈,正式支持eWASM智能合约。具体请见:

https://github.com/PDXbaap/ewasm-rust-demo/blob/master/README.md

来源:PDX

ewasm (Ethereum)

ewasm 不是一个智能合约开发语言,而是一个编译器的生成目标,它允许以太坊开发者使用其他语言(例如 Rust、C++等)开发智能合约并编译为以太坊接受的WebAssembly。

ewasm 是 WebAssembly 的一个安全子集,它是 web 平台上相对新出现的编译目标。方便的是,wams(以及 ewasm) 模块可以在任何 JavaScript 项目中使用。对于大多数区块链代码来说,通常 75% 以上的代码根本都不是智能合约 —— 而是使用JavaScript 与智能合约进行通信的代码。ewasm 和 JavaScript 使用同样的绑定和模块支持机制。

什么是WebAssembly

wasm是可以在stack-based虚拟机上运行的一种二进制指令格式,设计的首要目标是性能,很适合用在区块链项目中。

WebAssembly二进制代码(wasm格式)可以转换成一种中间表示,一种可读的AST(抽象语法树,wast格式),这种可读的中间表示方便了编写和调试。

对扩展性的改进:wasm支持module import/export功能,可以将扩展部分做成module,在项目中导入。

WebAssembly的优势

1.可扩展性好

2.32/64位的操作符

3.支持更多的高级语言(C,Rust,Go等)

4.由W3C领导,Google,Apple,MicroSoft等大公司支持,更广阔的社区

主流浏览器支持,已有项目支持在非浏览器环境运行(wabt,wavm等)

EVM2.0对比EVM1.0的优势

1.性能更好

2.可扩展性好

3.开发合约更容易,支持更多语言和工具

4.合约开发规范

ewasm 合约接口规范由以太坊定制,指定模块结构等信息,PDX Utopia 严格遵循此规范,具体如下

1.数据类型

2.禁止使用浮点数,兼容 evm 中规定的数据类型,例如:

bytes : 不定长字节数组

address : 160 bit 数字,在内存中以 20字节 小字节无符号整型表示

u128 : 128 bit 数字,在内存中以 16字节 小字节无符号整型表示

u256 : 256 bit 数字,在内存中以 32字节 小字节无符号整型表示

格式

每个合约必须存储为 wasm 字节码

导入模块

规定合约 import 的范围仅限于 EEI 提供的模块,ethereum 名称空间以外的包只允许使用 debug ,在生产环境中 debug 也应被禁止使用

导出函数

每个合约必须导出两个函数(只能导出两个函数)

memory : 可供 EEI 写入的共享内存

main : 一个入口函数,没有参数也没有返回值,将被 VM 执行

要关闭 wasm 的 start function 功能,开启它会影响 ewasm 在启动前获取合约内存地址指针的功能

关于 ABI

我们看到有关导出函数的规定与 solidity 合约中定义的 ABI 有些不一样,solidity 合约根据方法签名来生成相应的 ABI 以便对合约中的函数进行调度,这在 ewasm 看来似乎行不通,因为只有一个 main 函数被导出了, 如何使用 main 函数之外的函数呢?我们很自然就想到了使用合约的 input 来 定义目标方法和输入参数,事实上 solidity 也是这么做的,只是我们把这个灵活性 交还给开发者实现,以统一的 main 函数作为入口,然后自行封装 input 序列化方案,solidity 使用了 rlp 序列化 input , 在后面的例子中我们可以看到更加灵活的方式。

PDX Utopia区块链协议栈,正式支持eWASM智能合约。具体请见: https://github.com/PDXbaap/ewasm-rust-demo/blob/master/README.md

Ewasm能提供可执行的二进制格式、非常类似于传统计算机的体系架构、高效且支持多种编程语言及开发者工具,还能够向后兼容EVM,因此Ewasm是以太坊智能合约的未来。

你可能感兴趣的:(PDX Utopia区块链协议栈已正式支持eWASM智能合约)