很久没写合约了,今天一写很多语法都忘记了,整理一下把
语法 | 描述 |
---|---|
public | 公有,任何人(拥有以太坊账户的)都可以调用 牢记 |
private | 私有, 只有智能合约内部可以调用 牢记 |
external | 仅合约外部可以调用,合约内部需使用this调用 先忽略 |
internal | 仅合约内部和继承的合约可以调用 先忽略 |
view/constant | 函数会读取但是不会修改任何contract的状态变量 牢记 |
pure(纯净的) | 函数不使用任何智能合约的状态变量 牢记 |
payable | 调用函数需要付钱,钱付给了智能合约的账户 牢记 |
returns | 返回值函数声明中使用 |
状态变量默认是internal的(先理解为private即可)
pragma solidity ^0.4.24;
contract Test {
//状态变量
//类型不匹配时需要显示转换类型
//返回值需要使用returns描述
//public/private 可以修饰状态变量
//状态变量默认是私有的
uint256 public ui256 = 100;
int8 private i10 = -10;
//private 修饰的函数为私有的,只有合约内部可以调用
function add() private view returns(uint256) {
return ui256 + uint256(i10);
}
function isEqueal() public view returns(bool) {
return ui256 == uint256(i10);
}
//Public修饰的函数为共有的,合约内外都可以调用
function Add() public view returns(uint256){
return add();
}
}
view,constant,pure讲解
pragma solidity ^0.4.24;
contract test1 {
int8 public i8 = 100; //成员变量就是状态变量
int i256 = 256;
//表示不会修改函数内的状态变量
//为了明确语义,一般要加上constant(view两者完全相同)
function add() private constant returns(int) {
return i8 + i256;
}
//public 表示所有的人都可以看到的,而且可以调用
//private表示所有人都可以看到,但是无法调用
function mins() constant returns(uint256) {
return uint256(i256 - i8);
}
function isEqual(int a, int b) public pure returns(bool) {
return a == b;
}
function setValue(int8 num) {
i8 = num;
}
function setValue1(int8 num) constant {
i8 = num;
}
}
payable
pragma solidity ^0.4.24;
contract test1 {
uint128 public num;
//如果构造函数中未指定payable关键字,那么创建合约时不允许转账
//如果指定了payable,则可以转账
constructor() public {
}
//任何函数,只要指定了payable关键字,这个合约就可以接受转账,调用时,也可以转0
function giveMoney() public payable {
}
}
构造函数 仅在部署合约时调用一次,完成对合约的初始化。可以在创建合约时转钱到合约
相当于go里面的init函数
注意,所有在合约内的东西对外部的观察者来说都是可见,将某些东西标记为private仅仅阻止了其它合约来进行访问和修改,但并不能阻止其它人看到相关的信息。
- 匿名函数 用于转账 一个合约可以有且只有一个匿名函数,此函数不能有参数,也不能有任何返回值,当我们企图去执行一个合约上没有的函数时,那么合约就会执行这个匿名函数。
当合约在只收到以太币的时候,也会调用这个匿名函数,而且一般情况下会消耗很少的gas,所以当你接收到以太币后,想要执行一些操作的话,你尽可以把你想要的操作写到这个匿名函数里,因为这样做成本非常便宜。
//如果想向合约转账,在合约中添加如下函数即可
function() payable {
//函数体什么都不填
}
contract Test {
function() { x = 1; }
uint x;
}
contract Caller {
function callTest(address testAddress) {
Test(testAddress).call('0xabcdefgh'); // hash does not exist
// results in Test(testAddress).x becoming == 1.
}
}