如何在 Solidity 中生成随机数?

Solidity 中的数字生成是在Solidity 智能合约中创建随机数的过程。这可用于各种目的,例如为对象生成唯一 ID、在游戏中创建随机结果或选择随机参与者进行抽奖。

数字生成是 Solidity 的一个重要特性,因为它允许智能合约具有更大的灵活性和功能。

要在 Solidity 中生成随机数,请按照以下步骤操作:

 1. 创建一个​​RandomNumber​​合约

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
contract RandomNumber {

}

2. 创建一个名为的函数​​generateRandomNumber​​​,它不接受任何参数并返回一个​​uint​​值。

function generateRandomNumber() public view returns (uint) {
    // code to generate random number goes here
}

3. 在​​generateRandomNumber​​​函数内部,创建一个名为的变量​​timestamp​​​,用于存储当前块的时间戳。这可以使用​​block.timestamp​​变量获得。

function generateRandomNumber() public view returns (uint) {
    uint timestamp = block.timestamp;
}

4. 使用​​keccak256​​​库对​​timestamp​​​变量进行散列并将生成的散列存储在​​bytes32​​​名为 的变量中​​hash​​。

function generateRandomNumber() public view returns (uint) {
    uint timestamp = block.timestamp;
    bytes32 hash = keccak256(abi.encodePacked(timestamp));
}
  1. 使用​​bytesToUint​​​函数将 ​​hash​​​ 转为 ​​uint​​ 类型
function generateRandomNumber() public view returns (uint) {
    uint timestamp = block.timestamp;
    bytes32 hash = keccak256(abi.encodePacked(timestamp));
    return bytesToUint(hash);
}

6. 合约中​​bytesToUint​​​函数的作用是 byte32 转 uint256:

function bytesToUint(bytes32 b) public pure returns (uint256) {
    uint256 number;
    for (uint256 i = 0; i < b.length; i++) {
        number = number + uint8(b[i]) * (2**(8 * (b.length - (i + 1))));
    }
    return number;
}

最终代码

如何在 Solidity 中生成随机数?_随机数

运行效果

如何在 Solidity 中生成随机数?_Solidity_02

注意:该方法的随机性取决于区块时间戳,并不一定是真正随机的。建议使用更安全的方法生成随机数,例如使用随机数预言机服务。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值