- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在建立一个权益池,作为使用 Solidity 学习智能合约的一种方式。抵押奖励将根据用户的余额和抵押时间计算。问题是在质押过程中,余额可能会发生变化。
那么我怎样才能实现公平的奖励分配呢?可以计算每个区块的奖励分配吗?
最佳答案
您需要将赌注保存在一个数组中,而不是一个聚合变量中。
这是一个可以进一步优化的示例代码,有些部分(如支付)根本没有实现。但它清楚地显示了基于一系列股份的奖励计算,并考虑了每个股份的块数。
pragma solidity ^0.8.1;
contract StakingContract {
struct Stake {
address user;
uint256 amount;
uint64 sinceBlock;
uint64 untilBlock;
}
Stake[] stakes;
uint256 constant public percentPerBlock = 1; // TODO use more granular units
event LogPayout(address user, uint256 stakedAmount, uint256 rewardAmount);
function stake(uint256 _amount) external returns (uint256 stakeId) {
stakes.push(Stake(msg.sender, _amount, uint64(block.timestamp), 0));
return stakes.length - 1;
}
function unstake (uint256 _id) external {
require(stakes[_id].user == msg.sender, 'Not your stake');
require(stakes[_id].untilBlock == 0, 'Already unstaked');
stakes[_id].untilBlock = uint64(block.timestamp);
uint256 stakedForBlocks = (block.timestamp - stakes[_id].sinceBlock);
uint256 rewardAmount = stakes[_id].amount * stakedForBlocks * percentPerBlock / 100;
emit LogPayout(stakes[_id].user, stakes[_id].amount, rewardAmount);
// TODO actual payout
}
function viewUserTotalUnclaimedRewards(address _user) external view returns (uint256) {
uint256 totalUnclaimedRewards;
for(uint256 i = 0; i < stakes.length; i++) {
if (stakes[i].user == _user && stakes[i].untilBlock == 0) {
uint256 stakedForBlocks = (block.timestamp - stakes[i].sinceBlock);
uint256 rewardAmount = stakedForBlocks * percentPerBlock / 100;
totalUnclaimedRewards += rewardAmount;
}
}
return totalUnclaimedRewards;
}
}
笔记:
stake()
功能推新 Stake
结构到 stakes
阵列 unstake()
函数集untilBlock
一个特定的数组项,将其标记为完成 viewUserTotalUnclaimedRewards()
View 函数迭代该用户所有未完成(未设置 untilBlock
)的赌注,并将赌注金额和奖励加在一起 关于solidity - 如何可靠地计算每个区 block 的用户质押奖励?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63217281/
我想知道大括号在那种情况下是什么意思? uint64 configCount = s_configCount; { s_hotVars.latestConfigDigest = c
我正在运行一个独立的单用户 v5 节点实体服务器。当我以该单个用户身份登录时,我能够在一个不存在的容器中创建一个文档,并且服务器会为我创建该容器。 例如 POST https://my.server:
我想覆盖以下继承函数: function _setBaseURI(string memory baseURI) public override(ERC721Full, ERC721Metadata
我定义了一个映射类型的状态变量,例如映射(uint256 => uint256[])。我想将其公开,以便我可以从契约(Contract)外部访问它。但是,编译器报告错误 TypeError: Wron
我正在处理 Solidity 智能合约,并且正在导入 openzeppelin-solidity 库和 chainlink 库。 两者都有 SafeMath 库;我正在用 Python 加载所有 .s
我在以下示例中遇到了 Solidity Documentation 并且在我的项目中有类似的代码并想设置 default value如果键不是从调用者传递过来的,则到 key 参数 pragma so
据我所知,有两种方法可以获得某个地址的余额。 address firstAddress; "firstAddress.balance"这将获得地址“firstAddress”的余额。 address
我正在使用 solidity 构建一个 NFT 智能合约,并且我试图在部署合约时将 Array of Structs 传递到构造函数中。但是我收到以下错误。 TypeError: Cannot rea
免费的 Everscale Solidity。如何与负责 职能部门合作?如何正确等待回调并从sdk查看合约执行结果? 例如,我有契约(Contract)(没有任何用处)。如何在我的应用程序中以正确的方
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 3 年前。 Improve
我最近在很多代码中注意到人们将硬编码的配置(如端口号等)值放在类/方法的深处,使其难以找到,也无法配置。 这是否违反了 SOLID 原则?如果不是,我是否可以向我的团队成员引用另一个“原则”来说明为什
Solidity 最近的变化将回退函数格式从只是 function() 更改为 fallback(),这对于初学者来说非常好理解发生了什么,但是我有一个问题,关于编译器在我实现时给我的建议后备。 例如
如果我有类似的东西 class square : figure {} class triangle : figure {} 这是否意味着我永远不应该使用正方形和三角形类而只能引用图形? 永远不要这样做
我正在尝试将字节可靠地转换为 uint256。这是坚固的代码, // SPDX-License-Identifier: MIT pragma solidity 0.8.13; contract Sam
我想在 SolidJS 中动态设置 JSX 标签名称。我来自 React it is fairly simple to do : /* Working ReactJS Code: */ export
我正在尝试将字节可靠地转换为 uint256。这是坚固的代码, // SPDX-License-Identifier: MIT pragma solidity 0.8.13; contract Sam
我想在 SolidJS 中动态设置 JSX 标签名称。我来自 React it is fairly simple to do : /* Working ReactJS Code: */ export
我正在继续开发 ASP.NET 应用程序(基于 Web 表单),其中以前的开发人员没有遵循良好的面向对象设计原则,即 SOLID (http://www.remondo.net/solid-princ
我创建了 ERC20 代币,我想将我的代币转移到另一个地址。 我的元掩码中有两个帐户。(帐户 A/B) 我的 ERC20 代码在这里(我在账户 A 中部署并保存了代币) pragma solidity
struct Test { uint ui; string s; } function test(Test t) public { emit Log(t.ui, t.s); } 我对 AB
我是一名优秀的程序员,十分优秀!