solidity 数学和密码学函数

数学和密码学函数为开发者提供了一系列强大的工具,用于执行各种数学运算和加密操作

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 不为 0
    return 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 不为 0
        return 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));
    }
}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值