以太坊解读

以太坊是一个全新的区块链应用平台,被认为是区块链2.0。以太坊允许任何人通过智能合 约在平台上建立和使用基于区块链技术的去中心化应用DApp。以太坊的核心理念是内置图灵完 备编程语言的区块链,“图灵完备”的意思在于一切可计算的问题都能通过计算解决。建立这 种图灵完备的基础就是以太坊虚拟机(Ethereum Virtual Machine,EVM)。EVM类似于Java虚拟 机(JVM),编译后基于字节码运行,开发时则可以使用高级语言实现,编译器会自动转化为字节码。 

1.以太坊的基本概念:

以太坊由大量的节点组成,节点有账户与之对应,两个账户之间通过发送消息进行一笔交易。 交易里携带的信息和实现特定功能的代码叫作智能合约,运行智能合约的环境是以太坊虚拟机。 以太坊虚拟机运行在每个节点中,交易需要有节点参与,通过重复哈希运算来产生工作量,这些 6 节点称为矿工,计算的过程称为挖矿。交易的计算是要付出费用的,这些费用就称为gas。在以 太坊中,gas是由以太币转换生成的。以太币是以太坊上用来支付交易手续费和运算服务的媒介, 消耗的gas用于奖励矿工。基于以上智能合约代码和以太坊平台的应用叫作去中心化应用。 

1.1节点:通过节点可以进行区块链数据的读写。目前以太坊上的很多应用都是基于公有链 的,所以每一个节点都拥有相同地位和权利,没有中央服务器,每个节点都可以加入网络,读写以太坊中的数据。节点之间使用共识机制来确保数据交互的可靠性和正确性。单独的一个节点也可以搭建私有链,几个相互信任的节点可以搭建联盟链。 

1.2 矿工:矿工是指通过不断重复哈希运算来产生工作量的网络节点。矿工的任务是计算数 学难题,并将计算结果放入新的区块中。矿工之间是竞争关系,最先计算出结果的节点,将向全 网络进行广播,当结果被确认后,新生成区块所包含的奖励将会给与该节点,存入以太币地址中。 该节点所包含的以太币可以作为下次发起交易的资产。 

1.3 挖矿:在以太坊中,发行以太币的唯一途径是挖矿。 简单来说,挖矿的过程就是矿工寻找一个随机数进行SHA256计算哈 希值,如果计算后的哈希值满足一定的条件,比如前60位为0或小于等于某个预先的随机数(Nonce),那么这个矿工就赢得了创建区块的权利。 

1.4 账户:以太坊中包含两类账户:外部账户和合约账户。外部账户由公私钥对控制。合约 账户则在区块链上唯一标识了某个智能合约。两类账户都包含了以太币余额,能发送交易。每个 账户的地址长度为20字节,有一块持久化内存区域被称为存储区(storage),其形式为键值对, 键和值的长度均为32字节。重要的是,外部账户的地址是由公钥决定的,合约账户的地址是在部 署合约的时候确定的,当合约账户接收到一笔合法的交易后,就会执行里面包含的合约代码。所 以两类账户最大的区别是:合约账户存储了代码,外部账户则没有。 

1.5 gas:以太坊上的每一笔交易都有矿工的参与,且都需要支付一定的费用,这个费用在以 太坊中称为gas。gas的目的是限制执行交易所需的工作量,同时为执行交易支付费用。 合约的代码在EVM上运行时,gas会按照既定的规则逐渐消耗。gas价格是由交易创建者设置的,交易费 用=gas price * gas amount。如果执行结束后还有gas剩余,这些gas将会返还给发送者账户,而消费的gas则被当作奖励,发放到矿工账户。 

1.6EVM:以太坊虚拟机是以太坊中智能合约的运行环境,并且是一个沙盒,与外界隔离。 智能合约代码在EVM内部运行时,是不能进行网络操作、文件I/O或执行其他进程的。智能合约之间也只能进行有限的调用,这样保证了合约运行的独立性,并尽可能提高了运行时的安全性。 

1.7智能合约:合约是代码和数据的集合,存在于以太坊区块链的指定地址。合约方法支持 回滚操作,如果在执行某个方法时发生异常,如gas消耗完,则该方法已经执行的操作都会被回 滚。但是如果错误的交易一旦执行完毕,是没有办法篡改的。 

1.8交易:在以太坊中,交易都是通过状态转移来标记的,状态由被称为“账户”的对象和 两个账户之间的转移价值和信息状态转换构成。 以太坊账户分为由公私钥控制的外部账户和由合 约代码控制的合约账户。外部账户没有代码,用户通过创建和签名一笔交易从一个外部账户发送 消息,合约账户收到消息后,合约内部代码会被激活,对内部存储进行读取和写入,或者发送消息,或者调用方法。 

确定了账户后,即开始以太坊的交易。在以太坊中,“交易”是指存储从外部账户发出的消 息的签名数据包,在交易过程中比较重要的是消息机制。以太坊的消息机制能够确保合约账户和 外部账户拥有同等的权利,包括发送消息和创建其他合约。这使得合约可以同时由多个不同角色 参与,共同签名来提供服务,而不需要关心合约的每一方到底是什么类型的账户。 

(1) 检查交易是否有效,格式是否正确。 

(2) 计算交易所需费用,并判断交易发送者余额是否足够,如果足够,则从发送者账户中扣除 交易费用 

(3) 设定初始gas值。

4) 从发送者账户转移价值到接收者账户,若接收账户不存在则创建新账户并作为接收者。如果接收者是合约,则执行合约代码,直至代码运行完毕或者gas消耗完毕。 

 

 

 

 

 

转载于:https://www.cnblogs.com/sanshengsanshi/p/8845873.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值