Solidity 赋值运算符

Solidity 支持的赋值运算符,如下表所示:

序号 运算符与描述
1 = (简单赋值)
将右侧操作数的值赋给左侧操作数
例: C = A + B 表示 A + B 赋给 C
2 += (相加赋值)
将右操作数添加到左操作数并将结果赋给左操作数。
例: C += A 等价于 C = C + A
3 −= (相减赋值)
从左操作数减去右操作数并将结果赋给左操作数。
例: C -= A 等价于 C = C – A
4 *= (相乘赋值)
将右操作数与左操作数相乘,并将结果赋给左操作数。
例: C *= A 等价于 C = C * A
5 /= (相除赋值)
将左操作数与右操作数分开,并将结果分配给左操作数。
例: C /= A 等价于 C = C / A
6 %= (取模赋值)
使用两个操作数取模,并将结果赋给左边的操作数。
例: C %= A 等价于 C = C % A

注意: 同样的逻辑也适用于位运算符,因此它们将变成<<=、>>=、>>=、&=、|=和^=。

 

示例

下面的代码展示了如何使用赋值运算符。

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
contract SolidityTest {
   uint storedData; 
   constructor() {
      storedData = 10;   
   }
   function getResult() public pure returns(string memory){
      uint a = 1; 
      uint b = 2;
      uint result = a + b;
      return integerToString(result); 
   }
   function integerToString(uint _i) internal pure 
      returns (string memory) {
      if (_i == 0) {
         return "0";
      }
      uint j = _i;
      uint len;
      while (j != 0) {
         len++;
         j /= 10; // 赋值运算
      }
      bytes memory bstr = new bytes(len);
      uint k = len - 1;
      while (_i != 0) {
         bstr[k--] = byte(uint8(48 + _i % 10));
         _i /= 10;// 赋值运算
      }
      return string(bstr);  // 访问局部变量
   }
}

运行上述程序,输出结果:

0: string: 10

Solidity 支持条件运算符。序号运算符与描述1? : (条件运算符 )如果条件为真 ? 则取值X : 否则值Y示例下面的代码展示了如何使用这个运算符// SPDX-License-Identifier: ...