From 25ec9c5081ec7e42f4d5f2ed0f206fc786081796 Mon Sep 17 00:00:00 2001 From: yingying Date: Fri, 20 Sep 2024 15:46:20 +0800 Subject: [PATCH] Update resource.md --- docs/mechanism-algorithm/resource.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/mechanism-algorithm/resource.md b/docs/mechanism-algorithm/resource.md index f48bedb..9e47b56 100644 --- a/docs/mechanism-algorithm/resource.md +++ b/docs/mechanism-algorithm/resource.md @@ -150,7 +150,7 @@ B: 30_000_000_000 且energy_limit 为30_000_000_000 合理设置feeLimit,一方面能尽量保证正常执行;另外一方面,如果合约所需Energy过大,又不会过多消耗调用者的trx。在设置feeLimit之前,需要了解几个概念: 1. 合法的feeLimit为0 - 15*10^9 之间的整数值,单位是sun,折合0 - 15000 trx; -2. 不同复杂度的合约,每次正常执行消耗不同的Energy;相同合约每次消耗的Energy基本相同[^1],但由于动态能量模型机制,对于热门合约,不同时刻执行时可能需要的能量不同,具体请参考[动态能量模型章节]();执行合约时,逐条指令计算并扣除Energy,如果超过feeLimit的限制,则合约执行失败,已扣除的Energy不退还; +2. 不同复杂度的合约,每次正常执行消耗不同的Energy;相同合约每次消耗的Energy基本相同[^1],但由于动态能量模型机制,对于热门合约,不同时刻执行时可能需要的能量不同,具体请参考[动态能量模型章节](#_10);执行合约时,逐条指令计算并扣除Energy,如果超过feeLimit的限制,则合约执行失败,已扣除的Energy不退还; 3. 目前feeLimit仅指调用者愿意承担的Energy折合的trx[^2];执行合约允许的最大Energy还包括开发者承担的部分; 4. 一个恶意合约,如果最终执行超时,或者因bug合约崩溃,则会扣除该合约允许的所有energy; 5. 开发者可能会承担一定比例的Energy消耗(比如承担90%)。但是,当开发者账户的Energy不足以支付时,剩余部分完全由调用者承担。在feeLimit限制范围内,如调用者的Energy不足,则会燃烧等价值的trx。[^2]