内容推荐 本书是区块链智能合约开发中级教材的上册,主要介绍了智能合约平台部署和智能合约开发环境搭建,Solidity编程等相关知识。全书共分8章,内容包括区块链智能合约开发概述、智能合约平台、智能合约开发测试与部署、Solidity编程基础、Solidity高级编程、Solidity合约与实例、智能合约安全、以太坊虚拟机。 本书可用于“1+X”证书制度试点工作中的区块链智能合约开发职业技能等级证书教学和培训,也适合作为应用型本科、职业院校、技师学院的教材,同时也适合作为从事区块链智能合约开发的技术人员的参考用书。 目录 第1章 智能合约原理 1.1 智能合约的定义 1.2 为什么需要智能合约 1.3 智能合约的技术实现 1.4 智能合约的模型 1.5 智能合约的运行机制 第2章 智能合约平台 2.1 以太坊概述 2.2 以太坊架构 2.3 智能合约 2.4 账户 2.5 账户状态 2.6 以太坊虚拟机 2.7 gas 2.8 以太坊交易 2.8.1 价值传递 2.8.2 创建智能合约 2.8.3 调用合约方法 2.9 区块 2.10 以太坊客户端 2.10.1 geth安装 2.10.2 geth使用 2.11 以太坊钱包 2.12 以太坊网络 2.12.1 主网网络 2.12.2 测试网络 2.12.3 私有网络、开发者模式 2.12.4 模拟区块链网络 2.12.5 以太坊货币单位 2.13 以太坊历史回顾 2.13.1 奥林匹克 2.13.2 边疆 2.13.3 家园 2.13.4 DAO分叉 2.13.5 拜占庭 2.13.6 君士坦丁堡 2.13.7 伊斯坦布尔 第3章 智能合约的开发、测试与部署 3.1 什么是智能合约 3.2 Remix 3.2.1 基础模块 3.2.2 典型模块 3.2.3 单元测试 第4章 Solidity编程基础 4.1 Solidity中的变量 4.1.1 状态变量 4.1.2 局部变量 4.1.3 全局变量 4.1.4 Solidity变量名 4.2 Solidity数据类型 4.2.1 值类型 4.2.2 引用类型 4.2.3 类型转换 4.3 函数调用 4.3.1 参数 4.3.2 返回值 4.3.3 函数可见性 4.3.4 状态可变性(mutability) 4.4 变量的作用域 4.5 控制结构 4.6 合约 4.6.1 可见性 4.6.2 构造函数 4.6.3 使用new创建合约 4.6.4 constant状态常量 4.6.5 immutable不可变量 4.6.6 view()函数 4.6.7 pure()函数 4.6.8 getter()函数 4.6.9 receive()函数 4.6.10 fallback()函数 4.6.11 函数修改器 4.6.12 函数重载 4.6.13 事件 4.7 错误处理及异常 4.7.1 错误处理函数 4.7.2 require()还是assert() 4.7.3 try/catch 4.8 Solidity全局变量及API 4.8.1 区块和交易属性API 4.8.2 ABI编码及解码函数API 4.8.3 数学和密码学函数API 第5章 Solidity高级编程 5.1 合约继承 5.1.1 多重继承 5.1.2 父合约构造函数 5.1.3 抽象合约 5.1.4 函数重写 5.2 接口 5.3 库 5.3.1 内嵌库 5.3.2 链接库 5.3.3 using for 5.4 应用程序二进制接口 5.4.1 ABI编码 5.4.2 函数选择器 5.4.3 参数编码 5.4.4 通过ABI编码调用函数 5.4.5 ABI接口描述 5.5 gas优化 5.5.1 变量打包 5.5.2 选择适合的数据类型 5.5.3 内存和存储 5.5.4 减少存储 5.5.5 其他建议 5.6 使用内联汇编 5.6.1 汇编基础概念 5.6.2 Solidity中引入汇编 5.6.3 汇编变量定义与赋值 5.6.4 汇编中的块和作用域 5.6.5 汇编中访问变量 5.6.6 for循环 5.6.7 if判断语句 5.6.8 汇编switch语句 5.6.9 汇编函数 5.6.10 元组 5.6.11 汇编缺点 第6章 Solidity合约 6.1 OpenZeppelin 6.2 SafeMath安全算数运算 6.3 地址工具 6.4 ERC165接口实现 6.5 ERC20代币 6.5.1 标准ERC20实现 6.5.2 WETH实现 6.6 ERC777功能型代币 6.6.1 ERC1820接口注册表 6.6.2 ERC777标准 6.6.3 ERC777实现 6.6.4 实现Hook函数 6.7 ERC721 6.7.1 ERC721代币规范 6.7.2 ERC721实现 第7章 智能合约的安全性 7.1 安全事件 7.2 安全原则 7.3 已知的经典漏洞攻击方法 7.3.1 重入攻击 7.3.2 算术溢出 7.3.3 delegatecall导致意外代码的执行 7.3.4 未检查返回值 7.3.5 拒绝服务 7.3.6 错误命名构造函数 7.4 总结 第8章 以太坊虚拟机 8.1 什么是以太坊虚拟机 8.1.1 概述 8.1.2 账号 8.1.3 交易 8.1.4 gas 8.1.5 存储、主存和栈 8.1.6 指令集 8.1.7 消息调用 8.1.8 代理调用/代码调用和库 8.1.9 日志 8.1.10 创建合约 8.1.11 移除合约 8.2 EVM工作原理 8.2.1 EVM解释执行流程 8.2.2 创建合约流程 8.2.3 调用合约流程 8.2.4 Solidity编译为EVM字节码 8.3 EVM指令集 8.3.1 算术运算指令 8.3.2 位移运算指令 8.3.3 比较操作指令 8.4 gas 8.4.1 执行阶段的gas计量 8.4.2 gas计量原则 8.4.3 gas消耗和gas价格 8.4.4 区块的gas限制 8.5 WASM拓展 8.5.1 什么是WASM 8.5.2 WASM的特点 8.5.3 WA |