从零构建以太坊(Ethereum)智能合约到项目实战——学习笔记10
P57 、1-Solidity Types - 玩转 Solidity 数组 (Arrays)
学习目标
1、掌握Arrays的可变不可变的创建
2、深度理解可变数组和不可变数组之间的区别
3、二维数组
4、memory arrays的创建
5、bytes0~bytes32、bytes与byte[]对比
P58 、2-固定长度的数组(Arrays)系统讲解
固定长度类型数组的声明
pragma solidity ^0.4.; contract C{
//数组的长度为5,数组里面的存储的值的类型为uint类型
uint [] T = [,,,,];
}
通过Length方法获取数组长度遍历数组求总和
pragma solidity ^0.4.; contract C{
//数组的长度为5,数组里面的存储的值的类型为uint类型
uint [] T = [,,,,]; //通过for循环计算数组内部的值的总和
function numbers() constant public returns (uint){
uint num = ;
for(uint i= ; i < T.length ; i++){
num = num + T[i];
}
return num;
}
}
尝试修改T数组的长度
pragma solidity ^0.4.; contract C{
//数组的长度为5,数组里面的存储的值的类型为uint类型
uint [] T = [,,,,]; function setTLength(uint len) public {
//报错
T.length = len;
}
}
PS:声明数组时,一旦长度固定,将不能在修改数组的长度。
尝试修改T数组内部值
pragma solidity ^0.4.; contract C{
//数组的长度为5,数组里面的存储的值的类型为uint类型
uint [] T = [,,,,]; function setTIndex0Value() public {
T[] = ;
} //通过for循环计算数组内部的值的总和
function numbers() constant public returns (uint){
uint num = ;
for(uint i= ; i < T.length ; i++){
num = num + T[i];
}
return num;
}
}
PS:通过一个简单的试验可证明固定长度的数组只是不可修改它的长度,不过可以修改它内部的值,而bytes0~bytes32固定大小字节数组中,大小固定,内容固定,长度和字节均不可修改。
尝试通过push往T数组中添加值
pragma solidity ^0.4.; contract C{
//数组的长度为5,数组里面的存储的值的类型为uint类型
uint [] T = [,,,,]; function pushUintToT() public {
//报错
T.push();
}
}
PS:固定大小的数组不能调用push方法向里面添加存储内容。
P59 、3-可变长度的Arrays(上)
可变长度类型数组的声明
pragma solidity ^0.4.; contract C{
//数组的长度为5,数组里面的存储的值的类型为uint类型
uint [] T = [,,,,]; //通过for循环计算数组内部的值的总和
function T_Length() constant returns(uint) {
return T.length;
}
}
通过Length方法获取数组长度遍历数组求总和
pragma solidity ^0.4.4; contract C{
//数组的长度为5,数组里面的存储的值的类型为uint类型
uint [] T = [1,2,3,4,5]; //通过for循环计算数组内部的值的总和
function numbers() constant public returns (uint){
uint num = 0;
for(uint i=0 ; i < T.length ; i++){
num = num + T[i];
}
return num;
}
}
尝试修改T数组的长度
pragma solidity ^0.4.4; contract C{
//数组的长度为5,数组里面的存储的值的类型为uint类型
uint [] T = [1,2,3,4,5]; function setTLength(uint len) public {
T.length = len;
}
function TLength() constant returns(uint){
return T.length;
}
}
PS:对可变长度的数组而言,可随时通过length修改数组的长度。
尝试通过push往T数组中添加值
pragma solidity ^0.4.; contract C{
//数组的长度为5,数组里面的存储的值的类型为uint类型
uint [] T = [,,,,]; function T_Length() constant public returns (uint){
return T.length;
} function pushUintToT() public {
T.push();
} //通过for循环计算数组内部的值的总和
function numbers() constant public returns (uint){
uint num = ;
for(uint i= ; i < T.length ; i++){
num = num + T[i];
}
return num;
}
}
PS:当往里面增加一个值,数组的个数就会加1,当求和时也会将新增的数字加起来。
P60 、4-可变长度的Arrays(下)
pragma solidity ^0.4.; contract C{
uint [] T = new uint[](5); function C(){
for(uint i=;i<;i++){
T[i] = i+;
}
for(i=;i<;i++){
T.push(i+);
}
} //通过for循环计算数组内部的值的总和
function numbers() constant public returns (uint){
uint num = ;
for(uint i= ; i < T.length ; i++){
num = num + T[i];
}
return num;
}
}
P61 、5-Solidity 二维数组
P62 、6-创建 Memory Arrays
P63 、7-数组字面量 Array Literals 内联数组 Inline Arrays
P64 、8-创建固定大小字节数组/可变大小字节数组
P65 、Solidity Types - 枚举(Enums)
P66 、Solidity Types - Solidity 结构体(Structs)
P67 、Solidity Types - Solidity 字典/映射(Mappings)
P68 、集资(CrowdFunding)智能合约(Smart Contract)综合案例
P69 、单位(Units) 和 全局变量(Globally Available Variables)
P70 、1-Solidity 元组(Tuples)- 什么是元组,元组能做什么
P71 、2-Solidity 元组(Tuples)的使用
P72 、1-truffle framework初体验 - 如何编写智能合约
truffle官网:https://truffleframework.com/
开发环境为:ubuntu
先安装nodejs,安装完查看版本
node --version
v10.12.0
安装truffle框架
# npm install -g truffle
# truffle version
Truffle v5.0.1 (core: 5.0.1)
Solidity v0.5.0 (solc-js)
Node v10.12.0
P73 、2-建立简易的加密代币
P74 、3-通过zeppelin-solidity建立标准代币部落币「P 、BLC」
从零构建以太坊(Ethereum)智能合约到项目实战——学习笔记10的更多相关文章
- 区块链入门到实战(27)之以太坊(Ethereum) – 智能合约开发
智能合约的优点 与传统合同相比,智能合约有一些显著优点: 不需要中间人 费用低 代码就是规则 区块链网络中有多个备份,不用担心丢失 避免人工错误 无需信任,就可履行协议 匿名履行协议 以太坊(Ethe ...
- 零门槛,包教会。让你在5分钟内使用以太坊ERC20智能合约发行属于自己的空气币
前言 目前区块链是互联网中最最火的风口,没有之一.我周围的很多朋友也加入了“炒币”行列,但很不幸,几乎都被“割韭菜”了.而经过我的几天研究,发现,如果自己要发行一种空气币,简直太简单了.只需要下面几个 ...
- 以太坊solidity智能合约-生成随机数
Solidity随机数生成 在以太坊的只能合约中,没有提供像其他面向对象编程一样的生成随机数的工具类或方法.其实,所谓的随机数也是伪随机的,没有哪一种语言能够真正的生成随机数. 对于solidity来 ...
- 从零构建以太坊(Ethereum)智能合约到项目实战——第23章 从零构建和部署去中心化投票App,decentralization Voting Dapp
P90 .1-从零构建和部署去中心化投票App-01 P91 .2-从零构建和部署去中心化投票App-02 P92 .3-从零构建和部署去中心化投票App-03 参考博文:http://liyuech ...
- 从零构建以太坊(Ethereum)智能合约到项目实战——第20章 搭建自己的私有链网络
P75 .1-以太坊私网建立 .合约编译.部署完全教程(1) 使用此博文进行安装配置:https://blog.csdn.net/w88193363/article/details/79402074 ...
- 从零构建以太坊(Ethereum)智能合约到项目实战——第22章 玩转truffle framework 、Web3.js 框架
P84 .1-玩转truffle framework.Web3.js 框架 内容介绍 truffle官方网站:https://truffleframework.com/ P85 .2-truffle ...
- 以太坊solidity智能合约语言学习资源整理
暂时看到篇文章写的不错,先收集下来,后面有机会自己也整理一个 Solidity语言学习(一)Solidity语言学习(二)——Solidity的安装与编译Solidity语言学习(三)——智能合约编程 ...
- 以太坊区块链Java(EthereumJ)学习笔记:概述
本系列文章介绍以太坊区块链基于Java语言的解决方案.通过介绍EthereumJ定义的主要模块和Class,希望为大家学习和使用EthereumJ提供一些帮助. 整体架构 以太坊的Java解决方案主要 ...
- 从零构建以太坊(Ethereum)智能合约到项目实战——第24章 IPFS + 区块链
P93 .1-IPFS环境配置P94 .2-IPFS+P .IPNS+P .个人博客搭建 - 如何在IPFS新增一个文件P95 .3-IPFS+P .IPNS+P .个人博客搭建 - 通过ipfs创建 ...
随机推荐
- Codeforces Round #610 (Div. 2)E(模拟,DFS)
先找到一条多边形的边,然后循环一圈输出多边形上的点.把每个三角形看作一个结点,以两个三角形之间公用边为边建立一张图,DFS输出叶子结点,则得到先切后切的顺序. #define HAVE_STRUCT_ ...
- Linux 设备驱动IO操作
每个外设都是通过读写其寄存器来控制的.外设寄存器也称为I/O端口,通常包括:控制寄存器.状态寄存器和数据寄存器三大类. 根据CPU体系结构的不同,CPU对IO端口的编址方式有两种: (1)I/O映射方 ...
- git和github的关系以及简单易懂的理解
git和github的关系 写在前面:我身边好多人问我git和github的区别,想必对于好多人没学过的大佬们恐怕也是一脸懵逼,但是不知道也是不行的,所以我今天就来讲一讲这二者的区别和联系. 用一 ...
- 给footer标签设置padding:7px auto;失效
margin:auto可以做到水平居中,前提条件就是,这个标签是块状元素,并且有个确定的宽度,百分比的宽度也行: padding的话, 设置成auto它会自动继承浏览器的padding值, 当设置pa ...
- NET com组件注册
1.签名 右击项目->属性->[签名]标签, 选中[为程序集签名]–>[选择强名称密钥文件]–>[新建],输入你的密钥名称,去掉[使用密码保护密钥文件] 最重要的签名,并且注册 ...
- python web django 2nd level -- 待更新
练习代码位置 实例代码位置 --> app: myblog Form 利用Form表单验证,自己写的html 思路: 新建一个类 LoginForm(forms.Form) 新建对象 obj = ...
- powermt命令介绍
转载:http://blog.itpub.net/26442936/viewspace-2153417/ 介绍 PowerPath将多路径I/O功能.自动负载平衡和路径故障切换功能集成于一身,使存储管 ...
- 如何在app.js 和其他页面中更改globalData的值
它不能用this.setData方法更改值,该方法只能更改data:{}对象(而且在app.js中无法使用该方法),因此用app.globalData.isLogin = true;
- 「NOIP2018」赛道修建
传送门 Luogu 解题思路 一眼先二分(上界树的直径,下界最小边权),然后再考虑 \(\text{DP}\). 对于当前节点 \(u\),在它的所有儿子中分别返回一条匹配不完的长度最大的路径 \(M ...
- 聊聊面试中常问的GC机制
GC 中文直译垃圾回收,是一种回收内存空间避免内存泄漏的机制.当 JVM 内存紧张,通过执行 GC 有效回收内存,转而分配给新对象从而实现内存的再利用. JVM GC 机制虽然无需开发主动参与,减轻不 ...