❶ 以太坊怎么修改数据
先以太坊的数据保存在user用户名当中需要在硬盘的位置,一是可以备份你的私钥,而是可以删除钱包,还有其他的一些比较详细的操作
原标题:《解码以太坊智能合约数据》 正如我们在之前的文章中所讨论的,智能合约交易类似于智能合约驱动的web3应用程序中的后端API调用。每个智能合约交易和结果应用程序状态更改的细
以太坊中各种操作都需要支付gas,如存储数据、创建合约以及执行哈希计算等操作发起方在某次操作中愿意支付的最高手续费
❷ 以太坊是骗人的吗怎么做
不是骗人的,必须要懂行的人带你入行,不然不熟的人带你你就会走进资金盘,做以太坊可以有两个方向,
第一:下载交易所软件在上面交易,跟股票交易一样的,可以买多,也可以做空,也可以量化,也可以开合约,也可以开杠杆,总之跟股票操作差不多,这种来钱快,亏欠也快。
第二种:就是去厂家买显卡或者矿机回来连网通电就可以在电脑上挖矿,每天都有收益可以提现,这个很轻松没有风险,只有回本周期,这行就属于投资越大回本越快赚得越多。
希望可以帮到你
❸ 以太坊是什么
随着区块链技术的创新,一个新的平台诞生了,它就是以太坊。以太坊不像比特币那样只是一种加密货币,它还存在其它特征,使其成为了一个巨大的分布式计算机。
那么,到底什么是以太坊?
具体来说,以太坊(Ethereum)是一个可编程、可视化、更易用的区块链,它允许任何人编写智能合约和发行代币。就像比特币一样,以太坊是去中心化的,由全网共同记账,账本公开透明且不可窜改。
与比特币不同的是,以太坊是可编程的区块链,它提供了一套图灵完备的脚本语言,因此,开发人员可以直接用C语言等高级语言编程,转换成汇编语言,大大降低了区块链应用的开发难度。
为了更易理解,打个比方,以太坊就像是区块链里的Android,它是一个开发平台,让我们可以像基于Android Framework一样基于区块链技术写应用。它上面提供各种模块让用户来搭建应用,如果将搭建应用比作造房子,那么以太坊就提供了墙面、屋顶、地板等模块,用户只需像搭积木一样把房子搭起来,因此在以太坊上建立应用的成本和速度都大大改善。
事实上,在没有以太坊之前,写区块链应用是这样的:拷贝一份比特币代码,然后去改底层代码如加密算法,共识机制,网络协议等等(很多山寨币就是这样,改改就出来一个新币)。
至于以太坊如何运作?
与其它区块链一样,以太坊需要几千人在自己的计算机上运行一个软件,为该网络提供动力。网络中的每个节点(计算机)运行一个叫做以太坊虚拟机(EVM)的软件。如果将以太坊虚拟机想象成一个操作系统,它能理解并执行通过以太坊特定编程语言编写的软件,由以太坊虚拟机执行的软件/应用程序被称为“智能合约”。
不过,在这台计算机上操作并不是免费的,需要支付该网络自带的加密货币,叫做以太币(Ether)。以太币与比特币大致相同,除了一点,即以太币可以为在以太坊上执行智能合约而付费。
回到以太坊的发展史,以太坊的概念首次在2013至2014年间由程序员Vitalik Buterin受比特币启发后提出,大意为“下一代加密货币与去中心化应用平台”,在2014年通过ICO众筹开始得以发展。
截至2018年2月,以太币是市值第二高的加密货币,仅次于比特币。
对于许多程序工程师和投资人而言,2015年7月30号这一天是一个大日子,经过18个月的酝酿期后,以太坊区块链平台终于正式诞生了,当天在位于布鲁克林的办公室上午11:45左右,当以太坊区块链产生第一个创世区块,随即有很多狂热的矿工在后头想要赢得第一个区块,也就是以太坊专属电子货币,以太币的所有权。当时整个办公室掌声雷动,那一天天气很糟糕,纽约一带下了大雷雨,每个人的智能手机不时传来嘈杂的洪水警告讯号。
根据该公司网站资料的说明,以太坊是一个去中心化的应用平台,以智能合约为例,设计师可以完全排除死机被监控,被诈骗或者是被第三方横加干预的可能,跟比特币一样,以太坊利用以太币吸引参加者,建立验证交易平台的网络架构,维持网络架构的运作,并且以共识决定哪些是真正发生过存在的事件,但是以太坊和比特币也有所不同,以太坊提供一些功能强大的工具,让投入开发的人创造出去,具有去中心化的软件服务,使用范围可以从线上 游戏 横跨到股票交易。
以太坊的构想源自于2013年,当时才19岁的俄裔加拿大人为例,维塔利克布特林,他当时跟比特币的核心开发者争论,区块链网络架构需要有更稳固的手稿语言才能发展其他的应用软件,不过他的想法没有被采纳,促成了他打定主意要开发一套符合自己理念的区块链网络架构共识,这家公司可以说是他跨出的第一步,在以太坊区块链上推出了应用软件,如果我们把时间往回倒转几年,就会发现一个很有趣的对照。
有位大师托瓦兹推出Linux作业系统的举动,正如布特林推出以太坊一样如出一辙。共识系统公司的联合创始人约瑟夫鲁宾谈到区块链以太坊的兴起时表示,我愈发觉得走上街头去贴海报诉求是很浪费时间的一件事,倒不如一起合作,在这个失衡的 社会 的经济体制带来要比较实际得改变。
跟许多创业者一样,鲁宾提出的愿望也很有企图心,他不只想要创立一家了不起的公司,也想借机克服这个世界上难解的问题。这个公司的应用程序会对十多个其他领域的产业带来震撼力十足的效果,他们的计划包括分布式的三重记账会计体系,针对原本广受好评,但是后来却因为集中管控儿而遭受争议的reddit论坛推出分布式的新版本,自动执行的文件格式进行管理,系统现在叫智能合约,涵盖商务 体育 和 娱乐 领域的预测市场、公开竞标的能源市场、足以和苹果电脑分庭抗礼的一整套可以供大规模协作集体创造,实现无管理阶层公司之共同管理机制的商务工具。
以太坊Ethereum由V神(Vitalik Buterin)在2014年创办,它是一个区块链底层系统,类似于互联网的操作系统,基于它开发的DAPP(去中心化应用)类似于基于互联网操作系统开发的软件APP。
它的出现主要是弥补比特币的不足,比特币只能实现点对点的电子现金交易系统,但是区块链技术在其他场景的应用却无法实现。如果每用于一个场景,就搭建一个底层基础系统,再进行开发,太耗时间和精力,成本也很高。为此,以太坊就建了一个底层系统供开发者使用,开发者只需要在其基础上开发自己的DAPP应用就可以了。去年5月数据显示,全球就已有200多个以太坊应用。
此外,以太坊也是区块链比较优秀的公链之一。不过,它的交易速度太慢令众多开发者诟病,以太坊开发者正在不断尝试研发分片技术对此现象进行改变。
以太坊的本质是一个可编程可视化而且操作简单的区块链,允许任何人编写智能合约和发行代币(这也是为什么市面上各类空气币、传销币如此之多的一个原因之一)。和比特币一样,以太坊也是去中心化的,全网共同记录以太坊的所有情况,而且公开透明不可篡改。
那你想问,以太坊和比特币的不同之处在哪?通俗地讲,你可以把以太坊理解成为能够编程的区块链,它提供了一套图灵完备的脚本语言,后续的开发人员可以直接在这个基础上进行c语言等语言编程,之后转变成汇编语言,由此降低了区块链的应用的开发难度。就好像安卓系统上,准备好了api和接口,用户直接开发app就可以这样的逻辑。从以太坊诞生之初到现在,以太坊上已经诞生了几百个应用,俄罗斯政府甚至也与以太坊基金会合作。
希望我的回答能够帮助你!
在基础层面上,以太坊是基于区块链技术的软件平台。该平台允许构建和部署分散式应用程序。以太坊里的“以太”是什么?对Ethereum感兴趣的人们经常会问“以太是什么?”
了解以太是非常重要的,因为它是以太坊功能的基础。就像所有机器使用某种燃料一样,区块链也是如此。以太坊使用以太网,这是一种独特的代码,可用作支付运行应用程序或程序的方式。就像老虎机需要硬币(或者现在的预付卡)来运行硬币一样,客户必须使用乙醚作为付款才能在以太坊运行他们所要求的操作。
大家其他人的答案真的都是太麻烦了
讲得太复杂了
以太坊
简单来说就是这么一个结论:
以太坊等于 BTC+智能合约+合同自由+通缩资产+使用价值
这个结论其实不难理解的
官方定义更加诡诈:
开源的有智能合约功能的公共区块链平台。通过其专用加密货币以太币(Ether,又称“以太币”)提供去中心化的虚拟机
以太坊简单来说就是这么一个结论:
以太坊等于 BTC+智能合约+合同自由+通缩资产+使用价值
我给大家简单地来说说吧
首先先来看下面这个视频:也就是以太坊创始人V神的视频 特别好的解释
以太坊简单来说就是这么一个结论:
以太坊等于 BTC+智能合约+合同自由+通缩资产+使用价值
官方定义更加诡诈:
以太坊是一个可编程,可视化的区块链平台。其操作功能非常多,计算汇总各类数据等等。
以太坊是区块链技术的一个质的飞跃!就好比http是互联网底层支撑技术而以太坊就是可以基于以太坊智能合约做各种生态dapp
以太坊是什么?
以太坊是互联网新时代的基础:
内建货币与支付。
用户拥有个人数据主权,且不会被各类应用监听或窃取数据。
人人都有权使用开放金融系统。
基于中立且开源的基础架构,不受任何组织或个人控制。
以太坊的创建以太坊主网于 2015 年上线,是世界领先的可编程区块链。
和其它区块链一样,以太坊也拥有原生加密货币,叫作 Ether (ETH)。 ETH 是一种数字货币, 和比特币有许多相同的功能。 它是一种纯数字货币,可以即时发送给世界上任何地方的任何人。 ETH 的供应不受任何政府或组织控制,它是去中心化且具稀缺性的。 全世界的人们都在使用 ETH 进行支付,或将其作为价值存储和抵押品。
但与其它区块链不同的是,以太坊可以做更多的工作。 以太坊是可编程的,开发者可以用它来构建不同于以往的应用程序。
以太坊的作用这些去中心化的应用程序(或称“dapps”)基于加密货币与区块链技术, 因而值得信任,也就是说 dapps 一旦被“上传”到以太坊,它们将始终按照编好的程序运行。 这些应用程序可以控制数字资产,以便创造新的金融应用; 同时还是去中心化的,这意味着没有任何单一实体或个人可以控制它们。
目前,全世界有成千上万名开发者正在以太坊上构建应用程序、发明新的应用程序,其中有许多现在已经可以使用:
1.加密货币钱包:让你可以使用 ETH 或其他数字资产进行低成本的即时支付
2.金融应用程序:让你可以借贷、投资数字资产
3.去中心化市场:让你可以交易数字资产,甚至就现实世界事件的“预测”进行交易
4. 游戏 :你可以拥有 游戏 内的资产,甚至可以由此获得现实收益以及更多。
以太坊社区以太坊社区是世界上最大最活跃的区块链社区。它包括核心协议开发者、加密经济研究员、密码朋克、挖矿组织、ETH 持有者、应用开发者、普通用户、无政府主义者、财富 500 强公司。
没有公司或中心化的组织能够控制以太坊。 一直以来,以太坊由多元化的全球性社区贡献者来协同进行维护和改善,社区成员耕耘于以太坊的方方面面,从核心协议到应用程序。
以太坊拥堵的元凶找到了,竟然是它!
❹ Gate.io芝麻开门之以太坊是什么
以太坊是由 V 神(Vitalik Buterin)创建的加密货币,目前市值排名第二。
他和比特币一样,都是基于点对点(P2P)和密码学而建立起的一种区块链网络, 但不同的是,它在比特币网络 1.0 的基础上进行了升级,改变了原有区块链网络存在的一些问题。
例如,在共识机制方面,将逐渐由 POW 转变为 POS,以此来降低能源消耗、 减少手续费、缩短共识时间、提高效率。
在创新方面,增加了智能合约。智能合约是存在于以太坊区块网络节点上的一个程序,除了可以记录数据,还可以进行数据处理。 以太坊支持项目方在区块链网络上编写智能合约,但是所有的开发都是需要在遵守智能合约基础协议的情况下才可以进行,之后智能合约程序将会按照合约内容进行执行且无法修改信息。
其实智能合约类似于一种操作系统,它提供多种接口和 API 供项目方接入使用, 由于完整的区块链网络应用开发是一件很难的事情,因此让很多团队望而却步。 但有了以太坊提供的多种接口支持,让应用的开发变得简单,不用去投入太多时间、技术和资金从头做起,只需要遵守智能合约条款进行开发即可。
所以,这方便了很多数字货币的诞生。 目前市面上流通的数字货币,90%都是基于以太坊的 ERC-20 协议开发的。
❺ 以太坊交易记录在哪里查询
有自己的浏览器,以太坊和都是用的一个,而基于以太坊之上开发的代币也可以在以太坊的区块链浏览器上面查询,usdt在比特币区块链浏览器上面查询。
非小号上可以查看以太坊行情,但是并不能交易。想投资的话,可以去数字货币交易所,目前市场上主流的数字货币交易所有币安、火币网、比特网等。这里我们用以太坊区块链的钱包作为例子,小狐狸是加密钱包,以及进入区块链APP的出入口。进入之后获取钱包地址,再使用以太坊区块链的搜索器进入Etherscan官网首页后,就可以获取到以下区块链交易id信息:
所有者A利用他的私钥对前一次交易(比特货来源)和下一位所有者B签署一个数字签名,并将这个签名附加在这枚货币的末尾,制作出交易单。此时,B是以公钥作为接收方地址。A将交易单广播至全网,比特币就发送给了B,每个节点都将收到交易信息纳入一个区块中对B而言,该枚比特币会即时显示在比特币钱包中,但直到区块确认成功后才可以使用。目前一笔比特币从支付到最终确认成功,得到6个区块确认之后才能真正的确认到账。每个节点通过解一道数学难题,从而去获得创建新区块的权利,并争取得到比特币的奖励(新比特币会在此过程中产生)。
❻ 币安链的usdt怎么转到以太链
币安链的usdt怎么和以太链是不可以互相转换的。币安作为全球最大的数字货币市场交易所之一,一直以来各方面的政策行为都是很受大家关注的。
拓展资料:
1、以太坊:以太坊(英文Ethereum)是一个开源的有智能合约功能的公共区块链平台,通过其专用加密货币以太币(Ether,简称“ETH”)提供去中心化的以太虚拟机(Ethereum Virtual Machine)来处理点对点合约。以太坊的概念首次在2013至2014年间由程序员Vitalik Buterin受比特币启发后提出,大意为“下一代加密货币与去中心化应用平台”,在2014年通过ICO众筹开始得以发展。截至2018年2月,以太币是市值第二高的加密货币,仅次于比特币。
2、以太链模块化原则:以太坊的不同部分应被设计为尽可能模块化的和可分的。开发过程中,应该能够容易地让在协议某处做一个小改动的同时应用层却可以不加改动地继续正常运行。以太坊开发应该最大程度地做好这些事情以助益于整个加密货币生态系统,而不仅是自身。
3、以太坊通用原则:没有“特性”是以太坊设计哲学中的一个根本性部分。取而代之的是,以太坊提供了一个内部的图灵完备的脚本语言以供用户来构建任何可以精确定义的智能合约或交易类型。想建立一个全规模的守护程序(Daemon)或天网(Skynet),你可能需要几千个联锁合约并且确定慷慨地喂养它们,一切皆有可能。
4、以太坊简介原则:以太坊协议将尽可能简单,即便以某些数据存储和时间上的低效为代价。一个普通的程序员也能够完美地去实现完整的开发说明。这将最终有助于降低任何特殊个人或精英团体可能对协议的影响并且推进以太坊作为对所有人开放的协议的应用前景。添加复杂性的优化将不会被接受,除非它们提供了非常根本性的益处。
❼ 区块链中的数据存在哪里
区块链的数据中都存在终端或者是存在服务器里面的。因为都说的是区块链嘛,他的用户终端也可以是服务器,服务器也可以是用户终端,所以都储存在这些设备上面。
❽ 一条数据是如何完成上链的
区块链处理的流程大致分为三个阶段:
分别是上链前处理阶段、链上处理阶段和智能合约处理阶段。
上链前处理阶段
业务数据上链前需要将业务数据处理,并且对信息进行签名。这些过程可以通过对应的工具,比如序列化工具和各种椭圆曲线的签名工具来完成,不过更多的时候是通过将各种工具集成的SDK来完成,以太坊的web3就是比较典型的上链前处理的开发工具。
上链处理阶段
处理完成的数据发送到区块链节点后,就形成了一笔区块链交易并进入上链处理的阶段,链上处理大体可分为交易广播和区块共识流程。
智能合约处理阶段
上链处理完成后,业务数据已经记录在链上了,对于单纯存证的业务来说,将业务信息写入区块已经完成了这笔业务处理,只需记录存证业务的交易哈希并在取的时候通过交易哈希查询即可。但是大部分业务场景都需要进行一定的逻辑处理,因此通过智能合约处理是必须的。智能合约处理包括合约逻辑处理以及修改状态梅克尔树等流程。
链乔教育在线旗下学硕创新区块链技术工作站是中国教育部学校规划建设发展中心开展的“智慧学习工场2020-学硕创新工作站 ”唯一获准的“区块链技术专业”试点工作站。专业站立足为学生提供多样化成长路径,推进专业学位研究生产学研结合培养模式改革,构建应用型、复合型人才培养体系。
❾ 以太坊如何使用web3.js或者rpc接口获取交易数据交易时间与确认数
如果要查询主网上的交易记录,可以使用etherscan。但是,如果是你自己搭建的私链,应该如何查询交易记录呢?
答案是你需要自己监听链上的日志,存到数据库里,然后在这个数据库中查询。例如:
varaddr=""
varfilter=web3.eth.filter({fromBlock:0,toBlock:'latest',address:addr});
filter.get(function(err,transactions){
transactions.forEach(function(tx){
vartxInfo=web3.eth.getTransaction(tx.transactionHash);
//这时可以将交易信息txInfo存入数据库
});
});
web3.eth.filter()用来监听链上的日志,web3.eth.getTransaction()用来提取指定交易的信息,一旦获得交易信息,就可以存入数据库供查询用了。
推荐一个实战入门,你可以看看:以太坊教程
❿ 【深度知识】以太坊数据序列化RLP编码/解码原理
RLP(Recursive Length Prefix),中文翻译过来叫递归长度前缀编码,它是以太坊序列化所采用的编码方式。RLP主要用于以太坊中数据的网络传输和持久化存储。
对象序列化方法有很多种,常见的像JSON编码,但是JSON有个明显的缺点:编码结果比较大。例如有如下的结构:
变量s序列化的结果是{"name":"icattlecoder","sex":"male"},字符串长度35,实际有效数据是icattlecoder 和male,共计16个字节,我们可以看到JSON的序列化时引入了太多的冗余信息。假设以太坊采用JSON来序列化,那么本来50GB的区块链可能现在就要100GB,当然实际没这么简单。
所以,以太坊需要设计一种结果更小的编码方法。
RLP编码的定义只处理两类数据:一类是字符串(例如字节数组),一类是列表。字符串指的是一串二进制数据,列表是一个嵌套递归的结构,里面可以包含字符串和列表,例如["cat",["puppy","cow"],"horse",[[]],"pig",[""],"sheep"]就是一个复杂的列表。其他类型的数据需要转成以上的两类,转换的规则不是RLP编码定义的,可以根据自己的规则转换,例如struct可以转成列表,int可以转成二进制(属于字符串一类),以太坊中整数都以大端形式存储。
从RLP编码的名字可以看出它的特点:一个是递归,被编码的数据是递归的结构,编码算法也是递归进行处理的;二是长度前缀,也就是RLP编码都带有一个前缀,这个前缀是跟被编码数据的长度相关的,从下面的编码规则中可以看出这一点。
对于值在[0, 127]之间的单个字节,其编码是其本身。
例1:a的编码是97。
如果byte数组长度l <= 55,编码的结果是数组本身,再加上128+l作为前缀。
例2:空字符串编码是128,即128 = 128 + 0。
例3:abc编码结果是131 97 98 99,其中131=128+len("abc"),97 98 99依次是a b c。
如果数组长度大于55, 编码结果第一个是183加数组长度的编码的长度,然后是数组长度的本身的编码,最后是byte数组的编码。
请把上面的规则多读几篇,特别是数组长度的编码的长度。
例4:编码下面这段字符串:
The length of this sentence is more than 55 bytes, I know it because I pre-designed it
这段字符串共86个字节,而86的编码只需要一个字节,那就是它自己,因此,编码的结果如下:
184 86 84 104 101 32 108 101 110 103 116 104 32 111 102 32 116 104 105 115 32 115 101 110 116 101 110 99 101 32 105 115 32 109 111 114 101 32 116 104 97 110 32 53 53 32 98 121 116 101 115 44 32 73 32 107 110 111 119 32 105 116 32 98 101 99 97 117 115 101 32 73 32 112 114 101 45 100 101 115 105 103 110 101 100 32 105 116
其中前三个字节的计算方式如下:
184 = 183 + 1,因为数组长度86编码后仅占用一个字节。
86即数组长度86
84是T的编码
例5:编码一个重复1024次"a"的字符串,其结果为:185 4 0 97 97 97 97 97 97 ...。
1024按 big endian编码为004 0,省略掉前面的零,长度为2,因此185 = 183 + 2。
规则1~3定义了byte数组的编码方案,下面介绍列表的编码规则。在此之前,我们先定义列表长度是指子列表编码后的长度之和。
如果列表长度小于55,编码结果第一位是192加列表长度的编码的长度,然后依次连接各子列表的编码。
注意规则4本身是递归定义的。
例6:["abc", "def"]的编码结果是200 131 97 98 99 131 100 101 102。
其中abc的编码为131 97 98 99,def的编码为131 100 101 102。两个子字符串的编码后总长度是8,因此编码结果第一位计算得出:192 + 8 = 200。
如果列表长度超过55,编码结果第一位是247加列表长度的编码长度,然后是列表长度本身的编码,最后依次连接各子列表的编码。
规则5本身也是递归定义的,和规则3相似。
例7:
["The length of this sentence is more than 55 bytes, ", "I know it because I pre-designed it"]
的编码结果是:
248 88 179 84 104 101 32 108 101 110 103 116 104 32 111 102 32 116 104 105 115 32 115 101 110 116 101 110 99 101 32 105 115 32 109 111 114 101 32 116 104 97 110 32 53 53 32 98 121 116 101 115 44 32 163 73 32 107 110 111 119 32 105 116 32 98 101 99 97 117 115 101 32 73 32 112 114 101 45 100 101 115 105 103 110 101 100 32 105 116
其中前两个字节的计算方式如下:
248 = 247 +1
88 = 86 + 2,在规则3的示例中,长度为86,而在此例中,由于有两个子字符串,每个子字符串本身的长度的编码各占1字节,因此总共占2字节。
第3个字节179依据规则2得出179 = 128 + 51
第55个字节163同样依据规则2得出163 = 128 + 35
例8:最后我们再来看个稍复杂点的例子以加深理解递归长度前缀,
["abc",["The length of this sentence is more than 55 bytes, ", "I know it because I pre-designed it"]]
编码结果是:
248 94 131 97 98 99 248 88 179 84 104 101 32 108 101 110 103 116 104 32 111 102 32 116 104 105 115 32 115 101 110 116 101 110 99 101 32 105 115 32 109 111 114 101 32 116 104 97 110 32 53 53 32 98 121 116 101 115 44 32 163 73 32 107 110 111 119 32 105 116 32 98 101 99 97 117 115 101 32 73 32 112 114 101 45 100 101 115 105 103 110 101 100 32 105 116
列表第一项字符串abc根据规则2,编码结果为131 97 98 99,长度为4。
列表第二项也是一个列表项:
["The length of this sentence is more than 55 bytes, ", "I know it because I pre-designed it"]
根据规则5,结果为
248 88 179 84 104 101 32 108 101 110 103 116 104 32 111 102 32 116 104 105 115 32 115 101 110 116 101 110 99 101 32 105 115 32 109 111 114 101 32 116 104 97 110 32 53 53 32 98 121 116 101 115 44 32 163 73 32 107 110 111 119 32 105 116 32 98 101 99 97 117 115 101 32 73 32 112 114 101 45 100 101 115 105 103 110 101 100 32 105 116
长度为90,因此,整个列表的编码结果第二位是90 + 4 = 94, 占用1个字节,第一位247 + 1 = 248
以上5条就是RPL的全部编码规则。
各语言在具体实现RLP编码时,首先需要将对像映射成byte数组或列表两种形式。以go语言编码struct为例,会将其映射为列表,例如Student这个对象处理成列表["icattlecoder","male"]
如果编码map类型,可以采用以下列表形式:
[["",""],["",""],["",""]]
解码时,首先根据编码结果第一个字节f的大小,执行以下的规则判断:
1.如果f∈ [0,128),那么它是一个字节本身。
2.如果f∈[128,184),那么它是一个长度不超过55的byte数组,数组的长度为 l=f-128
3.如果f∈[184,192),那么它是一个长度超过55的数组,长度本身的编码长度ll=f-183,然后从第二个字节开始读取长度为ll的bytes,按照BigEndian编码成整数l,l即为数组的长度。
4.如果f∈(192,247],那么它是一个编码后总长度不超过55的列表,列表长度为l=f-192。递归使用规则1~4进行解码。
5.如果f∈(247,256],那么它是编码后长度大于55的列表,其长度本身的编码长度ll=f-247,然后从第二个字节读取长度为ll的bytes,按BigEndian编码成整数l,l即为子列表长度。然后递归根据解码规则进行解码。
以上解释了什么叫递归长度前缀编码,这个名字本身很好的解释了编码规则。
(1) 以太坊源码学习—RLP编码( https://segmentfault.com/a/1190000011763339 )
(2)简单分析RLP编码原理
( https://blog.csdn.net/itchosen/article/details/78183991 )