温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么编写代码计算UTXO

发布时间:2021-12-18 10:32:49 来源:亿速云 阅读:158 作者:iii 栏目:互联网科技

本篇内容主要讲解“怎么编写代码计算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”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI