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: ...