十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
本篇内容主要讲解“怎么编写代码计算UTXO”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么编写代码计算UTXO”吧!
成都创新互联公司-专业网站定制、快速模板网站建设、高性价比安州网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式安州网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖安州地区。费用合理售后完善,十载实体公司更值得信赖。
const TX_TYPE_IN = 1; const TX_TYPE_OUT = 2; export const CreateUtxos = async (address: string, data: any) => { let mapData = new Map(); let temp = new Map(); for (const iter of data) { mapData.set(iter.hash, iter); // console.log(iter.hash); let type = TX_TYPE_IN; for (const input of iter.inputs) { if (input.coin.coinbase) continue; if (address == input.coin.address) { type = TX_TYPE_OUT; } } let out = -1; let balance = 0; for (const output of iter.outputs) { out++; if (address == output.address) { balance = output.value; break; } } temp.set(iter.hash, { type, out, balance, spentTxid: null, spentHeight: 0 }); } for (const [key, value] of mapData) { for (const input of value.inputs) { if (input.coinbase) continue; if (temp.has(input.prevout.hash)) { const pre = temp.get(input.prevout.hash); const local = temp.get(key); if (pre.spentHeight <= 0 && (pre.type != local.type || local.type == TX_TYPE_OUT)) { pre.spentTxid = value.hash; pre.spentHeight = value.height; } } } } let balance = 0; let unspentList: Array= []; for (const [key, value] of temp) { if (value.spentHeight === 0) { balance += value.balance; // console.info(key, value.out); unspentList.push(value); } /*else { temp.delete(key); }*/ } // return {balance, unspentList: Array.from(temp.values())} return { balance, unspentList }; }
到此,相信大家对“怎么编写代码计算UTXO”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!