solidity智能合约[29]-函数作用域
1、当状态变量中已经有了一个变量a、状态变量中就不能够再有一个同名的状态变量。
2、当状态变量中和函数体内部已经有了都有一个同名的函数的时候,默认处理的是函数体内部的变量。也就是说,变量的操作和其他语言一样,仍然满足就近原则。
1
2
3
4
5
6
7
8
9
10
uint public a = 100;
uint b = 200;
// uint public a = 999; 当状态变量中已经有了一个变量a、状态变量中就不能够再有一个同名的状态变量。
function scopeTest() pure public returns(uint){
uint a = 88;
a = 77; //修改的是函数体内部的a
return a ;//返回的是函数体内部的a。
}
3、在函数的参数中,可以有和状态变量同名的函数a。
但是一旦函数中参数中有了变量名字为a,函数体内部的任何位置都不能再次有对于a的定义。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
function scopeTest2(uint a) pure public returns(uint){
//错误1
// uint a = 0;
//错误2
// for(uint a = 0;a<8;a++){
// }
//错误3:
{
// uint a = 0;
a = 99; //可以修改
return a ;//可以返回
}
}
完整代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
pragma solidity ^0.4.23;
contract scope{
uint public a = 100;
uint b = 200;
// uint public a = 999;
function scopeTest() pure public returns(uint){
uint a = 88;
a = 77;
return a ;
}
function scopeTest2(uint a) pure public returns(uint){
// uint a = 0;
// for(uint a = 0;a<8;a++){
// }
{
// uint a = 0;
a = 99;
return a ;
}
}
}
本文链接:https://dreamerjonson.com/2018/11/22/solidity-29-function-scpoe/
版权声明:本博客所有文章除特别声明外,均采用CC BY 4.0 CN协议许可协议。转载请注明出处!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。