zoukankan      html  css  js  c++  java
  • 孤荷凌寒自学第172天区块链086天Dapp041

    孤荷凌寒自学第171天

    区块链086天Dapp041

     

    【主要内容】

    今天继续学习实战,开始做一个菠菜类的猜大小的智能合约。共耗时21分钟。

    (此外整理作笔记花费了约30分钟)

    详细学习过程见文末学习过程屏幕录像。

     

     

    【继续修改一个dapp的合约代码】

    今天已修改完成的情况:

    ```

    pragma solidity ^0.4.25;

     

    contract dudaxiao{

        //原合约是一次性合约,就是只能参与一次。

        struct jilu{

            uint time; //开奖时间

            uint result; //开奖的那个数字 

            uint peilv; //赢了一局后的赔率,这儿暂时没有理解

        }

     

        uint private createmeblocknumber; //创建合约时的以太坊网络区块高度

        address private owner; //合约部署节点

        bool private isstopthis; //是否已经停止本合约

        bool private iscanxiazhu; //是否可以下注,就是判断是否是一轮游戏的中间过程,原合约表示合约只使用一次,只投注一次即可。

        unit private yingli; //赢利,这儿暂时没有理解

     

        //---下面申明只存放一次参与过程参与节点信息的节点地址数组

        address[] private addsmall; //所有押小的地址

        address[] private addbig; //所有押大的地址

     

        //--下面存放的是各参与节点押的金额的maping对象变量 

        //--就是说,下面的mapping记录下了每一个参与游戏的节点投注的金额

        mapping(address -> uint) private bigmap; //此mapping中记录了每一个压大的节点投注的金额

        mapping(address -> uint) private smallmap; //此mapping中记录了每一个压小的节点投注的金额

     

        //定义记录此次(因为本合约只玩一次)游戏的开奖结果

        Result private r;

     

        //下面开始定义函数修改器

        //判断合约是否已经不再执行了(就是说已经不能再参与游戏了,游戏已经结束 )

        modifier onlyIfNotStopped{

            require(isstopthis==false);

            _;

        }    

     

        //判断合约是否允许下注,就是说现在还可以下注吗?

        modifier canXiaZhu{

            require(iscanxiazhu==true);

            _;

        }

     

        //判断当前调用合约的节点是否是部署合约的节点

        modifier onlyOwner{

            require(msg.sender==owner);

            _;

        }

     

        function dudaxiao() public{

            //这是合约初始化函数,只在部署时执行一次的函数

            //--记录下当前合约部署时的以太坊的块高度

            createmeblocknumber=block.number; //当前块的Index

            onwer=msg.sender; //部署合约时的节点地址

            isstopthis=false; //合约还没有停用

            iscanxiazhu=true; //当前还可以下注

            yingli=0;

     

        }

     

        //下面定义的是接收eth转入的两个函数

        //回退函数来接收eth

        function () public payable{

     

        }

     

        //专门的下注函数用以接收eth

        function xiazhu(bool isda) public payable{

            

     

        }



        

     

    }

     

    ```

     

    【关于ether的单位】

    因为原代码中检查下注金额时使用的单位是finney,所以专门查找 了一下(其实是复习了一下)关于ether代币的单位

    博文地址;

    https://www.sohu.com/a/218371714_100105055

    以太坊的最小单位是 Wei。1 个以太币 = 10 的 18 次方 Wei,但因为这个单位太小,好像 Byte 字节与 KB、MB、GB 的电脑存储单位一样,以太坊还有其他的单位:

     

    Kwei(Babbage)= 10 的 3 次方 Wei

     

    Mwei(Lovelace)= 10 的 6 次方 Wei

     

    Gwei(Shannon)= 10 的 9 次方 Wei

     

    MicroEther(Szabo)= 10 的 12 次方 Wei

     

    MilliEther(Finney)= 10 的 15 次方 Wei

     

    Ether = 10 的 18 次方 Wei

     

    每个单位都还有个别名,即括号里的那个,每个别名又各有来历。通常,小额支付使用 Finney,计算 Gas 价格使用 GWei。

     

     

    github: https://github.com/lhghroom/Self-learning-blockchain-from-scratch

    原文地址:https://www.941xue.com/content.aspx?id=1557  

     

     

    【欢迎大家加入[就是要学]社群】

    如今,这个世界的变化与科技的发展就像一个机器猛兽,它跑得越来越快,跑得越来越快,在我们身后追赶着我们。

    很多人很早就放弃了成长,也就放弃了继续奔跑,多数人保持终身不变的样子,原地不动,成为那猛兽的肚中餐——当然那也不错,在猛兽的逼迫下,机械的重复着自我感觉还良好地稳定工作与生活——而且多半感觉不到这有什么不正常的地方,因为在猛兽肚子里的是大多数人,就好像大多数人都在一个大坑里,也就感觉不出来这是一个大坑了,反而坑外的世界显得有些不大正常。

    为什么我们不要做坑里的大多数人?

    因为真正的人生,应当有百万种可能 ;因为真正的一生可以有好多辈子组成,每一辈子都可以做自己喜欢的事情;因为真正的人生,应当有无数种可以选择的权利,而不是总觉得自己别无选择。因为我们要成为一九法则中为数不多的那个一;因为我们要成为自己人生的导演而不是被迫成为别人安排的戏目中的演员。

    【请注意】

    就是要学社群并不会告诉你怎样一夜暴富!也不会告诉你怎样不经努力就实现梦想!

    【请注意】

    就是要学社群并没有任何可以应付未来一切变化的独门绝技,也没有值得吹嘘的所谓价值连城的成功学方法论!

    【请注意】

    社群只会互相帮助,让每个人都看清自己在哪儿,自己是怎样的,重新看见心中的梦想,唤醒各自内心中的那个英雄,然后勇往直前,成为自己想要成为的样子!

    期待与你并肩奔赴未来!

    www.941xue.com

    QQ群:646854445 (【就是要学】终身成长)

     

     

     

     

    【同步语音笔记】

    https://www.ximalaya.com/keji/19103006/347798046

     

    【学习过程屏幕录屏】

    https://www.bilibili.com/video/BV1Ha4y1J7hx/

     

     

    欢迎大家添加我为好友: QQ: 578652607
  • 相关阅读:
    Javaweb开发环境与搭建
    剑指Offer:面试题32——从1到n整数中1出现的次数(java实现)
    剑指Offer:面试题31——连续子数组的最大和(java实现)
    剑指Offer:面试题30——最小的k个数(java实现)
    剑指Offer:面试题29——数组中出现次数超过一半的数字(java实现)
    剑指Offer:解决难题时的三大方法
    剑指Offer:面试题28——字符串的排列(java实现)(待序)
    剑指Offer:面试题27——二叉搜索树与双向链表(java实现)
    剑指Offer:面试题26——复制复杂的链表(java实现)
    剑指Offer:面试题25——二叉树中和为某一值的路径(java实现)
  • 原文地址:https://www.cnblogs.com/lhghroom/p/14021939.html
Copyright © 2011-2022 走看看