pragma solidity ^0.4.0;

contract test {
uint [5] T =[1,2,3,4,5] ;//固定长度的数组:可修改数组内值大小,不支持push,不可更改长度 /*
contract test {
uint [] T = new uint[](5); //ParserError: Expected identifier but got 'storage'
//全局数组,默认创建在storage中,无法创建在memory中,长度可修改
function setlength(uint aa){
uint [] memory a = new uint[](5);
bytes [] memory b = new bytes[](5);
//TypeError: Type bytes memory[] memory is not implicitly
//convertible to expected type bytes storage ref[] storage pointer.
//函数内创建数组,需要指定存储在memory中,a.length不可更改
//a.length = 10; // TypeError: Expression has to be an lvalue
a[2] = 5;
}
}
*/
function setValue(uint para){
T[0] = para;
}
/*
uint [] T =[1,2,3,4,5] ; //动态长度的数组:可修改数组内值大小,支持push,可更改长度 /*
uint [] T1 = new uint[](5); constructor() public{
for (uint i;i<T1.length;i++){
T1[i] = i;
}
}
*/
function setlenth(uint para){
T.length = 6;
} function addvalue(uint para){
T.push(3);
}
*/ function setValue1(){
T[0] = 10;
}
function getValue() constant returns(uint){
return T.length;
} function get1Value() constant returns(uint){
return T[0];
}
} pragma solidity ^0.4.0; contract test {
//二维数组
uint [2][3] T = [[1,2],[2,3]];
/*
1,2
2,3
0,0
*/ uint [2][] T1 = new uint[2][](5); /*[i][j] T.length = j
0,0
0,0
0,0
0,0
0,0
*/
function getlenth() constant returns(uint){
return T.length; //
} function getlenth1() constant returns(uint){
return T1.length; //
} function get1lenth() constant returns(uint[2][]){ //输出二维数组
return T1; //
}
} pragma solidity ^0.4.0; contract test {
function setValue() public{ g([1,2,3]); //uint8
//TypeError: Invalid type for argument in function call.
//Invalid implicit conversion from uint8[3] memory to uint256[3] memory requeste g([uint(1),2,3]);
}
//uint 256
function g(uint[3] data){
} uint [] x1 = [uint(1),2,3];
//storage:可变数组 memory:固定数组
function get1() public{
uint [] memory x = [uint(1),2,3];
//memory:可变数组 memory:固定数组
//在函数内部,memory类型的固定长度的数组不可直接赋值给storge/memory类型的可变数组
//TypeError: Invalid type for argument in function call.
//Invalid implicit conversion from uint8[3] memory to uint256[3] memory requested
}
function get1() public constant returns(uint[]){
return x1; //uint256[]: 1,2,3 == [1,2,3]
//uint [] memory x = [uint(1),2,3];
//TypeError: Invalid type for argument in function call.
//Invalid implicit conversion from uint8[3] memory to uint256[3] memory requested
} pragma solidity ^0.4.0; contract test { bytes3 public b = 0x123456; //bytes3: 0x123456 byte[3] public b1; //b1=0x000000 可直接通过索引进行查询 bytes public b2= new bytes(3); //bytes: 0x000000 == byte[] public b3 = new byte[](3) byte[] public b3 = new byte[](3); // 0x000000 可直接通过索引进行查询 /*
function setb() public{
b[0] =0x01;
}
*/ function setb1() public{
b1[0] =0x01;
} function setb2(bytes aa)public {
for (uint i;i<aa.length;i++){
b2.push(aa[i]);
}
}
}
/*
总结:创建固定大小字节数组/可变大小字节数组
固定大小字节数组:
bytes0~bytes32:长度不可变,内容不可修改
byte[len] b :长度不可变,内容可以修改
可变大小字节数组:可直接通过索引进行查询
bytes b = new bytes(len) == byte[] b = new byte[](len)
特殊的可变字节数组:
string :bytes() 通过bytes转换,length获取长度,通过索引修改相应的字节内容
固定大小字节数组 -> 可变大小字节数组
bytes3 a;
bytes [] b = new bytes[a.length]
for (uint i;i<a.length;i++){
b[i] = a[i]
}
return b; uint [5] T =[1,2,3,4,5] ;//固定长度的数组:可修改数组内值大小,不支持push,不可更改长度
uint [] T =[1,2,3,4,5] ; //动态长度的数组:可修改数组内值大小,支持push,可更改长度 uint [] T = new uint[](5); //ParserError: Expected identifier but got 'storage'
//全局数组,默认创建在storage中,无法指定在memory中,长度可修改 //函数内创建数组,需要指定存储在memory中,a.length不可更改 uint [] x1 = [uint(1),2,3] //[uint(1),2,3] = [1,2,3];
//storage:可变数组 memory:固定数组
*/
}

ethereum(以太坊)(十一)--字节数组(二)的更多相关文章

  1. ethereum(以太坊)(十一)--字节数组(一)

    pragma solidity ^0.4.0; contract byte1{ /* 固定大小字节数组(Fixed-size byte arrays) 固定大小字节数组可以通过bytes1,bytes ...

  2. ethereum(以太坊)(一)

    从这周开始,开始学习以太坊开发--solidity,开始决定往区块链方向发展,毕竟区块链技术应用广泛.一开始接触solidity开发语言不太习惯,毕竟一直在学习python语法,有很多都不能接受.有难 ...

  3. 创建自己的加密货币MNC——以太坊代币(二)

    创建一个基于以太坊平台的分红币MNC,根据持有的代币数量,进行分红的算法.github地址: https://github.com/lxr1907/MNC 1.使用以太坊根据比例换购token MNC ...

  4. ethereum(以太坊)(四)--值传递与引用传递

    contract Person { string public _name; function Person() { _name = "liyuechun"; } function ...

  5. 以太坊开发教程(二) 利用truffle发布宠物商店 DAPP 到 以太坊测试环境Ropsten

    1.环境安装 1) node安装 设置镜像地址: curl --silent --location https://rpm.nodesource.com/setup_8.x | bash -下载安装 ...

  6. ethereum(以太坊)(基础)--容易忽略的坑(二)

    pragma solidity ^0.4.0; contract EMath{ string public _a="lin"; function f() public{ modif ...

  7. ethereum(以太坊)(十二)--应用(二)__投票(基础总和)

    编写应用合约之前,先弄清它的逻辑,有助于我们更好的部署合约 pragma solidity ^0.4.21; pragma experimental ABIEncoderV2; contract vo ...

  8. ethereum(以太坊)(十二)--应用(一)__集资(构造函数/映射)

    pragma solidity ^0.4.4; contract funder{ //0xca35b7d915458ef540ade6068dfe2f44e8fa733c //0x14723a09ac ...

  9. ethereum(以太坊)(二)--合约中属性和行为的访问权限

    pragma solidity ^0.4.0; contract Test{ /* 属性的访问权限 priveta public internal defualt internal interlnal ...

随机推荐

  1. logback.xml日志文件过滤器配置简析

    自定义过滤器 java代码,目的是在mdc中放值,然后在日志中打印 package com.controller; import com.pojo.JsonData; import org.slf4j ...

  2. Spring文件上传Demo

    package com.smbea.controller; import java.io.File; import java.io.FileOutputStream; import java.io.I ...

  3. GitHub webstorm 及 README.md 姿势

    README.md 语法格式: 规范的README文件开头都写上一个标题,这被称为大标题. 标题: #一级标题 ##二级标题 ###三级标题 ####四级标题 #####五级标题 ######六级标题 ...

  4. sql注入【手工及一些工具】

    Sql注入原理分析: 网站程序存在可控传递参数,参数未进行过滤直接带入数据库查询,导致攻击者可通过传递恶意sql语句代码进行执行攻击. Sql注入产生条件 1.必须有参数传递 2.参数值带入数据库查询 ...

  5. Vim插件推荐

    看下文时要知道我的<leader>键就是\. ctags C程序阅读辅助工具.在看C/C++代码的时候经常需要在文件之间跳来跳去,这是很麻烦的事,ctags就是解决这种问题的.ctags是 ...

  6. MySQL数据库实验六:存储过程建立与调用

    实验六  存储过程建立与调用 一.实验目的 理解存储过程的概念.建立和调用方法. 二.实验环境 三.实验示例 1.定义一个函数,按性别计算所有学生的平均年龄. CREATE FUNCTION aver ...

  7. 377. Combination Sum IV 70. Climbing Stairs

    back function (return number) remember the structure class Solution { int res = 0; //List<List< ...

  8. CRUD全栈式编程架构总结

    这里放出实例代码 github.com/SkyvenXiong/HCC

  9. EF写INNER JOIN 链接

    面对多表的查询,一般都是多表连接后下面再写条件,但是有一种写法可以提升一下EF生成的语句的效率 首先先去查询每一个表,把每一个表对应的条件附加上去,注意:过滤数据最多的条件放在首先位置 var lt ...

  10. 反射java

    所谓反射(Refection),其实就是程序自己能够检查自身信息,就像程序会通过镜子反光来看自己本身一样.反射使得 Java语言具有了“动态性”,即程序首先会检查某个类中的方法.属性等信息,然后再动态 ...