
青山
UniswapV2 技术深度解析项目
本项目基于 Solidity 0.8.30 与 Foundry 工具链,从零完整实现 UniswapV2 的生态系统,包括核心协议、外围组件、安全防护和高级特性,配套 23 篇系统化的中文教程文档。
本项目参照 Jeiwan 的 Programming DeFi: Uniswap V2 系列教程,结合现代 Solidity 开发最佳实践(Foundry + Solidity 0.8.30),为中文开发者提供完整的学习路径。
🌟 项目特色
🎉 项目完成状态
✅ 项目已完结 - 所有核心功能已实现,全部测试通过
已完成的核心模块
📊 项目统计
🚀 快速开始
环境要求
安装步骤
1. 安装 Foundry 工具链
curl -L https://foundry.paradigm.xyz | bash
foundryup
2. 克隆项目仓库
git clone https://github.com/RyanWeb31110/uniswapv2_tech
cd uniswapv2_tech
3. 安装依赖(OpenZeppelin 合约库和 Forge 标准库)
forge install
4. 编译所有合约
forge build
运行测试
运行所有测试(71 个测试用例)
forge test
查看测试覆盖率统计
forge test --summary
运行特定测试文件
forge test --match-contract UniswapV2PairTest
运行特定测试函数
forge test --match-test testMint
查看详细的 Gas 报告
forge test --gas-report
使用项目脚本运行测试(会在 logs/ 目录生成日志)
./scripts/test.sh
其他常用命令
格式化代码
forge fmt
检查代码格式
forge fmt --check
清理编译产物
forge clean
📁 项目架构
src/
├── core/ 🔷 核心协议层
│ ├── UniswapV2Factory.sol 工厂合约 - CREATE2 确定性部署
│ ├── UniswapV2Pair.sol 交易对合约 - AMM 核心逻辑
│ └── UniswapV2ERC20.sol LP 代币 - EIP-2612 支持
├── periphery/ 🔶 外围组件层
│ ├── UniswapV2Router.sol 路由合约 - 用户交互入口
│ └── WETH.sol 包装以太坊合约
├── libraries/ 📚 工具库集合
│ ├── UniswapV2Library.sol 核心计算库
│ ├── UQ112x112.sol 高精度定点数
│ └── StorageOptimization.sol 存储优化库
├── security/ 🔒 安全防护组件
│ └── ReentrancyGuard.sol 重入攻击防护
├── oracle/ 🔮 预言机系统
│ └── UniswapV2Oracle.sol TWAP 价格预言机
└── examples/ 💡 教学示例
├── ArbitrageBot.sol 套利机器人
└── LendingProtocol.sol 借贷协议
test/ 🧪 测试套件
├── core/ 核心协议测试
├── periphery/ 外围组件测试
├── security/ 安全防护测试
├── oracle/ 预言机系统测试
├── gas/ Gas 优化测试
└── mocks/ 测试辅助合约
docs/ 📖 系列教程文档(23篇完整版)
├── UniswapV2 深入解析系列 01:架构概述与开发环境搭建.md
├── UniswapV2 深入解析系列 02:流动性池机制与LP代币铸造.md
├── UniswapV2 深入解析系列 03:流动性移除机制与LP代币销毁.md
├── ... 完整的渐进式学习路径
├── UniswapV2 深入解析系列 22:重入防护与闪电贷安全.md
└── UniswapV2 深入解析系列 23:协议费用与系列总结.md
🎯 核心特性
🔷 核心协议层
🔶 外围组件层
🔒 安全防护系统
🔮 高级特性
📚 完整学习路径(23 篇系列教程)
🔰 基础篇(第 1-5 篇)
🔧 进阶篇(第 6-14 篇)
🚀 高级篇(第 15-23 篇)
💡 学习建议:建议按顺序阅读教程,每篇文章都配有完整的代码实现和测试用例,可以边学边实践。
⚡ 性能与优化
Gas 优化成果
完整测试套件
测试覆盖范围
✅ 核心协议层(32 测试):Pair 流动性管理、交换、闪电贷、费用机制
✅ 工厂合约(17 测试):交易对创建、地址计算、权限管理
✅ 外围组件(11 测试):Router 流动性操作、精确输入/输出兑换
✅ 安全防护(9 测试):重入攻击防护、恶意代币处理
✅ 预言机系统(12 测试):TWAP 累积价格计算、时间窗口查询
✅ 工具库(3 测试):价格计算、储备查询、路径管理
🛠 技术亮点与最佳实践
现代 Solidity 开发实践
安全防护机制
代码质量保证
🔄 与原版 Uniswap V2 的区别
现代化改进 | 特性 | 原版 Uniswap V2 (2020) | 本项目 (2024) |
---|---|---|---|
Solidity 版本 | 0.5.16 / 0.6.6 | 0.8.30 | |
SafeMath | 必须使用 | 内置溢出检查,无需 SafeMath | |
错误处理 | require 字符串 |
自定义 error ,节省 Gas |
|
ERC20 实现 | 自己实现 | 使用 OpenZeppelin ERC20Permit | |
测试框架 | Truffle / Hardhat | Foundry(更快) | |
测试语言 | JavaScript | Solidity(类型安全) | |
代码注释 | 英文简洁注释 | 完整中文 NatSpec 注释 |
功能对比 ✅ 完整实现:
✨ 额外增强:
学习友好性
🎓 适用人群与学习收获
适合以下开发者
学完本项目你将掌握
📖 参考资源
官方文档
学习资源
相关项目
🤝 贡献与反馈
代码贡献流程
git checkout -b feature/your-feature
forge test
forge fmt
文档贡献
反馈渠道
📜 许可证
本项目采用 MIT 许可证,详见 LICENSE 文件。
⚠️ 免责声明
本项目仅供学习和研究使用,未经过专业安全审计,请勿在生产环境或主网中直接部署使用。
🙏 致谢
如果本项目对你有帮助,欢迎 Star ⭐ 支持!
项目作者:RyanWeb31110
项目仓库:https://github.com/RyanWeb31110/uniswapv2_tech