怎么编写代码计算UTXO

本篇内容主要讲解“怎么编写代码计算UTXO”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么编写代码计算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 };
}

到此,相信大家对“怎么编写代码计算UTXO”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/219927.html

(0)
上一篇 2022年1月2日
下一篇 2022年1月2日

相关推荐

发表回复

登录后才能评论