在以太坊中,合约是一种特殊的账户,它没有私钥,只有代码。而合约的地址通常是由部署者的地址与nonce共同做keccak哈希生成的。具体的算法实际上就是:
contractAddress = keccak256(rlp.encode(deployingAddress, nonce))[12:]
对于那些需要在多个链部署的项目来说,如果保证部署者的地址相同,nonce相同,则可以部署出相同地址的合约。例如,Uniswap的UniswapV2Factory在Ethereum的主网、Ropsten、Rinkeby等均有相同的地址。
但是这种部署方式要求每个网的部署顺序要完全一致,以确保nonce相同。有没有办法能更好地部署不同链得到相同的地址呢?
答案是使用CREATE2
指令。
CREATE2
指令是以太坊EIP-1014引入的一种能预先计算合约地址的新的指令,它的算法如下:
contractAddress = keccak256(0xff + deployingAddress + salt + keccak256(bytecode))[12:]
只要保证deployingAddress
和一个指定的salt
不变,相同的合约代码(bytecode)部署后得到的合约地址就一定是相同的。
如果我们在不同的链首先部署一个能部署合约的合约,