CryptoZombies学习笔记——Lesson5
chapter1:token代币
简而言之,通证就是支持交易的包含一系列规范的函数接口的一个智能合约,发币可以用ERC20标准,但是像僵尸这种非同质化代币,需要用ERC721标准
chapter2:erc721 和多继承
erc721目前仍是草稿,没有官方建议标准。
contract ERC721 {
event Transfer(address indexed _from, address indexed _to, uint256 _tokenId);
event Approval(address indexed _owner, address indexed _approved, uint256 _tokenId);
function balanceOf(address _owner) public view returns (uint256 _balance);
function ownerOf(uint256 _tokenId) public view returns (address _owner);
function transfer(address _to, uint256 _tokenId) public;
function approve(address _to, uint256 _tokenId) public;
function takeOwnership(uint256 _tokenId) public;
}
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中的方法运用在其他数据类型上。比如:
using SafeMath for uint;
// now we can use these methods on any uint
uint test = 2;
test = test.mul(3); // test now equals 6
test = test.add(5); // test now equals 11
在safeMath库中,有一个assert语句,和require类似,会抛出异常。和require不同的是,require失败会返还gas,但assert不会。
所以在solidity中我们对数值进行操作时一定要使用safemath库,比如:
myUint++;
更改为:
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的更多相关文章
- CryptoZombies学习笔记——Lesson1
CryptoZombies是一个学习以太坊开发的平台,我将在这里记录学习过程中的一些笔记. 课程网址:cryptozombies.io 首先是第一课——Lesson1:Making the Zombi ...
- CryptoZombies学习笔记——Lesson3
第三课就开始深入讲解solidity编程技巧了. chapter1: 智能合约的不变性. 合约一旦部署到以太坊后,就不可更改了,所以从一方面来说,智能合约代码的安全性是如此重要,因为一旦发现你的代码里 ...
- CryptoZombies学习笔记——Lesson2
第二课是僵尸猎食,将把app变得更像一个游戏,添加多人模式,建立更多创造僵尸的方法. chapter1 依然是简介 chapter2:映射和地址 映射相当于一个索引,指向不同地址,不同地址存储的数据不 ...
- CryptoZombies学习笔记——Lesson4
第四课主要介绍payable函数相关. chapter1: payable修饰函数 以太坊允许同时调用函数和eth转账.msg.value显示发送到合约的以太币数,ether是内置整型数.如果函数没有 ...
- 孙鑫视频VC++深入详解学习笔记
孙鑫视频VC++深入详解学习笔记 VC++深入详解学习笔记 Lesson1: Windows程序运行原理及程序编写流程 Lesson2: 掌握C++基本语法 Lesson3: MFC框架程序剖析 Le ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- PHP-自定义模板-学习笔记
1. 开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2. 整体架构图 ...
- PHP-会员登录与注册例子解析-学习笔记
1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...
- 2014年暑假c#学习笔记目录
2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...
随机推荐
- python 爬虫简介以及使用方法
阶段大纲: 一. 爬虫 1. 基本操作 - 登录任意网站(伪造浏览器的任何行为) 2. 性能相关 - 并发方案: - 异步IO: gevent/Twisted/asyncio/aiohttp - 自定 ...
- vue-router笔记
1.vue-router 安装 在安装webpack模块时就安装了 eg: vue init webpack demo (安装webpack模块并取名为demo) 在安装模块时没有安装的话 ...
- 20181.5IDEAx64位授权码
转载于:https://blog.csdn.net/q258523454/article/details/79775092 2DZ8RPRSBU-eyJsaWNlbnNlSWQiOiIyRFo4UlB ...
- LinkedList的源码分析(基于jdk1.8)
1.初始化 public LinkedList() { } 并未开辟任何类似于数组一样的存储空间,那么链表是如何存储元素的呢? 2.Node类型 存储到链表中的元素会被封装为一个Node类型的结点.并 ...
- hadoop生态搭建(3节点)-15.Nginx_Keepalived_Tomcat配置
# Nginx+Tomcat搭建高可用服务器名称 预装软件 IP地址Nginx服务器 Nginx1 192.168.6.131Nginx服务器 Nginx2 192.168.6.132 # ===== ...
- 【NXP开发板应用—智能插排】3.驱动GPIO点亮外接LED
[前言] 首先感谢深圳市米尔科技有限公司举办的这次活动并予以本人参加这次活动的机会,以往接触过嵌入式,但那都是皮毛,最多刷个系统之类的,可以说对于嵌入式系统开发这件事情是相当非常陌生的,这次活动为我提 ...
- eval函数的作用
eval函数的作用是去掉字符串最外侧的引号,并按照Python的语法执行去掉引号后的字符内容. [实例1] x=eval("12+36")print(x) #结果为48此例中,去 ...
- 解决brew下载php(不存在libphp7.so)
我是一名PHP的初学者,在mac上安装php7参考作者 coolma <在mac中如何安装php7>: 1. 安装Homebrew(mac ox不可或缺套件管理器,方便快捷的安装插件等) ...
- FPGA算法学习(1) -- Cordic(Verilog实现)
上两篇博文Cordic算法--圆周系统之旋转模式.Cordic算法--圆周系统之向量模式做了理论分析和实现,但是所用到的变量依然是浮点型,而cordic真正的用处是基于FPGA等只能处理定点的平台.只 ...
- JavaWeb——升级赛-学生成绩管理系统(2).java---19.01.03
dao.java package Dao; import java.sql.Connection;import java.sql.ResultSet;import java.sql.SQLExcept ...