深入了解以太坊

news/2024/12/27 16:18:57 标签: 区块链, 运维, javascript
想知道更多关于区块链技术知识,请百度【链客区块链技术问答社区】
链客,有问必答!!

一、关于以太坊
        2013年,V神发布以太坊白皮书,2014年7月开始以太币的预售,圈内人称这种代币发行叫做“币众筹”,通过为期42天的预售,以太坊团队通过预售60102216个以太币募集了3万多个比特币,另外还对预售之前参与开发的早起贡献者、长期从事项目研究的开发者,分别按照当时以太币发售总量的9.9%进行分配,所以以太坊正式发行时有7200多万个以太币。以太坊预售结束后,采用工作量证明机制POW进行挖矿,每年按照当时发行总量的26%奖励矿工。
        2014年10月,以太坊将区块链的出块时间从60秒缩减到了12秒,目前基本稳定在15秒。每个区块奖励5个以太币,虽然都是采用POW挖矿机制,但是以太坊的出块机制和比特币还是有区别的,由于以太坊的出块时间短,导致以太坊很容易形成孤块。孤块是指不在最长链上的区块,比特币的孤块没有任何区块奖励,但是在以太坊中,孤块可以被引用,被引用的孤块被成为“叔块”,他们打包的数据也会记录在区块链中。和比特币不一样,以太坊的叔块有奖励,每个叔块可以获得4.375个以太币的奖励。
        以太坊是一个可编程的,图灵完备的区块链开发平台,相当于一个去中心化的全球计算机。在一个编程系统之上,通常会有一些编译和执行的虚拟机来做支撑。JAVA有JVM,在以太坊里,也有以太坊的虚拟机EVM可以执行任意复杂的算法代码,开发者可以使用现有的JavaScript或者python等编程语言,在以太坊上创造出自己想要的应用。通过以太坊的虚拟机,可以很简便的发行数字资产、编写智能合约、建立和运行去中心化的应用、成立去中心自治组织等。
        以太币(ETH)又被成为以太坊内部的燃料,和币类数字资产不同,以太坊除了用于转账,还用于支付智能合约的费用。为了避免以太坊区块链上充斥垃圾合约和垃圾应用,在以太坊上建立和运行智能合约,必须用以太币(ETH)支付智能合约费用。例如:在以太坊区块链上转账A新创造的数字资产,需要用以太币(ETH)支付手续费,而不是A新创造的数字资产。
二、关于以太坊虚拟机
        以太坊是一个可编程的区块链,与比特币不同的是,比特币定位于一个应用,而以太坊定位于平台,可以在这个平台上利用智能合约做各种应用。这样,以太坊成为了多种不同类型去中心化区块链的平台,包括但不限于密码学货币。
        以太坊在狭义上表示一套协议,这套协议定义了去中心化应用的平台,它的核心是以太坊虚拟机EVM。与其他区块链系统一样,以太坊同样包括 了一个点对点(P2P)协议。以太坊区块链数据库由连接到网络的多个节点维护和更新,这个网络上的每个节点都运行EVM并且执行相同的指令。因此,以太坊也可以被称为“世界计算机”。这种在整个以太坊网络上进行大规模并行计算不是为了获得更高的效率。实际上这个过程是以太坊上的计算比在传统计算机上的要缓慢而且昂贵很多。每个以太坊节点运行EVM是为了在区块链中保持一致。去中心化一致性使得以太坊具有非常高的容错性,保证了零宕机,而且使存储在区块链上的数据永远不可改变以及无法审查。
三、以太坊是如何工作的
        以太坊包含了许多类似比特币的功能和技术,同时也做了某些修改和创新。比特币区块链纯粹是一个关于交易的列表,而以太坊的基础单元是账户。以太坊区块链跟踪每一个账号的状态,账号间的所有状态的转移都是价值和信息的转移。以太坊有2种账户类型:
    外部拥有的账户(EOA),被私钥控制且没有任何代码与之关联;
    合约账户,由它们的合同代码控制且有代码与之关联,且只能由一个EOA账户“激活”。
        对于大多数人来说,两者最基本的区别是外部账户是由人掌控--因为人能控制私钥,进而控制外部账户。而合约账户则是由合同代码控制的,只有当外部账户发出指令,合约账户才能进行相应的操作。广受欢迎的“智能合约”是合约账户中的代码,是一个交易发送到账号上执行的程序。用户可以通过部署代码到区块链中创建一个新合约。
        和比特币一样的是,每次交易,用户都需要支付一定小额的费用,用来维护网络安全、稳定。节点通过收集交易费用来验证整个网络。网络中的节点(矿工)接受、传播、验证和执行交易,然后整理归档这些交易,打包成一个区块,与别的矿工竞争将区块添加到区块链中,添加成功的矿工将收到奖励。通过这些措施,鼓励人们为全网提供更多的算力。


http://www.niftyadmin.cn/n/928507.html

相关文章

Stream Collectors - partitioningBy

public static <T> Collector<T,​?,​Map<Boolean,​List<T>>> partitioningBy​(Predicate<? super T> predicate) 分区函数&#xff0c;返回一个map&#xff0c;key永远只有两个分别是boolean值false和true&#xff0c;用法和groupingBy类…

Oracle再发力,区块链平台多项更新

本周&#xff0c;Oracle宣布将加速全球区块链的采用。据悉&#xff0c;目前全球已经众多企业通过Oracle区块链平台享受到了区块链应用程序的优势&#xff0c;而Oracle将为区块链平台添加更多新功能&#xff0c;帮助用户加速区块链应用程序的开发、集成和部署。 Oracle区块链平台…

Stream Collectors - reducing

public static <T> Collector<T,​?,​Optional<T>> reducing​(BinaryOperator<T> op) 不能看方法名理解其作用&#xff0c;入参是一个二目运算函数参数&#xff0c;作用比较广泛。 处理流程简单描述&#xff1a; 第一步&#xff1b;a&#xff0c…

这才是Tomcat内存配置的正确姿势

1.背景 虽然阅读了各大牛的博客或文章,但并没有找到特别全面的关于JVM内存分配方法的文章,很多都是复制黏贴 为了严谨,本文特别备注只介绍基于HotSpot VM虚拟机,并且基于JDK1.7的内存分配情况,有关GC的说法也是基于CMS的concurrent collection(而非G1),防止大牛拍砖. 目前主流的…

拥抱PostgreSQL,红帽再表态:SSPL的MongoDB坚决不用

2019年1月&#xff0c;红帽在最新的RHEL 8.0 Beta Release Note 中明确表示因为 MongoDB 使用了 SSPL 协议&#xff0c;所以将不会在 8.0 系统中提供该数据库。 2019年2月12日&#xff0c;红帽官方发博称&#xff0c;Red Hat Satellite将在后端标准化PostgreSQL&#xff0c;并且…

Stream Collectors - summarizingInt

public static <T> Collector<T,​?,​IntSummaryStatistics> summarizingInt​(ToIntFunction<? super T> mapper) public static <T> Collector<T,​?,​LongSummaryStatistics> summarizingLong​(ToLongFunction<? super T> mapp…

1_npctele

1_npctele 其他同1_itemtele slot       排序字段(传送NPC中的显示根据这个来排序 也就是 数值越小的越在前)creature    传送员id (这里指定ID可以设置多个传送员)parentmenuidicongossipmapposition_xposition_yposition_zposition_oactionvendoridreqtypereqva…

Go语言的通道(2)-缓冲通道

有缓冲的通道相比于无缓冲通道&#xff0c;多了一个缓存的功能&#xff0c;如下图描述的一样&#xff1a; 从图上可以明显看到和无缓冲通道的区别&#xff0c;无缓冲必须两个Goroutine都进入通道才能进行数据的交换&#xff0c;这个不用&#xff0c;如果数据有&#xff0c;直接…