1. 程式人生 > >solidity智慧合約[29]-函式作用域

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 ;
   }
   }

}

image.png