美文网首页ETH
3分钟漫谈以太坊The DAO事件,浅入浅出区块链(2)

3分钟漫谈以太坊The DAO事件,浅入浅出区块链(2)

作者: 假装在去天使之城的路上 | 来源:发表于2018-10-14 13:32 被阅读7次

    这片博文主要是继续的简要的介绍一下The DAO事件,以及ETH和ETC的关系。

    这是一系列关于区块链的漫谈博客。用讲故事的方法,漫聊一下区块链。其中也会穿插一些区块链相关概念,以及编程的介绍。主要目的是漫谈,每个主题之间相对独立,在阅读的时候,可以选择你有兴趣的部分阅读。

    虽然目的是漫谈,但准确的信息是博文的基本,如果有不准确的地方,请留言或者发消息,我会及时订正。

    复习一下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以上的请求。

    图片来源

    图片来自网络

    相关链接

    相关文章

      网友评论

        本文标题:3分钟漫谈以太坊The DAO事件,浅入浅出区块链(2)

        本文链接:https://www.haomeiwen.com/subject/atbzaftx.html