数学和密码学函数为开发者提供了一系列强大的工具,用于执行各种数学运算和加密操作
addmod(uint x, uint y, uint k) returns (uint)
计算 (x + y) % k,加法会在任意精度下执行,并且加法的结果即使超过 2**256 也不会被截取。
从 0.5.0 版本的编译器开始会加入对 k != 0 的校验(assert)。
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;contract AddModExample {// 使用 addmod 函数计算 (x + y) % k// 20 % 3 = 2// 3 * 6 = 18 // 20 - 18 function safeModAdd( uint256 x, uint256 y, uint256 k ) public pure returns (uint256) {// require(k != 0, "Modulus cannot be 0"); // 确保模数 k 不为 0return addmod(x, y, k);}
}
mulmod(uint x, uint y, uint k) returns (uint)
计算 (x * y) % k,乘法会在任意精度下执行,并且乘法的结果即使超过 2**256 也不会被截取。
从 0.5.0 版本的编译器开始会加入对 k != 0 的校验(assert)。
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;contract AddModExample {// 使用 addmod 函数计算 (x + y) % k// 20 % 3 = 2// 3 * 6 = 18 // 20 - 18 function safeModAdd( uint256 x, uint256 y, uint256 k ) public pure returns (uint256) {// require(k != 0, "Modulus cannot be 0"); // 确保模数 k 不为 0return mulmod(x, y, k);}
}
keccak256(bytes memory) returns (bytes32)
计算输入的 Keccak-256 哈希值。
备注
以前 keccak256 的别名叫 sha3 ,在 0.5.0 版本中被删除。
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;contract AddModExample {function safeModAdd( string calldata _a ) public pure returns (bytes32 ) {return keccak256(bytes(_a));}
}
ripemd160(bytes memory) returns (bytes20)
计算输入的 RIPEMD-160 哈希值。
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;contract AddModExample {function safeModAdd( string calldata _a ) public pure returns (bytes20 ) {return ripemd160(bytes(_a));}
}