chapter1:token代币

简而言之,通证就是支持交易的包含一系列规范的函数接口的一个智能合约,发币可以用ERC20标准,但是像僵尸这种非同质化代币,需要用ERC721标准

chapter2:erc721 和多继承

  erc721目前仍是草稿,没有官方建议标准。

  1. contract ERC721 {
  2. event Transfer(address indexed _from, address indexed _to, uint256 _tokenId);
  3. event Approval(address indexed _owner, address indexed _approved, uint256 _tokenId);
  4.  
  5. function balanceOf(address _owner) public view returns (uint256 _balance);
  6. function ownerOf(uint256 _tokenId) public view returns (address _owner);
  7. function transfer(address _to, uint256 _tokenId) public;
  8. function approve(address _to, uint256 _tokenId) public;
  9. function takeOwnership(uint256 _tokenId) public;
  10. }

  solidity支持多继承,用逗号隔开继承的父类。

chapter3:balanceOf , ownerOf函数的应用

chapter4:重构

  注意到ownerOf函数和前面课程中一个modifier重名了,此时我们不能修改erc721中的函数名,因为这是一个标准,所有其他也用了erc721的合约希望函数名是相同的,这样才能实现通信,所以我们要改变自己定义的那个函数名。

chapter5:erc721交易逻辑

  erc721有两种交易方法。

  第一种: transfer函数,参数tokenid和目标账户地址,完成转账;

  第二种:approve函数,参数tokenid和目标账户,标记目标账户为允许提取代币;当外部账户通过takeOwnerShip发起提取时,合约检查账户是否有许可,如果有则完成转账。

chapter9:防止溢出

  在以太坊虚拟机(EVM) 中, 整数指定了固定大小的数据类型。这是指一个整型变量只
能有一定范围的数字表示。 比如,一个 uint8 的范围是[0,255]。 如果输入 256,则会表示
成 0。不加注意的话,只要没有检查用户输入又执行计算,导致数字超出存储它们的数据类
型允许的范围, Solidity 中的变量就可以被用来组织攻击。 今年 4 月,黑客对 BEC 智能合
约进行溢出漏洞攻击,造成代币增发贬值。
  OpenZepplin 提供了一个 SafeMath 库,可以保障数值避免出现溢出,能够有效的避免
溢出漏洞的出现

chapter10:SafeMath第二部分

  出现了一个新关键词:library。可以利用using关键字让library中的方法运用在其他数据类型上。比如:

  1. using SafeMath for uint;
  2. // now we can use these methods on any uint
  3. uint test = 2;
  4. test = test.mul(3); // test now equals 6
  5. test = test.add(5); // test now equals 11

在safeMath库中,有一个assert语句,和require类似,会抛出异常。和require不同的是,require失败会返还gas,但assert不会。

  所以在solidity中我们对数值进行操作时一定要使用safemath库,比如:

  1. myUint++;

  更改为:

  1. myUint = myUint.add(1);

chapter 11:  

  但是存在一个问题,safemath是针对uint256的,如果输入的数据是uint16或uint8之类,会强制转换成uint256,那么对于uint8溢出的数据转换后就不溢出了,容易造成错误。

  所以safemath库中还提供了safemath32,safemath16的library,可以直接using调用。

chapter12:

  编程时加一些标签是一个好习惯:

  //这是一个普通注释

  ///@notice:这时候一个带标签的netspec tag。标签有@title,@author,@notice解释该合约或函数做什么,@dev解释对开发者的更多细节,@param,@return。

到这里整个教程的代码部分就结束了,下一章学习的是如何部署智能合约。

CryptoZombies学习笔记——Lesson5的更多相关文章

  1. CryptoZombies学习笔记——Lesson1

    CryptoZombies是一个学习以太坊开发的平台,我将在这里记录学习过程中的一些笔记. 课程网址:cryptozombies.io 首先是第一课——Lesson1:Making the Zombi ...

  2. CryptoZombies学习笔记——Lesson3

    第三课就开始深入讲解solidity编程技巧了. chapter1: 智能合约的不变性. 合约一旦部署到以太坊后,就不可更改了,所以从一方面来说,智能合约代码的安全性是如此重要,因为一旦发现你的代码里 ...

  3. CryptoZombies学习笔记——Lesson2

    第二课是僵尸猎食,将把app变得更像一个游戏,添加多人模式,建立更多创造僵尸的方法. chapter1 依然是简介 chapter2:映射和地址 映射相当于一个索引,指向不同地址,不同地址存储的数据不 ...

  4. CryptoZombies学习笔记——Lesson4

    第四课主要介绍payable函数相关. chapter1: payable修饰函数 以太坊允许同时调用函数和eth转账.msg.value显示发送到合约的以太币数,ether是内置整型数.如果函数没有 ...

  5. 孙鑫视频VC++深入详解学习笔记

    孙鑫视频VC++深入详解学习笔记 VC++深入详解学习笔记 Lesson1: Windows程序运行原理及程序编写流程 Lesson2: 掌握C++基本语法 Lesson3: MFC框架程序剖析 Le ...

  6. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  7. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  8. PHP-会员登录与注册例子解析-学习笔记

    1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...

  9. 2014年暑假c#学习笔记目录

    2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...

随机推荐

  1. GPUImage源码解读之GPUImageFramebuffer

    简介 OpenGL ES的FrameBuffer是渲染发生的地方,普通的2D图形的渲染默认发生在屏幕上:而三维的图形渲染则除了包括像素点的颜色,还有Depth Buffer,Stencil Buffe ...

  2. 使用bareos备份

    官方文档http://doc.bareos.org/master/html/bareos-manual-main-reference.html bareos主要由主控端和客户端构成: 包含的重要的服务 ...

  3. RPM包、YUM、system初始化进程基本知识

  4. 关于ajax请求数据的方法

    $.ajax({  //课程详情信息    type:'get',     data: {'id':courseId},    dataType:'json',        beforeSend : ...

  5. django的render的特殊用法

    以前都是将模板渲染好, 传输到前端, 但是现在前后端分离了, 模板渲染引擎还有用, 而且很好用. 比如在渲染一个表格的时候, 每一行都有两个操作按钮, 并且这个按钮上是有a标签的 你可以使用字符串拼接 ...

  6. 献给初学者:小白该如何学习Linux操作系统

    一. 选择适合自己的Linux发行版 谈到linux的发行版别,太多了,可能谁也不能给出一个准确的数字,但是有一点是能够必定的,linux正在变得越来越盛行, 面临这么多的Linux 发行版,打算从别 ...

  7. PTA基础编程题目集7-2然后是几点

    有时候人们用四位数字表示一个时间,比如1106表示11点零6分.现在,你的程序要根据起始时间和流逝的时间计算出终止时间. 读入两个数字,第一个数字以这样的四位数字表示当前时间,第二个数字表示分钟数,计 ...

  8. Shuffling Machine

    7-43 Shuffling Machine(20 分) Shuffling is a procedure used to randomize a deck of playing cards. Bec ...

  9. lvs健康检查脚本第三版

    如下是学习完马哥视频lvs后改写的健康检查脚本第三版.利用工作之余三四个小时时间才把整个逻辑搞清楚,有时候自己都有点蒙圈,尤其是在写到while循环的时候.总的来说非常感谢马哥的慷慨解囊!脚本原稿及思 ...

  10. WPF 为 PasswordBox 控件添加水印,最低级版

    原因也很直接,老板需要,一开始为TextBox发愁,就找了这个控件凑合用,至于版权什么的,内部工具也不卖钱,而且我不懂英文,也就无视了: Extended WPF Toolkit™ Community ...