打字猴:1.703877908e+09
1703877908 在前一章中,我们用Hooked-Web3-Provider向交易中添加nonce。不幸的是,Hooked-Web3-Provider尝试得到nounce的方法并不正确。它为每个账户维护一个计数器,每次从该账户发送交易就增加计数。但如果交易是非法的(例如,如果交易尝试发送比账户内更多的以太币),它并不能减少计数。因此直到Hooked-Web3-Provider被重置(即客户端被重置),该账户的其他交易都在排队且不会被挖。如果创建多个Hooked-Web3-Provider实例,则这些实例不能彼此同步账户的nonce,所以最终的nonce结果可能是错的。但是在向交易添加nonce之前,Hooked-Web3-Provider得到的总是到待定区块的交易计数器,并使用与计数器相比较大的那一个。所以如果来自于Hooked-Web3-Provider管理的一个账户的交易是网络中的另一个节点发送的,并被待定区块接纳,则Hooked-Web3-Provider能看到它。但是不能依赖整个Hooked-Web3-Provider计算nonce。这对于客户端应用原型机制造很有益处,并适合在如果没有向网络广播交易且Hooked-Web3-Provider经常重置用户,就可以看到和重新发送交易的应用中使用。例如,在钱包服务中,用户将频繁地上载页面,所以经常创建新的Hooked-Web3-Provider实例。如果交易没有被广播、不合法或者没有被挖出,那么用户可以更新页面并重新发送交易。
1703877909
1703877910
1703877911
1703877912
1703877913 区块链项目开发指南 [:1703875357]
1703877914 区块链项目开发指南 6.2 solcjs概述
1703877915
1703877916 solcjs是用于编译solidity文件的node.js库和命令行工具。它不使用solc命令行编译器,而是纯粹使用JavaScript进行编译,因此它的安装比solc简单得多。
1703877917
1703877918 Solc是真实的solidity编译器,用C++编写。C++代码使用emscripten被编译成JavaScript。Solc的每一个版本都被编译成JavaScript。访问https://gIthub.com/ethereum/solc-bin/tree/gh-pages/bin,可以发现每个solidity版本的以JavaScript为基础的编译器。solcjs仅使用这些编译器中的一种来编译solidity源代码。这些编译器在浏览器和node.js环境中都可以运行。
1703877919
1703877920
1703877921 solidity的浏览器使用这些以JavaScript为基础的编译器编译solidity源代码。
1703877922
1703877923
1703877924
1703877925
1703877926 区块链项目开发指南 [:1703875358]
1703877927 区块链项目开发指南 6.2.1 安装solcjs
1703877928
1703877929 solcjs可以作为solc的npm包使用。和其他npm包一样,solcjs npm包可以在本地或者全局安装。如果包安装在全局,则命令行工具solcjs可用。因此,为了安装命令行工具,运行如下命令:
1703877930
1703877931
1703877932
1703877933
1703877934 接着运行如下命令,看看如何用命令行编译器编译solidity文件:
1703877935
1703877936
1703877937
1703877938
1703877939 我们不学习solcjs命令行工具,而是学习用solcjs API编译solidity文件。
1703877940
1703877941
1703877942 solcjs默认使用的编译器版本与其自身版本匹配。例如,如果安装solcjs的0.4.8版本,则将默认使用0.4.8编译器版本进行编译。也可以配置solcjs,以使用一些其他的编译器版本。在写本书之时,solcjs的最新版本是0.4.8。
1703877943
1703877944
1703877945
1703877946
1703877947 区块链项目开发指南 [:1703875359]
1703877948 区块链项目开发指南 6.2.2 solcjs API
1703877949
1703877950 solcjs提供了compiler方法,用于编译solidity代码。根据源代码是否有import(引用),该方法可以用于两种不同方法:如果源代码没有import,则需要两个实参,即第一个实参是字符串作solidity源代码,第二个实参是Boolean,表示是否最优化字节码。如果源字符串包含多个合约,则将编译全部。示例如下:
1703877951
1703877952
1703877953
1703877954
1703877955 如果源代码包含对其他合约的引用(imports),则第一个实参就是一个对象,它的键是文件名,值是文件内容。所以无论何时编译器看到一个import语句,它不会在文件系统中寻找文件,而是通过与文件名匹配的键在对象中寻找文件内容。示例如下:
1703877956
1703877957
[ 上一页 ]  [ :1.703877908e+09 ]  [ 下一页 ]