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的更多相关文章

  1. 区块链入门到实战(27)之以太坊(Ethereum) – 智能合约开发

    智能合约的优点 与传统合同相比,智能合约有一些显著优点: 不需要中间人 费用低 代码就是规则 区块链网络中有多个备份,不用担心丢失 避免人工错误 无需信任,就可履行协议 匿名履行协议 以太坊(Ethe ...

  2. 零门槛,包教会。让你在5分钟内使用以太坊ERC20智能合约发行属于自己的空气币

    前言 目前区块链是互联网中最最火的风口,没有之一.我周围的很多朋友也加入了“炒币”行列,但很不幸,几乎都被“割韭菜”了.而经过我的几天研究,发现,如果自己要发行一种空气币,简直太简单了.只需要下面几个 ...

  3. 以太坊solidity智能合约-生成随机数

    Solidity随机数生成 在以太坊的只能合约中,没有提供像其他面向对象编程一样的生成随机数的工具类或方法.其实,所谓的随机数也是伪随机的,没有哪一种语言能够真正的生成随机数. 对于solidity来 ...

  4. 从零构建以太坊(Ethereum)智能合约到项目实战——第23章 从零构建和部署去中心化投票App,decentralization Voting Dapp

    P90 .1-从零构建和部署去中心化投票App-01 P91 .2-从零构建和部署去中心化投票App-02 P92 .3-从零构建和部署去中心化投票App-03 参考博文:http://liyuech ...

  5. 从零构建以太坊(Ethereum)智能合约到项目实战——第20章 搭建自己的私有链网络

    P75 .1-以太坊私网建立 .合约编译.部署完全教程(1) 使用此博文进行安装配置:https://blog.csdn.net/w88193363/article/details/79402074 ...

  6. 从零构建以太坊(Ethereum)智能合约到项目实战——第22章 玩转truffle framework 、Web3.js 框架

    P84 .1-玩转truffle framework.Web3.js 框架 内容介绍 truffle官方网站:https://truffleframework.com/ P85 .2-truffle ...

  7. 以太坊solidity智能合约语言学习资源整理

    暂时看到篇文章写的不错,先收集下来,后面有机会自己也整理一个 Solidity语言学习(一)Solidity语言学习(二)——Solidity的安装与编译Solidity语言学习(三)——智能合约编程 ...

  8. 以太坊区块链Java(EthereumJ)学习笔记:概述

    本系列文章介绍以太坊区块链基于Java语言的解决方案.通过介绍EthereumJ定义的主要模块和Class,希望为大家学习和使用EthereumJ提供一些帮助. 整体架构 以太坊的Java解决方案主要 ...

  9. 从零构建以太坊(Ethereum)智能合约到项目实战——第24章 IPFS + 区块链

    P93 .1-IPFS环境配置P94 .2-IPFS+P .IPNS+P .个人博客搭建 - 如何在IPFS新增一个文件P95 .3-IPFS+P .IPNS+P .个人博客搭建 - 通过ipfs创建 ...

随机推荐

  1. Codeforces Round #610 (Div. 2)E(模拟,DFS)

    先找到一条多边形的边,然后循环一圈输出多边形上的点.把每个三角形看作一个结点,以两个三角形之间公用边为边建立一张图,DFS输出叶子结点,则得到先切后切的顺序. #define HAVE_STRUCT_ ...

  2. Linux 设备驱动IO操作

    每个外设都是通过读写其寄存器来控制的.外设寄存器也称为I/O端口,通常包括:控制寄存器.状态寄存器和数据寄存器三大类. 根据CPU体系结构的不同,CPU对IO端口的编址方式有两种: (1)I/O映射方 ...

  3. git和github的关系以及简单易懂的理解

    git和github的关系   写在前面:我身边好多人问我git和github的区别,想必对于好多人没学过的大佬们恐怕也是一脸懵逼,但是不知道也是不行的,所以我今天就来讲一讲这二者的区别和联系. 用一 ...

  4. 给footer标签设置padding:7px auto;失效

    margin:auto可以做到水平居中,前提条件就是,这个标签是块状元素,并且有个确定的宽度,百分比的宽度也行: padding的话, 设置成auto它会自动继承浏览器的padding值, 当设置pa ...

  5. NET com组件注册

    1.签名 右击项目->属性->[签名]标签, 选中[为程序集签名]–>[选择强名称密钥文件]–>[新建],输入你的密钥名称,去掉[使用密码保护密钥文件] 最重要的签名,并且注册 ...

  6. python web django 2nd level -- 待更新

    练习代码位置 实例代码位置 --> app: myblog Form 利用Form表单验证,自己写的html 思路: 新建一个类 LoginForm(forms.Form) 新建对象 obj = ...

  7. powermt命令介绍

    转载:http://blog.itpub.net/26442936/viewspace-2153417/ 介绍 PowerPath将多路径I/O功能.自动负载平衡和路径故障切换功能集成于一身,使存储管 ...

  8. 如何在app.js 和其他页面中更改globalData的值

    它不能用this.setData方法更改值,该方法只能更改data:{}对象(而且在app.js中无法使用该方法),因此用app.globalData.isLogin = true;

  9. 「NOIP2018」赛道修建

    传送门 Luogu 解题思路 一眼先二分(上界树的直径,下界最小边权),然后再考虑 \(\text{DP}\). 对于当前节点 \(u\),在它的所有儿子中分别返回一条匹配不完的长度最大的路径 \(M ...

  10. 聊聊面试中常问的GC机制

    GC 中文直译垃圾回收,是一种回收内存空间避免内存泄漏的机制.当 JVM 内存紧张,通过执行 GC 有效回收内存,转而分配给新对象从而实现内存的再利用. JVM GC 机制虽然无需开发主动参与,减轻不 ...