codecamp

以太坊 ETH

前提条件

为了更好地理解此页面,推荐先阅读:以太坊简介

什么是加密货币?

加密货币是一种基于分布式账本(区块链)的交换媒介。

交换媒介是指被广泛接受、可支付任何商品和服务的物品,而分布式账本是记录交易的数据存储系统。区块链技术允许用户在分布式账本上进行交易,而无需依赖受信任的第三方来维护账本。

第一个加密货币是由 ​Satoshi Nakamoto​ 创建的比特币。 自 2009 年比特币发行以来,人们已经在许多不同的区块链上制作了数以千计的加密货币。

什么是以太币 (ETH)?

以太币 (​ETH​) 是用于以太坊网络上许多事物的加密货币。 从根本上讲,它是唯一可接受的交易费用支付方式,而且合并后,还需用于在主网得到验证并提出区块。 以太币还被用作 ​DeFi ​借贷市场的主要抵押形式,​NFT ​市场的主要记账单位以及提供服务、销售实体商品赚取的付款等。

以太坊允许开发者创建 去中心化应用 (​dapp​),它们共享算力池。 这个共享池是有限的,因此以太坊需要一种机制来确定谁可以使用它。 否则,某个 ​dapp ​可能会意外或恶意地消耗所有网络资源,从而导致其他应用程序无法访问算力池。

ETH ​加密货币支持以太坊算力的定价机制。 当用户想要完成一笔交易时,他们必须支付以太币,使他们的交易被区块链识别。 这些使用成本被称为 ​gas ​费用,​gas ​费用的多少取决于执行交易所需的算力和全网当时的算力需求。

因此,即使某恶意 ​dapp ​无限循环提交,交易最终也会耗尽 ​ETH ​并终止,从而使网络恢复正常。

铸造 ETH

铸造是指在以太坊分类账上创造新以太币的过程。 底层以太坊协议创造出新以太币,单一用户不可能创造。

当矿工在以太坊区块链上创建出一个区块时,就会铸造出新以太币。 作为对矿工的激励,以太坊协议在每个区块中都设置了奖励,增加区块矿工设置的地址余额。 区块奖励随时间而变化,目前奖励为每区块 2 个以太币。

燃烧 ETH

除了通过区块奖励创造 ​ETH​,也可以通过被称为“燃烧”的过程销毁 ​ETH​。 当 ​ETH ​被燃烧掉,它也就永久退出流通。

以太坊上的每一笔交易都会发生 ​ETH ​燃烧。 当用户支付交易费用时,基本 ​gas ​费将根据协议被销毁。 根据网络需求,某些区块燃烧的 ​ETH ​超出铸造的 ​ETH​。

ETH 面额

由于以太坊上许多交易规模较小,​ETH ​有一些面额单位表示较小金额。 在这些单位中,​Wei ​与 ​Gwei ​特别重要。

Wei ​是最小的 ​ETH ​单位,因此在以太坊黄皮书等众多技术实施中,都以 ​Wei ​为基础进行运算。

Gwei​(giga-wei 的缩写),常用于描述以太坊的 ​gas ​费用。

面额 ETH 值 常见用法
Wei 10-18 技术实施
Gwei 10-9 可读 gas 费用

传输 ETH

以太坊上的每一笔交易都包含一个 值域,指定了要从发送者地址发送到接收者地址的 ​ETH ​转移数量(以 ​Wei ​为单位)。

当接收者地址是智能合约时,当智能合约执行其代码时,这些转移的以太币可用于支付 ​gas ​费用。

查询 ETH

用户可以通过检查帐户余额字段来查询任何帐户的 ​ETH ​余额,显示以 ​wei​ 为单位的 ​ETH ​持有面额。

Etherscan ​是常用于检查地址余额的基于 ​web ​的应用程序。 例如,此 ​Etherscan ​页面显示以太坊基金会的余额。


以太坊 简介
以太坊 去中心化应用
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

以太坊基础

以太坊 节点和客户端

以太坊 共识机制

以太坊 工作量证明

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }