这片博文主要是继续的简要的介绍一下The DAO事件,以及ETH和ETC的关系。
- 3分钟漫谈以太坊The DAO事件,浅入浅出区块链(2)>> 你在这里
- 3分钟漫谈以太坊The DAO事件,浅入浅出区块链(1)
这是一系列关于区块链的漫谈博客。用讲故事的方法,漫聊一下区块链。其中也会穿插一些区块链相关概念,以及编程的介绍。主要目的是漫谈,每个主题之间相对独立,在阅读的时候,可以选择你有兴趣的部分阅读。
虽然目的是漫谈,但准确的信息是博文的基本,如果有不准确的地方,请留言或者发消息,我会及时订正。
复习一下DAO
DAO是Decentralized Autonomous Organization的简称。
可以理解为:去中心化自治组织。任何符合以下特征的组织,都可以被成为DAO组织。
DAO组织的进化过程:发布智能合约,发行代币(ICO),众筹资金,运营和投资众筹的资金。
复习一下The DAO事件
德国一家专注“智能锁”的公司发布了一个DAO项目,黑客利用一个DAO项目的漏洞,转移了一笔巨款,然后以太坊的白帽黑客们,通过软分叉,和硬分叉的方法拿回了被盗的以太币。
复习一下以太坊,以太币,gas
以太坊是一个平台,以太币是在以太坊上通用的数字货币,gas是支付给矿工的“运费”。
gas的价格相对稳定,以太币变化比较大。
为什么需要gas?
我们在亚马逊,淘宝上购物的时候,通常情况下我们买够一定金额,商家就会给我们免运费。为什么在以太坊上,或者其他区块链上,不能够给我免运费呢?而且网络上运费,主要就是电费。
理论上说,免gas是有可能的。但是实际上呢,有黑客的存在。如果黑客可以免费的向以太坊发送请求,会发生情况?
等你3秒钟,想想哦。
想好了么?黑客可以在短时间内,先网络里发送很多请求,网络上的节点就会忙于处理黑客的请求,就无暇顾及其他正常的请求了,这样的攻击也称作DOS攻击。
关于gas
除了上面提到发送请求到以太坊节点以外,关于gas我们顺便了解一下:
- 部署智能合约到时候,我们需要支付gas
- 发送以太币的时候,我们需要支付gas
- 需要存储到区块链上的时候,我们需要支付gas
- 调用一个External函数的时候,我们需要支付一大笔gas
以太坊智能合约
在以太坊网络里,可以使用Solidity来编写智能合约。
External
是以太坊智能合约编程语言Solidity里面的修饰限定词。
是用来描述智能合约的可见范围的限定词。
用语 | 可视范围 |
---|---|
private | 仅限合约内使用 |
internal | +可被子合约使用 |
public | +可被外部合约使用 |
external | 仅限外部合约使用 |
与可视范围相对应的,还有对于函数的操作范围的限定词:
用语 | 用法 |
---|---|
view | 函数只查询数据 |
pure | 函数内没有使用任何外部数据 |
payable
是solidity语言里面的另外一个非常有用的限定词。
当函数内需要接受以太币的时候,这个函数必须要设为:payable,否则就会被抛出异常。
function buySomething() external payable {
// Check to make sure 0.001 ether was sent to the function call:
require(msg.value == 0.001 ether);
// If so, some logic to transfer the digital item to the caller of the function:
transferThing(msg.sender);
}
Fallback Function 回调函数
我们先看一个智能合约的例子:
contract MyContract {
//这个没有函数名,没有参数,没有返回值的函数,就叫做Fallback Function
function() payable { }
//这个函数的函数名为:buySomething,所以不是Fallback Function
function buySomething() external payable {
}
}
- Fallback函数,在两种情况下会被调用:当智能合约里,没有处理请求的相应的函数的时候;当智能合约没有其他附属数据,只是在接受以太币的时候。
- 虽然Fallback函数,没有参数,但是 msg.data 可以在函数里使用,从而得到调用者的相关信息。
- 基本上,如果智能合约需要接受以太币的转账,定义一个payable的Fallback函数是必须。
- Fallback函数不能够处理2300 gas以上的请求。
图片来源
图片来自网络