市值: $2.1591T 2.61%
成交额(24h): $74.6886B -50.71%
恐惧与贪婪指数:

15 - 极度恐惧

  • 市值: $2.1591T 2.61%
  • 成交额(24h): $74.6886B -50.71%
  • 恐惧与贪婪指数:
  • 市值: $2.1591T 2.61%
加密货币
话题
百科
资讯
加密话题
视频
热门加密百科

选择语种

选择语种

选择货币

加密货币
话题
百科
资讯
加密话题
视频

什么是 CREATE2 操作码以及它如何启用确定性合约地址?

CREATE2 enables predictable contract addresses in Ethereum, allowing off-chain systems to reference contracts before deployment.

2025/11/13 23:40

了解以太坊中的 CREATE2 操作码

1. CREATE2操作码是在君士坦丁堡升级期间通过EIP-1014引入以太坊的。它可以作为传统 CREATE 操作码的替代方案,传统 CREATE 操作码使用发送者的随机数来部署智能合约,以确定生成的合约地址。与 CREATE 不同,CREATE2 允许开发人员在部署之前通过考虑除随机数之外的特定输入来计算合约的地址。

2. 在需要合约地址可预测性的场景中,该功能至关重要。例如,链下系统或第 2 层解决方案可能需要引用尚未部署的合约。通过启用地址预计算,CREATE2 支持无需信任的交互并改善去中心化组件之间的协调。

3. CREATE2 生成的地址结构依赖于涉及四个元素的加密哈希:部署者的地址、用户定义的盐(32 字节值)、合约的字节码(也称为 init_code)以及该字节码的 keccak256 哈希。由于这些输入都不依赖于发送者的交易计数,因此相同的组合将始终产生相同的地址。

4. 该机制的一个显着优点是能够有条件地部署合约。仅当满足某些条件时才能部署合约,但其未来地址仍然是提前已知的。这使得诸如反事实实例化之类的用例成为可能,其中应用程序甚至在合约上线之前就假设合约存在于已知位置。

确定性地址生成解释

1. 确定性合约地址意味着给定相同的输入集,输出地址将始终相同。对于 CREATE2,使用的公式为keccak256(0xff + 地址 + salt + keccak256(init_code))[12:] 。前缀 0xff 确保名称空间与通过 CREATE 创建的地址分离,从而降低冲突风险。

2. 盐参数起着至关重要的作用。它由开发人员选择,可以对有意义的数据进行编码,例如用户标识符、时间戳或特定于应用程序的密钥。只要盐和其他组件保持不变,从同一创建者地址重新部署相同的字节码就会产生完全相同的目的地。

3. 由于地址取决于初始化代码而不是运行时代码的哈希值,因此构造函数参数或编译字节码的任何更改都会改变最终地址。这使得部署对编译细节高度敏感,需要仔细的版本控制和可重现的构建。

4. 开发人员经常利用钱包工厂的确定性寻址,每个用户都会获得一个唯一派生的智能合约钱包。这些钱包可以预期在链外,甚至在部署发生之前就可以正确路由交易。

去中心化金融和二层系统中的应用

1. 在去中心化交易所和自动化做市商中,CREATE2 有助于创建具有可预测地址的矿池。这简化了前端和机器人的集成,前端和机器人可以查询池数据,而无需等待事件日志或依赖注册表。

2. 状态通道和汇总等第 2 层扩展解决方案利用 CREATE2 进行反事实合约部署。通道中的参与者可以与虚拟合约实例进行交互,准确地知道它在链上实现后将驻留在哪里。这减少了链上足迹,同时保留了安全保证。

3. 智能合约钱包,例如符合 ERC-4337(账户抽象)的钱包,依赖确定性地址来实现无缝的用户体验。用户可以在未来的钱包地址存在之前将资金接收到该地址,因为资金交易的目标是预先计算的位置。

4. 另一个用例涉及可升级的代理模式,其中确定性地部署实施契约。尽管代理通常使用 CREATE,但将它们与基于 CREATE2 的工厂相结合可以增强跨部署的模块化和可审核性。

常见问题解答

问:可以使用CREATE2在同一地址多次部署同一个合约吗?

答:不可以。如果计算出的 CREATE2 地址已存在合约,则尝试在那里部署另一个合约将会失败。 EVM 可以防止覆盖现有代码,确保地址被占用后的不变性。

问:salt 值如何影响 CREATE2 部署中的安全性?

答:盐一定要慎重选择。可预测的盐可能允许攻击者在预期地址预先部署恶意合约。使用安全随机性或唯一标识符可以减轻这种风险,特别是在未经许可的环境中。

问:就 Gas 而言,CREATE2 比 CREATE 贵吗?

答:是的。由于计算确定性地址需要额外的哈希操作,CREATE2 通常会消耗更多的 Gas。确切的成本取决于 init_code 的大小和部署时的网络状况。

免责声明:info@kdj.com

所提供的信息并非交易建议。根据本文提供的信息进行的任何投资,kdj.com不承担任何责任。加密货币具有高波动性,强烈建议您深入研究后,谨慎投资!

如您认为本网站上使用的内容侵犯了您的版权,请立即联系我们(info@kdj.com),我们将及时删除。

相关百科

在Bybit上进行BTC交易如何选择线性永续合约和反向永续合约?

在Bybit上进行BTC交易如何选择线性永续合约和反向永续合约?

2026-06-06 02:54:55

合同结算机制1. Bybit的线性永续合约以USDT结算,这意味着所有盈亏计算、保证金要求和清算门槛均以稳定币单位计价。 2.反向永续合约以BTC本身结算,因此每笔交易都会直接影响交易者的BTC余额——收益会增加BTC持有量,而损失会减少BTC持有量。 3. 反向合约的定价引擎使用 BTC/USDT...

如何识别和避免止损、欺骗等期货市场操纵行为?

如何识别和避免止损、欺骗等期货市场操纵行为?

2026-06-07 14:20:10

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少了新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将达到 3.125 BT...

如何在Bybit上设置风险管理规则来限制我的每日最大损失?

如何在Bybit上设置风险管理规则来限制我的每日最大损失?

2026-06-04 16:40:15

账户级损失限额配置1. 使用双因素身份验证通过网络或移动应用程序登录您的 Bybit 帐户。 2. 导航至“资产”部分,然后从左侧菜单中选择“风险管理”。 3. 选择“每日损失限制”并将该功能切换为“开”以激活控制。 4. 输入代表当前交易日 USDT 最大允许净亏损的数值。 5. 使用您的电子邮件...

如何在币安上启用投资组合保证金模式以降低我的保证金要求?

如何在币安上启用投资组合保证金模式以降低我的保证金要求?

2026-06-05 04:59:43

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少每个区块新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将使其达到 3.1...

如何将我的未平仓期货头寸从币安迁移到Bybit而不平仓?

如何将我的未平仓期货头寸从币安迁移到Bybit而不平仓?

2026-06-04 03:59:47

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少了新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将达到 3.125 BT...

如何处理美国加密货币期货交易利润的税务影响?

如何处理美国加密货币期货交易利润的税务影响?

2026-05-29 18:19:59

Bitcoin 减半机制1. Bitcoin 的协议强制规定 2100 万枚代币的固定供应上限,并通过区块奖励引入新单位。 2. 每 210,000 个区块(大约每四年)区块奖励就会减少一半,这个过程称为减半。 3. 最近一次减半发生在 2024 年 4 月,每个区块的奖励从 6.25 BTC 减少...

在Bybit上进行BTC交易如何选择线性永续合约和反向永续合约?

在Bybit上进行BTC交易如何选择线性永续合约和反向永续合约?

2026-06-06 02:54:55

合同结算机制1. Bybit的线性永续合约以USDT结算,这意味着所有盈亏计算、保证金要求和清算门槛均以稳定币单位计价。 2.反向永续合约以BTC本身结算,因此每笔交易都会直接影响交易者的BTC余额——收益会增加BTC持有量,而损失会减少BTC持有量。 3. 反向合约的定价引擎使用 BTC/USDT...

如何识别和避免止损、欺骗等期货市场操纵行为?

如何识别和避免止损、欺骗等期货市场操纵行为?

2026-06-07 14:20:10

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少了新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将达到 3.125 BT...

如何在Bybit上设置风险管理规则来限制我的每日最大损失?

如何在Bybit上设置风险管理规则来限制我的每日最大损失?

2026-06-04 16:40:15

账户级损失限额配置1. 使用双因素身份验证通过网络或移动应用程序登录您的 Bybit 帐户。 2. 导航至“资产”部分,然后从左侧菜单中选择“风险管理”。 3. 选择“每日损失限制”并将该功能切换为“开”以激活控制。 4. 输入代表当前交易日 USDT 最大允许净亏损的数值。 5. 使用您的电子邮件...

如何在币安上启用投资组合保证金模式以降低我的保证金要求?

如何在币安上启用投资组合保证金模式以降低我的保证金要求?

2026-06-05 04:59:43

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少每个区块新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将使其达到 3.1...

如何将我的未平仓期货头寸从币安迁移到Bybit而不平仓?

如何将我的未平仓期货头寸从币安迁移到Bybit而不平仓?

2026-06-04 03:59:47

Bitcoin 减半机制1. Bitcoin 的协议强制执行固定的发行时间表,其中大约每 210,000 个区块,区块奖励就会减少一半。 2. 该事件大约每四年发生一次,直接减少了新进入流通的 BTC 数量。 3.截至2020年减半,矿工每区块获得6.25 BTC;下一次减少将达到 3.125 BT...

如何处理美国加密货币期货交易利润的税务影响?

如何处理美国加密货币期货交易利润的税务影响?

2026-05-29 18:19:59

Bitcoin 减半机制1. Bitcoin 的协议强制规定 2100 万枚代币的固定供应上限,并通过区块奖励引入新单位。 2. 每 210,000 个区块(大约每四年)区块奖励就会减少一半,这个过程称为减半。 3. 最近一次减半发生在 2024 年 4 月,每个区块的奖励从 6.25 BTC 减少...

查看所有文章

User not found or password invalid

Your input is correct