news 2026/6/23 4:55:21

14.ETH-以太坊概述-北大肖臻老师客堂笔记

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
14.ETH-以太坊概述-北大肖臻老师客堂笔记

北京大学肖臻老师《区块链技术与应用》公开课第 14 讲是以太坊 (Ethereum)的开篇,主题通常是**“以太坊概述” (Introduction to Ethereum)**。

在告别了比特币章节后,课程正式进入“区块链 2.0”时代。这一讲主要介绍了以太坊的设计理念、与比特币的区别以及核心账户模型。

以下是本课内容的结构化详细总结

一、 以太坊的定位:区块链 2.0

  1. 从去中心化货币到去中心化合约
  • 比特币 (Bitcoin):主要目标是做一个去中心化的加密货币(Payment Network),被称为“全球账本”。
  • 以太坊 (Ethereum):主要目标是做一个去中心化的智能合约平台 (Smart Contract Platform),被称为“世界计算机”。
  1. 可编程性
  • 比特币的脚本语言(Script)非常简单,功能有限(非图灵完备),很难开发复杂的应用。
  • 以太坊提供了一种图灵完备 (Turing Complete)的编程语言(Solidity),允许开发者在区块链上编写任意复杂的逻辑(智能合约)。

二、 以太坊的账户模型 (Account-based Model)

这是以太坊与比特币最底层的区别。

1. 比特币:UTXO 模型
  • 特点:没有“账户余额”的概念,你的钱是一堆“未花费的交易输出” (UTXO) 拼凑出来的。
  • 缺点:难以精确控制“状态”。比如你想写一个合约限制“每天只能取 10 块钱”,在 UTXO 模型下很难实现,因为你需要追溯并管理大量零散的 UTXO。
2. 以太坊:基于账户的模型
  • 特点:系统直接记录每个账户的余额 (Balance)计数器 (Nonce)等状态。这就好比银行账户,想转账直接扣款即可。
  • 优点
  • 直观:符合人们对“账户”的直觉理解。
  • 易于编程:智能合约本质上就是管理状态(State),账户模型天生适合状态管理。
  • 防重放攻击:显式地使用 Nonce(交易计数器)来防止同一笔交易被广播两次。

三、 两类账户 (Two Types of Accounts)

在以太坊中,账户分为两类,它们在数据结构上是统一的,但功能不同。

1. 外部账户 (Externally Owned Account, EOA)
  • 控制者:由私钥控制(即普通用户使用的账户)。
  • 特点
  • 有余额 (Balance)。
  • 有 Nonce (交易序号)。
  • 没有代码(No Code)。
  • 主动发起交易:只有 EOA 才能发起交易(Transaction),这是区块链一切活动的源头。
2. 合约账户 (Contract Account)
  • 控制者:由代码逻辑控制(没有私钥对应)。

  • 特点

  • 有余额。

  • 有 Nonce。

  • 有代码(Code):存储了智能合约的编译后字节码。

  • 有存储(Storage):维护了一棵存储树(Storage Trie),保存合约运行时的状态变量(如投票数、众筹金额等)。

  • 被动执行:合约账户不能自己发起交易,必须被 EOA 或其他合约调用(发送消息)才能触发其代码执行。

四、 交易与消息 (Transaction & Message)

  • 交易 (Transaction)

  • 指的是从外部账户 (EOA)发出的签名数据包。

  • 包含:接收方地址、金额、Nonce、签名、以及可选的数据(Data,用于调用合约函数)。

  • 消息 (Message / Internal Transaction)

  • 指的是合约调用合约时产生的数据传递。

  • 它不直接记录在区块链上,而是作为交易执行过程中的一部分。

五、 以太坊的数据结构概览

肖老师在这一讲中也简要铺垫了以太坊复杂的状态树结构(下一讲会深入):

  • 状态树 (State Trie):记录全网所有账户的状态(余额、Nonce、代码哈希、存储根)。
  • 特点:使用 MPT (Merkle Patricia Trie) 结构,既能像 Merkle Tree 一样验证数据完整性,又能高效地进行查找和更新。

🧠 逻辑流程:以太坊的运行机制

执行层

网络层

用户层

1. 发起交易 (带签名)
2. 验证签名 & Nonce
3. 触发代码 (EVM执行)

条件满足

调用其他合约

用户 EOA

以太坊网络

合约账户

逻辑判断

4. 修改状态 (余额/存储)

发送内部消息 Message

💡 总结

第 14 讲的核心任务是**“转换思维”**:
从比特币的“UTXO + 脚本”思维,转换到以太坊的“账户 + 状态 + 智能合约”思维。这是理解后续去中心化应用 (DApp) 的基石。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 8:01:59

Z-Image Turbo综合评测:开源AI绘图工具的新选择

Z-Image Turbo综合评测:开源AI绘图工具的新选择 1. 为什么你需要一个“本地极速画板” 你有没有试过这样的场景:刚想用AI画一张概念图,结果等了40秒,生成的图却是一片漆黑;或者好不容易跑起来,显存直接爆…

作者头像 李华
网站建设 2026/6/10 18:19:34

开箱即用的人脸分析工具:InsightFace WebUI 使用测评

开箱即用的人脸分析工具:InsightFace WebUI 使用测评 1. 为什么你需要一个真正“开箱即用”的人脸分析工具? 你是否遇到过这样的场景: 想快速验证一张照片里有多少人、各自大概多大年纪、是男是女,却要先配环境、装CUDA、下载模…

作者头像 李华
网站建设 2026/6/22 16:48:36

图片旋转判断模型企业部署指南:Docker Compose编排+API服务化

图片旋转判断模型企业部署指南:Docker Compose编排API服务化 1. 这个模型到底能帮你解决什么问题? 你有没有遇到过这样的场景:用户上传了一堆商品图、证件照或扫描件,结果有的横着、有的倒着、有的歪了15度——人工一张张手动旋…

作者头像 李华
网站建设 2026/6/13 5:44:01

音乐分类新体验:ccmusic-database/music_genre Web应用快速上手

音乐分类新体验:ccmusic-database/music_genre Web应用快速上手 你有没有过这样的困惑:听到一首歌,旋律很熟悉,节奏很带感,但就是说不准它属于什么流派?是爵士还是放克?是电子还是拉丁&#xff…

作者头像 李华