您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“怎么編寫代碼計(jì)算UTXO”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“怎么編寫代碼計(jì)算UTXO”吧!
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<any> = []; 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 }; }
到此,相信大家對“怎么編寫代碼計(jì)算UTXO”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。