区块链2026年5月26日15 分钟阅读

BSV 交易手续费如何计算:输入总额减去输出总额

BSV 交易手续费不是独立字段,而是输入总额减去输出总额。理解这个规则有助于正确处理找零、估算费用、管理 UTXO,并避免把余额误作为手续费。

林知衡

林知衡

technical_editor

分享

在 BSV 交易中,手续费不是一个单独写在交易里的字段。它来自一个简单但非常关键的规则:

TEXT
1fee = sum(inputs) - sum(outputs)

也就是说,交易的所有输入金额减去所有输出金额,差额就是手续费。矿工通过这部分差额获得交易处理费用。

这个规则看似简单,但对手动构造交易、管理 UTXO、估算费用和排查交易失败都非常重要。尤其是忘记创建找零 output 时,可能会把原本属于自己的余额全部变成手续费。

一句话理解:手续费来自输入输出差额

BSV 采用 UTXO 模型。交易会消耗旧的输出作为 input,再创建新的 output。

在这个模型里,并没有一个字段专门写着:

TEXT
1fee = 5 satoshis

手续费是通过金额差额隐含表达的:

TEXT
1手续费 = 输入总额 - 输出总额

只要输入总额大于输出总额,剩下没有被分配到任何 output 的金额,就会被视为矿工可获得的手续费。

BSV 交易手续费如何计算:输入总额减去输出总额 文章封面

手续费如何计算

假设一笔交易有两个 input:

  • input 1:1000 satoshis
  • input 2:500 satoshis

输入总额为:

TEXT
11000 + 500 = 1500 satoshis

这笔交易创建两个 output:

  • output 0:给收款人 600 satoshis
  • output 1:找零 895 satoshis

输出总额为:

TEXT
1600 + 895 = 1495 satoshis

那么手续费就是:

TEXT
11500 - 1495 = 5 satoshis

交易本身不会额外保存一个“手续费字段”。矿工和节点可以通过输入输出金额直接计算出这笔交易支付了多少费用。

为什么采用这种设计

在 UTXO 模型中,input 的作用是消耗已有的 UTXO,output 的作用是创建新的 UTXO。

如果一笔交易消耗了 1500 satoshis 的旧输出,却只创建了 1495 satoshis 的新输出,那么少掉的 5 satoshis 并没有被分配给任何接收方。协议会把这部分差额视为交易手续费。

这种设计有几个特点:

  • 不需要额外的手续费字段。
  • 手续费与交易结构直接绑定。
  • 任何人都可以通过输入输出金额验证费用。
  • 手续费计算与 UTXO 消耗、找零创建天然结合。

因此,只要你手动构造交易,就必须明确每个 input 的金额、每个 output 的金额,以及最后留下多少差额作为手续费。

忘记找零 output 的后果

忘记找零是手动构造交易时最常见、也最严重的错误之一。

假设你有一个金额为 100000 satoshis 的 UTXO,想给别人支付 1000 satoshis。

如果你只创建一个 output:

TEXT
1output:给收款人 1000 satoshis

那么交易手续费会变成:

TEXT
1100000 - 1000 = 99000 satoshis

也就是说,剩下的 99000 satoshis 不会自动回到你的钱包,而是全部成为手续费。

你原本可能只想支付 2 satoshis 手续费,但由于没有创建找零 output,整个未分配余额都会被协议视为费用。

钱包通常会自动处理找零,包括选择 inputs、创建收款 output、创建找零 output 和估算手续费。但如果你在代码中手动构造交易,就必须显式创建找零 output,并确保输出总额与预期手续费匹配。

手续费和交易大小的关系

手续费通常与交易大小有关。交易越大,需要支付的费用可能越多。

影响交易大小的因素包括:

  • input 数量
  • output 数量
  • 脚本长度
  • OP_RETURN 数据大小
  • 签名数量
  • 是否包含额外证明或背景数据

因此,转账金额小并不意味着交易体积一定小。

例如,一笔只转出很少金额的交易,如果包含大量 inputs,或者携带较大的 OP_RETURN 数据,也可能成为一笔体积较大的交易。矿工和交易处理服务通常会结合费率、交易大小和自身策略判断是否接受交易。

对于大交易,可以参考 BSV TypeScript SDK 的 Large Transactions guide:

https://bsv-blockchain.github.io/ts-sdk/guides/large-transactions/

BSV 的低费不等于零费

BSV 强调低费用,目标是支持微支付和高频数据交易。但低费并不等于零费,也不意味着可以无限制提交垃圾数据。

开发者仍然需要考虑:

  • 最低可接受费用
  • dust output
  • 交易大小
  • 矿工 policy
  • 服务商 API 限制
  • 大批量交易的总成本

低费用是 BSV 的重要优势之一,但它需要工程上的费用估算和 UTXO 管理配合。对于生产应用来说,费用不是可以忽略的细节,而是交易构造、广播和运营成本的一部分。

手续费与矿工激励

矿工处理交易、打包区块,需要获得经济激励。

在 Bitcoin/BSV 中,矿工收入主要来自两部分:

  • 区块补贴
  • 交易手续费

随着区块补贴长期下降,交易手续费会变得越来越重要。

BSV 的经济模型强调低费高量:单笔交易手续费可以很低,但如果交易数量足够大,总手续费仍然可以支撑交易处理者的收入。

因此,低手续费并不是取消激励,而是把经济模型建立在更高交易量和更低单笔成本之上。

SDK 与钱包如何处理费用

使用 @bsv/sdk 或钱包接口时,很多费用细节通常会被自动处理。

钱包或 SDK 相关工具通常会完成:

  • 选择 inputs
  • 创建收款 outputs
  • 创建找零 output
  • 估算手续费
  • 签名交易

但自动处理并不意味着开发者可以完全不了解费用机制。生产应用仍然可能遇到以下问题:

  • 费用估算失败
  • 交易过大
  • 余额足够但 UTXO 不合适
  • 服务返回费用不足
  • 重试时产生重复交易

理解“手续费 = 输入总额 - 输出总额”有助于开发者排查这些问题。例如,当服务提示费用不足时,可以检查交易大小、input/output 金额、找零设置以及使用的费率是否符合矿工或服务商策略。

ARC 相关实现可参考:

https://github.com/bitcoin-sv/arc

新手常见误解

下面这些误解在交易构造和调试中很常见:

  • 手续费不是交易里的独立 output。
  • 手续费等于输入总额减输出总额。
  • 忘记找零会让剩余金额全部变成手续费。
  • 低费不等于零费。
  • 转账金额小不代表交易体积小。
  • 多 input 交易可能需要更多手续费。
  • 钱包自动估费不代表永远不会出错。

实践建议

如果你正在手动构造 BSV 交易,建议始终检查以下事项:

  1. 明确所有 input 的金额。

  2. 明确所有收款 output 的金额。

  3. 显式创建找零 output。

  4. 用公式计算实际手续费:

    TEXT
    1fee = sum(inputs) - sum(outputs)
  5. 检查交易大小是否符合预期。

  6. 确认费用满足矿工或交易处理服务的 policy。

  7. 对大批量交易进行总成本估算。

只要掌握这个核心规则,BSV 交易中的费用问题就会清晰很多:钱不是“额外扣掉”的,而是在输入输出之间没有被重新分配的那部分,成为了手续费。

参考资料

专题

BSV基础知识

第16篇 / 共43篇文章

系统整理 BSV、区块链基础概念、协议能力和生态知识的专题文章。

查看专题

阅读路径

进度 16/43

  1. 01
    第 1 篇

    为什么 BSV 仍然值得关注

    阅读文章

    关于结算设计、数据持久性,以及为什么建设者仍在关注 BSV。

    2026年4月30日5 分钟阅读
  2. 02
    第 2 篇

    P2P Electronic Cash:什么是点对点电子现金?

    阅读文章

    点对点电子现金是理解 Bitcoin 和 BSV 的入口。它强调通过交易、签名和公开账本直接转移数字价值,而不是依赖中心平台账户。本文解释 peer-to-peer、cash、双花、UTXO 以及 BSV 为什么重视低费用、高频交易和链上数据。

    2026年5月19日15 分钟阅读
  3. 03
    第 3 篇

    时间戳服务器:区块链为什么是时间顺序记录?

    阅读文章

    区块链不只是账本,更是一台公开的时间排序机器。本文解释 Bitcoin/BSV 中 timestamp server 的含义、区块高度与确认数的作用,以及时间戳在防双花和数据存证场景中的价值。

    2026年5月20日15 分钟阅读
  4. 04
    第 4 篇

    Proof of Work:矿工为什么能排序交易?

    阅读文章

    Proof of Work 通过“计算昂贵、验证便宜”的机制,让矿工在开放网络中竞争新区块,并用累积工作量决定交易历史排序。本文解释 PoW 的工作原理、矿工为何能排序交易、其安全意义,以及 BSV 在大区块、低费用和高交易量方向下的矿工经济逻辑。

    2026年5月20日5 分钟阅读
  5. 05
    第 5 篇

    BSV 网络如何运转:交易、区块、手续费与矿工激励

    阅读文章

    本文用最基础的视角解释 BSV 网络的运行机制:交易如何构成、区块如何组织、矿工如何获得激励,以及为什么 BSV 特别强调低手续费、大区块和高吞吐链上交易。

    2026年5月20日15 分钟阅读
  6. 06
    第 6 篇

    SPV 入门:轻客户端为什么不需要下载全链

    阅读文章

    SPV(简化支付验证)让轻客户端无需下载完整区块链,也能验证某笔交易是否被包含在区块中。本文解释 SPV 的工作原理、Merkle proof 的作用、它能证明什么、不能证明什么,以及为什么 SPV 是 BSV 架构中的核心能力。

    2026年5月20日15 分钟阅读
  7. 07
    第 7 篇

    BSV 与 BTC/BCH 的路线差异:为什么强调链上扩容、低费和企业数据

    阅读文章

    BTC、BCH、BSV 都源自 Bitcoin,但技术路线明显不同。本文从链上扩容、低费用、稳定协议、SPV、企业数据和现实挑战出发,系统解释 BSV 为什么选择低费高量和大规模链上扩展路线。

    2026年5月20日15 分钟阅读
  8. 08
    第 8 篇

    WIF、助记词与 HD Wallet:BSV 钱包密钥管理入门

    阅读文章

    WIF、助记词和 HD Wallet 都与密钥保存、恢复和派生有关,但含义不同。本文解释它们的区别、xpub 的作用,以及在 BSV 钱包和应用开发中的安全实践。

    2026年5月20日25 分钟阅读
  9. 09
    第 9 篇

    BSV 主网 mainnet 与测试环境有什么区别

    阅读文章

    主网承载真实价值,测试环境用于学习和开发。本文梳理 BSV mainnet 与测试环境的区别、常见风险、SDK 使用中的注意事项,以及项目配置中的分环境建议。

    2026年5月24日5 分钟阅读
  10. 10
    第 10 篇

    钱包不是账户系统:BSV 钱包管理的是密钥和 UTXO

    阅读文章

    BSV 钱包不是传统账户系统。链上没有单一余额字段,钱包通过管理私钥、UTXO、交易构造和签名来计算余额并发起交易。理解这一点,有助于正确认识找零、多输入、非托管钱包和应用授权等关键概念。

    2026年5月24日15 分钟阅读
  11. 11
    第 11 篇

    BRC-100:钱包与应用之间的标准接口

    阅读文章

    BRC-100 是 BSV 生态中描述应用与钱包如何通信的接口标准。它强调应用表达业务意图,钱包保留密钥控制权,帮助非托管应用以更安全、统一的方式请求创建交易、签名和返回结果。

    2026年5月24日8 分钟阅读
  12. 12
    第 12 篇

    Transaction Input 是什么:理解 BSV 交易输入与 UTXO 引用

    阅读文章

    Transaction input 是 BSV 交易的资金来源,它引用上一笔交易中的某个未花费 output,并提供解锁数据。理解 input 有助于掌握 UTXO 模型、outpoint、双花冲突、手续费计算和交易调试。

    2026年5月26日15 分钟阅读
  13. 13
    第 13 篇

    理解 BSV Transaction Output:金额、Locking Script 与 UTXO

    阅读文章

    Transaction output 是 BSV 交易创建的新价值单元,通常由金额和 locking script 组成。它既可以表示付款和找零,也可以承载 OP_RETURN 数据、token 状态或业务记录。理解 output、UTXO 和 output index,是理解 BSV 交易与应用协议设计的基础。

    2026年5月26日15 分钟阅读
  14. 14
    第 14 篇

    TXID 是什么:BSV 交易唯一标识的作用、误区与设计建议

    阅读文章

    TXID 是 BSV 中最常见的交易标识,可用于查询交易、引用 output、保存业务记录和构建 SPV 证明。但 TXID 标识的是整笔交易,不等于 output,也不代表交易已最终完成。实际应用中应结合 output index、状态、raw transaction 和证明材料一起保存。

    2026年5月26日15 分钟阅读
  15. 15
    第 15 篇

    理解 BSV 交易中的找零 output:为什么它必须显式写入交易

    阅读文章

    找零 output 是 BSV UTXO 模型中的关键概念:旧 UTXO 必须整体花费,未用完的金额需要通过新的 output 退回给付款方。本文解释找零的工作方式、手续费关系、找零地址、隐私影响以及 UTXO 管理中的实践问题。

    2026年5月26日15 分钟阅读
  16. 16
    第 16 篇当前

    BSV 交易手续费如何计算:输入总额减去输出总额

    阅读文章

    BSV 交易手续费不是独立字段,而是输入总额减去输出总额。理解这个规则有助于正确处理找零、估算费用、管理 UTXO,并避免把余额误作为手续费。

    2026年5月26日15 分钟阅读
  17. 17
    第 17 篇

    什么是 raw transaction:BSV 交易序列化、TXID 与签名的基础

    阅读文章

    raw transaction 是交易按协议规则序列化后的原始字节表示,通常以十六进制字符串展示。它关系到 TXID、签名、广播和调试,是理解 BSV 交易底层机制的关键概念。

    2026年5月26日10 分钟阅读
  18. 18
    第 18 篇

    BSV 交易调试中的 Endian 问题:为什么 TXID 看起来会反过来

    阅读文章

    Endian 是 BSV 交易调试中常见的字节序问题,尤其容易出现在 raw transaction、TXID、outpoint、数字字段和 Merkle proof 中。理解显示格式与底层序列化字节的区别,可以避免很多“TXID 不匹配”或“proof 算错”的误判。

    2026年5月26日12 分钟阅读
  19. 19
    第 19 篇

    什么是 UTXO:理解 BSV 交易模型的基础

    阅读文章

    UTXO 是“未花费交易输出”,是 BSV 交易模型的基本单位。钱包余额并不是链上的账户字段,而是一组可控制 UTXO 的金额总和。理解 UTXO,有助于理解 BSV 的 input、output、找零、手续费、双花、Script 以及并行处理。

    2026年5月27日15 分钟阅读
  20. 20
    第 20 篇

    在 BSV 中,花钱就是消耗旧 UTXO、创造新 UTXO

    阅读文章

    在 BSV 中,花钱不是修改余额,而是消耗旧 UTXO、创建新 UTXO。理解这一点,有助于掌握付款、找零、交易链以及 token 和应用状态转移的基本逻辑。

    2026年5月27日12 分钟阅读
  21. 21
    第 21 篇

    一个地址可以有很多 UTXO:理解 BSV 中的地址、余额与交易构造

    阅读文章

    在 BSV 的 UTXO 模型中,一个地址不是账户,也不是单一余额槽。同一个地址可以关联多个 UTXO,钱包余额只是这些 UTXO 的汇总。理解这一点,有助于正确处理交易构造、手续费、UTXO 碎片化和隐私问题。

    2026年5月27日5 分钟阅读
  22. 22
    第 22 篇

    UTXO 模型为什么适合并行处理?——BSV 扩容的技术基础

    阅读文章

    UTXO 模型将状态拆分为独立输出,使得交易验证可以并行进行,为 BSV 的链上扩容和高吞吐提供了关键数据结构基础。本文对比账户模型与 UTXO 模型,解释并行性原理、实际限制以及与 Teranode 和应用设计的关系。

    2026年6月2日3 分钟阅读
  23. 23
    第 23 篇

    理解比特币双花问题:为什么同一个 UTXO 不能被花两次

    阅读文章

    双花是数字现金系统的核心问题。本文用通俗语言解释双花的原理、交易结构、矿工作用、0-conf 风险、签名与双花的关系,以及工程实践中的注意事项。

    2026年6月2日3 分钟阅读
  24. 24
    第 24 篇

    理解 BSV 中的 Locking Script:花费条件的核心机制

    阅读文章

    Locking script 是 BSV 交易中不可或缺的部分,它定义了 UTXO 的花费条件。本文从基础概念出发,逐步解析 locking script 的位置、与地址的关系、表达方式及其在应用中的重要性。

    2026年6月2日3 分钟阅读
  25. 25
    第 25 篇

    深入理解 Unlocking Script:区块链交易的“开锁证据”

    阅读文章

    Unlocking Script 是交易输入中的解锁材料,用于满足上一笔输出的锁定条件。本文从概念、位置、工作原理到常见误解,全面解析这一关键机制。

    2026年6月2日3 分钟阅读
  26. 26
    第 26 篇

    P2PKH:BSV 中最常见的支付脚本模板详解

    阅读文章

    P2PKH(Pay to Public Key Hash)是 Bitcoin/BSV 中最基础的普通支付脚本。本文拆解其核心逻辑、工作流程、与地址的关系、解锁条件,并解释为什么 BSV 开发者需要理解它。

    2026年6月2日2 分钟阅读
  27. 27
    第 27 篇

    OP_RETURN:BSV链上数据写入入门

    阅读文章

    了解OP_RETURN的基本概念、与普通支付的区别、数据格式要求、隐私注意事项以及应用场景。

    2026年6月2日2 分钟阅读
  28. 28
    第 28 篇

    解读Bitcoin Script:基于栈的脚本语言及其执行模型

    阅读文章

    Bitcoin Script是一种基于栈执行的脚本语言,用于验证交易花费条件。本文从栈的概念出发,通过例子说明其执行过程,并探讨P2PKH、受限设计、BSV应用等关键点,帮助理解这一链上验证语言的核心机制。

    2026年6月2日2 分钟阅读
  29. 29
    第 29 篇

    标准脚本 vs 非标准脚本:BSV 开发中容易被忽略的边界

    阅读文章

    共识上有效的交易,网络不一定处理。理解标准脚本与矿工策略,避免交易广播失败。

    2026年6月2日3 分钟阅读
  30. 30
    第 30 篇

    从零开始使用 @bsv/sdk:安装、验证与第一步

    阅读文章

    介绍 @bsv/sdk 的安装、项目搭建与验证过程,帮助开发者快速进入 BSV 开发环境,理解 SDK 在技术栈中的角色。

    2026年6月15日3 分钟阅读
  31. 31
    第 31 篇

    WalletClient:应用与钱包之间的通信入口

    阅读文章

    WalletClient 是 BSV 应用中连接钱包的标准化客户端,它让应用描述交易意图,钱包负责授权、签名和 UTXO 管理,从而隔离私钥、UTXO 和签名等复杂度。

    2026年6月15日3 分钟阅读
  32. 32
    第 32 篇

    使用 createAction() 创建你的第一笔 BSV 交易:入门指南

    阅读文章

    createAction() 是 BSV SDK 的核心方法,让应用通过高级接口描述交易动作,钱包自动处理签名、费用和广播。本文带你理解其原理、参数和实际用法。

    2026年6月15日3 分钟阅读
  33. 33
    第 33 篇

    自动选择 inputs、找零和手续费:钱包如何为你构建完整交易

    阅读文章

    使用高级SDK时,钱包可以自动选择可花费的UTXO、生成找零output并计算手续费。本文解释这一过程的工作原理、益处和潜在风险。

    2026年6月15日3 分钟阅读
  34. 34
    第 34 篇

    将数据写入 BSV 区块链:从 OP_RETURN 到应用协议

    阅读文章

    BSV 交易不仅能转移 satoshis,还能通过数据输出将文本、哈希或业务事件写入链上。本文从第一笔 Hello BSV 交易讲起,介绍数据输出与支付输出的区别、如何使用 SDK 构造 OP_RETURN、十六进制转换原因,以及如何走向结构化协议设计。

    2026年6月16日2 分钟阅读
  35. 35
    第 35 篇

    用 WhatsOnChain 查看 BSV 交易:从 txid 到链上结构的完整指南

    阅读文章

    本文教你如何使用区块浏览器 WhatsOnChain 查看交易详情,理解 inputs、outputs、脚本、手续费等核心概念,并借助浏览器反向理解 SDK 的底层逻辑。

    2026年6月16日3 分钟阅读
  36. 36
    第 36 篇

    BSV 交易入门:手动指定输入(Inputs)的正确姿势

    阅读文章

    在 BSV 的 UTXO 模型中,手动指定交易输入是进阶开发的必备技能。本文深入解析输入的本质、所需信息、代码示例和常见误区,帮你避开“地址扣款”的思维陷阱。

    2026年6月18日3 分钟阅读
  37. 37
    第 37 篇

    手动指定交易输出,掌握 BSV 应用设计的关键一步

    阅读文章

    理解比特币交易输出(output)的机制,从手动构造交易开始。本文介绍输出的类型、找零规则、索引顺序及常见误区,帮助你从“会发交易”进阶到“会设计 BSV 应用”。

    2026年6月18日2 分钟阅读
  38. 38
    第 38 篇

    比特币交易手续费:计算方式、影响因子与BSV实践指南

    阅读文章

    交易手续费并非显式字段,而是输入总额与输出总额的差额。理解手续费计算逻辑、交易大小的影响因素以及BSV网络策略,是构建链上应用的基础。

    2026年6月18日3 分钟阅读
  39. 39
    第 39 篇

    为什么比特币交易的每个输入都需要单独签名?

    阅读文章

    理解比特币交易中多输入签名的必要性,避免常见误解,并了解 P2PKH 签名的基本逻辑、SDK 使用方法以及签名保护的具体内容。

    2026年6月18日3 分钟阅读
  40. 40
    第 40 篇

    BSV 交易序列化:从对象到广播的必经之路

    阅读文章

    理解交易序列化是连接应用开发与区块链网络的关键。本文介绍为何需要序列化、标准交易结构、hex 的作用、SDK 中的序列化与反序列化、txid 关系以及常见误区,帮助你从调 SDK 进阶到调试链上数据。

    2026年6月18日3 分钟阅读
  41. 41
    第 41 篇

    BSV 交易广播:从构造到提交的完整指南

    阅读文章

    在 BSV 开发中,构造交易只是第一步。本文详细讲解广播交易的意义、常见误区、广播前检查、返回值处理及失败原因,帮助开发者正确将交易提交至网络。

    2026年6月18日2 分钟阅读
  42. 42
    第 42 篇

    交易链:一笔交易怎样花掉刚刚生成的 UTXO

    阅读文章

    理解交易链,才能真正理解比特币白皮书中“coin 是一条数字签名链”的含义。本文从最小模型出发,介绍 UTXO 在交易之间如何转移,以及交易链在 BSV 应用状态管理中的关键作用。

    2026年6月18日3 分钟阅读
  43. 43
    第 43 篇

    比特币区块头:SPV和轻客户端的80字节基石

    阅读文章

    区块头是比特币区块的80字节摘要,虽不包含完整交易,却是连接工作量证明链和承诺交易集的关键结构。本文解释区块头字段、Merkle root和SPV原理,帮助理解BSV大规模扩展的实现基础。

    2026年6月20日4 分钟阅读

推荐文章