solidity官方中文文档学习
https://solidity-cn.readthedocs.io/zh/develop/
一、提示
1、在线remix编辑器进行开发
http://remix.hubwiz.com/#optimize=false&version=soljson-v0.5.1+commit.c8a2cb62.js
2、警告
安全考量
3、查询特定的某个编译器版本会受哪些 bug 影响
https://github.com/ethereum/solidity/blob/develop/docs/bugs_by_version.json
二、以太坊综述(ethereum)
1、为什么学习以太坊
庞大的开发者社区,目前最大的区块链开发平台;
相对比较成熟,有代表性,资料众多;
以应用入手,学习曲线不那么陡峭;
与javascript结合紧密,方便开发人员上手。
2、主要参考资料
《精通以太坊》(mastering ethereum)
《以太坊白皮书》
《以太坊黄皮书》(《以太坊:一种安全去中心化的通用交易账本 拜占庭版本》)
《以太坊官方文档》
《solidity官方文档》
3、涉及钱包
MetaMask - 浏览器插件钱包
Remix - 基于浏览器的 Solidity 在线编辑器
Geth -以太坊客户端(go语言)
web3.js – 以太坊 javascipt API库
Ganache – 以太坊客户端(测试环境私链)
Truffle – 以太坊开发框架
4、环境准备(教程给出的)
Chrome浏览器(最新版本 70.0.3538.67)
Linux 系统或虚拟机(ubuntu 16.04.3)
需要安装:go(1.9), git(2.7.4), node(9.0.0), npm(5.7.1)
文本编辑器(VisualCode)
科学上网工具
三、以太坊简介(一)
1、公链发展简史
2008比特币(1.0):简单的记账;
2014以太坊(2.0):智能合约;
2017EOS、ArcBlock、IOTA(3.0):高性能、大吞吐量、开发者友好、用户友好。
2、以太坊的出现
3、发展阶段
“前沿”(Frontier) – Block #0
以太坊的初始阶段,持续时间为2015年7月30日至2016年3月
“家园”(Homestead) - Block #1,150,000
以太坊的第二阶段,于2016年3月推出
“大都会”(Metropolis) Block #4,370,000
以太坊的第三个阶段,于2017年10月推出的“拜占庭”(Byzantium)是 Metropolis 的两个硬分叉中的第一个,也是我们现在所处的阶段。“君士坦丁堡”(Constantinople)Metropolis 阶段的第二部分,计划于2018年推出。预计将包括切换到混合POW/POS 共识算法,以及其他变更。
“宁静”(Serenity)
以太坊的第四个也是最后一个阶段。Serenity尚未有计划的发布日期。
4、以太坊重大分叉(大概是2018年的数据)
Block #200,000
“Ice Age” - 引入指数难度增加的硬分叉,促使向 Proof-of-Stake 过渡。
Block #1,192,000
“The DAO" - 扭转了被攻击的DAO合约并导致以太坊(ETH)和以太坊经典(ETC)分裂成两个竞争系统的硬分叉。
Block #2,463,000
“Tangerine Whistle” - 改变某些IO运算的 gas 计算,并从拒绝服务攻击中清除累积状态,该攻击利用了这些操作的低 gas 成本。
Block #2,675,000
“Spurious Dragon” - 一个解决更多拒绝服务攻击媒介的硬分叉,以及另一种状态清除。此外,还有重放攻击保护机制。
5、发展状况
根据State of DApps的统计(时间截止于2020.3.27)
四、以太坊简介(二)
1、以太坊特点
2、以太坊组成部分
P2P网络
以太坊在以太坊主网络上运行,该网络可在TCP端口30303上寻址,并运行一个名为ÐΞVp2p的协议。
交易(Transaction)
以太坊交易是网络消息,其中包括发送者(sender),接收者(receiver),值(value)和数据的有效载荷(payload)。
以太坊虚拟机(EVM)
以太坊状态转换由以太坊虚拟机(EVM)处理,这是一个执行字节码(机器语言指令)的基于堆栈的虚拟机。
数据库(Blockchain)
以太坊的区块链作为数据库(通常是 Google 的 LevelDB)本地存储在每个节点上,包含序列化后的交易和系统状态。
客户端
以太坊有几种可互操作的客户端软件实现,其中最突出的是 Go-Ethereum(Geth)和 Parity。
3、以太坊的重要概念(和比特币相比的一些不同点)
账户(Account)
包含地址,余额和随机数,以及可选的存储和代码的对象。
地址(Address)
一般来说,这代表一个EOA或合约,它可以在区块链上接收或发送交易。更具体地说,它是ECDSA 公钥的 keccak 散列的最右边的160位。
交易(Transaction)
gas
以太坊用于执行智能合约的虚拟燃料。以太坊虚拟机使用核算机制来衡量gas的消耗量并限制计算资源的消耗。
五、以太坊简介(三)
1、以太坊的货币
以太坊的货币单位称为以太(ether),也可以表示为ETH或符号Ξ。
以太币的发行规则:
挖矿前(Pre-mine,Genesis)
2014年7月/8月间,为众筹大约发行了7200万以太币。这些币有的时候被称之为“矿前”。众筹阶段之后,以太币每年的产量基本稳定,被限制不超过7200万的25%
挖矿产出(Mining)
——区块奖励(block reward)
——叔块奖励(uncle reward)
——叔块引用奖励(uncle referencing reward)
以太币产量未来的变化
以太坊出块机制从工作量证明(PoW)转换为股权证明(PoS)后,以太币的发行会有什么变化尚未有定论。股权证明机制将使用一个称为Casper的协议。在Casper协议下,以太币的发行率将大大低于目前幽灵(GHOST)协议下的发行率。
2、以太坊的挖矿产出
区块奖励(Block rewards)
每产生一个新区块就会有一笔固定的奖励给矿工,初始是5个以太币,现在是3个。
叔块奖励(Uncle rewards)
有些区块被挖得稍晚一些,因此不能作为主区块链的组成部分。比特币称这类区块为“孤块”,并且完全舍弃它们。但是,以太币称它们为“叔块”(uncles),并且在之后的区块中,可以引用它们。如果叔块在之后的区块链中作为叔块被引用,每个叔块会为挖矿者产出区块奖励的7/8。这被称之为叔块奖励。
叔块引用奖励(Uncle referencing rewards)
矿工每引用一个叔块,可以得到区块奖励的1/32作为奖励(最多引用两个叔块)
这样的一套基于POW的奖励机制,被称为以太坊的“幽灵协议”
六、以太坊简介(四)
1、以太坊区块收入
https://etherscan.io:以太坊区块查看
普通区块收入
— 固定奖励(挖矿奖励),每个普通区块都有
— 区块内包含的所有程序的 gas 花费的总和
— 如果普通区块引用了叔块,每引用一个叔块可以得到固定奖励的1/32
叔块收入
叔块收入只有一项,就是叔块奖励,计算公式为:
叔块奖励 = ( 叔块高度 + 8 – 引用叔块的区块高度 ) * 普通区块奖励 / 8
七、以太坊简介(五)
1、“幽灵”(GHOST)协议
以太坊出块时间:
设计为12秒,实际14~15秒左右
快速确认:
会带来区块的高作废率,由此链的安全性也会降低
“幽灵”协议:
Greedy Heaviest Observed SubTree, ”GHOST”
——计算工作量证明时,不仅包括当前区块的祖区块,父区块,还要包括祖先块的作废的后代区块(“叔块”),将他们进行综合考虑。
——目前的协议要求下探到第七层(最早的简版设计是五层),也就是说,废区块只能以叔区块的身份被其父母的第二代至第七代后辈区块引用,而不能是更远关系的后辈区块。
——以太坊付给以“叔区块”身份为新块确认作出贡献的废区块7/8的奖励,把它们纳入计算的“侄子区块”将获得区块奖励的1/32,不过,交易费用不会奖励给叔区块。
八、以太坊简介(六)
1、以太坊和图灵完备
2、去中心化应用
3、以太坊应用
4、代币
5、名词解释
名词 | 解释 |
---|---|
EIP | Ethereum Improvement Proposals,以太坊改进建议 |
ERC | Ethereum Request for Comments的缩写,以太坊征求意见。一些EIP被标记为ERC,表示试图定义以太坊使用的特定标准的提议 |
EOA | External Owned Account,外部账户。由以太坊网络的人类用户创建的账户 |
Ethash | 以太坊1.0 的工作量证明算法。 |
HD钱包 | 使用分层确定性(HD protocol)密钥创建和转账协议(BIP32)的钱包。 |
Keccak256 | 以太坊中使用的密码哈希函数。Keccak256 被标准化为SHA-3 |
Nonce | 在密码学中,术语nonce用于指代只能使用一次的值。以太坊使用两种类型的随机数,账户随机数和POW随机数 |
九、总结
以上内容来自尚硅谷教学视频,讲述以太坊的一些理论知识,没有实际操作。最好看相隔时间比较近的教学视频,因为很多东西发展很快,一些数据在不断发生变化,更新的数据更利于掌握目前项目的发展。