最近写智能合约代码发现一个问题,我写了一个读区块链的函数,结果发现这个读区块链的函数执行后居然上链了!这有点颠覆我的认知,我一直以为只有写区块链才需要上链,因为写区块链会导致区块链状态发生改变。而读区块链应该不会才对!经过我不断的怀疑,测试,验证终于发现一个秘密。下面就是我读区块链功能类似的代码,我用更直接的方式写出来:
pragma solidity >=0.4.0 <0.7.0;
contract Hello {
string hello = "hello, world";
function sayHello() public returns (string memory) {
return hello;
}
}
代码看上去绝对人畜无害。但是用remix部署以后就成了下面这个样子
可以看到执行sayHello后确实通知了metamask钱包进行签名交易。最后上链了,如下图所示:
后来我发现,是因为sayHello这个函数没有用view修饰。如果用view修饰以后就执行sayHello不会上链了。
这真是一个让人大跌眼镜的问题,而且实在是没有道理。上不上链完全是由关键字view决定的。那如果一个写区块链操作用view修饰会发生什么情况呢?
结果是没有语法错误,但是不会上链。
pragma solidity >=0.4.0 <0.7.0;
contract Hello {
string hello = "hello, world";
function sayHello() public returns (string memory) {
return hello;
}
function setHello(string _hello) public view {
hello = _hello;
}
}
有兴趣的小伙伴们可以自己去尝试一下。