分享百科

EVM

在 DEFCON 7 的演讲中,讲者分享了智能合约开发者应关注的编程语言特性,尤其是基于其在 OpenZeppelin Contracts 项目的经验。OpenZeppelin Contracts 的初衷是提供可重用的合约库,以减少开发者引入错误的风险。然而,随着时间推移,开发者需要在库的基础上添加自定义行为,因此确保安全性和可扩展性成为了关键。 讲者以 ERC20 代币为例,强调了安全抽象的重要性。通过提供一个安全的 mint 函数,确保了代币合约的基本属性得以保持,避免了开发者在实现时犯错。此外,讲者指出,继承机制虽然是实现可扩展性的主要方式,但也可能导致不一致的行为,增加了出错的风险。 随着以太坊网络的拥堵,开发者对 gas 效率的关注日益增加,手写汇编代码成为一种趋势。尽管这种做法在某些情况下能提高效率,但讲者警告说,过度依赖低级细节可能会分散开发者的注意力,影响合约的安全性。 最后,讲者呼吁探索新的编程语言设计,尤其是借鉴函数式编程语言的特性,以期在未来的智能合约开发中实现更高的安全性和效率。这一探索不仅有助于解决当前的局限性,也为智能合约的未来发展开辟了新的可能性。
76
0
0
2025-01-23 10:37
本次会议围绕区块链技术在金融领域的应用展开,特别是传统金融(TradFi)与去中心化金融(DeFi)之间的互动与融合。与会者包括来自不同背景的专家,讨论了CBDC(中央银行数字货币)及其对金融市场的影响。专家们认为,CBDC与商业银行货币是互补的,能够提升支付效率,但不会根本改变现有支付方式。会议还探讨了隐私保护与合规性之间的矛盾,强调了零知识证明(ZKP)等技术在确保交易隐私方面的重要性。此外,专家们分享了各自的项目如何支持开发者和创业者,推动区块链技术的应用与发展。最后,会议鼓励与会者积极参与未来的区块链项目,推动金融包容性与技术创新。
88
0
0
2025-01-23 10:37
Ethereum虚拟机(EVM)是以太坊系统的核心,负责计算状态转变并处理交易。以太坊的世界状态包含所有账户、NFT、代币和DeFi信息,只有一个当前状态,随着每个新块的挖掘而更新。EVM通过处理交易中的操作码(opcodes)来计算新的世界状态,确保所有节点在处理相同交易时得到一致结果。EVM是一个虚拟机,抽象了底层硬件,允许在不同平台上运行。它使用Merkle Patricia树结构来存储账户信息,并通过栈和内存进行计算。EVM的设计确保了以太坊的去中心化和一致性,尽管它的计算能力受到每个块最大气体限制的约束。
133
0
0
2025-01-21 12:01
John Becker ,Chainalysis 的软件工程师,对以太坊虚拟机(EVM)及其内部智能合约设计模式进行了深入概述。他解释了 EVM 的结构,包括其基于堆栈的架构、内存管理,以及操作码和字节码在执行智能合约中的重要性。贝克强调了理解函数选择器、调用数据和合约执行的控制流的重要性。他还介绍了一些工具,如 Heimdall,用于反编译和分析合约,并讨论了 Solidity 如何编译为 EVM 字节码,使开发者能够有效地与合约进行交互。这次演讲为希望加深对 EVM 和智能合约开发知识的人提供了全面的指南。
116
0
0
2025-01-21 11:38
在本次演讲中,Gilbert介绍了以太坊虚拟机(EVM)及其操作码(opcodes),强调了理解这些内容对Solidity开发者的重要性。通过学习EVM操作码,开发者可以提高代码安全性,减少错误,并理解Solidity设计决策的基础。演讲涵盖了虚拟机的概念、EVM的结构(包括堆栈、内存和存储),以及如何将Solidity代码编译为操作码。此外,Gilbert还讨论了存储变量的索引、紧凑存储的优势以及内部和外部函数调用的区别。最后,他提到了一些学习资源和审计服务,鼓励开发者深入了解EVM和安全性。
102
0
0
2025-01-03 21:01
讲师:0xKJ 大纲: 1.延迟执行的可行性,去除状态树 2.并行 EVM 原理 3.与图灵机理论的关系 >直播时间:2024-07-03
421
0
0
2024-07-12 10:14
SLOADS 给Foundry增加存储相关的作弊码
2127
0
0
2023-04-23 17:20
W2-1理解 call 与 delegatecall 调用
1661
0
0
2023-03-15 09:04
W1-1 理解区块链及智能合约开发
2150
0
0
2023-03-08 09:02
登链社区