来源|Medium作者|arjunaskykok整理/Aholiab出品|区块链大本营
根据IEEE此前的一项调查,Python已成为最受开发者欢迎的语言之一。由于其对于技术小白天然友好的特性,以及不断更新的新功能。Python越来越受到国内外开发者的喜爱。越来越多被用于独立、大型项目的开发开始使用Python。
20世纪90年代初荷兰人GuidovanRossum为了打发圣诞节的无趣,决心开发一个新的脚本解释程序,作为ABC语言的一种继承。
之所以选中Python作为该编程语言的名字,是取自英国20世纪70年代首播的电视喜剧《蒙提.派森的飞行马戏团》。
对于区块链开发者来说,Python也是十分实用的语言之一。今天,我们就Python开发一个简单的区块链数据结构。
德国外长:欧盟将对俄罗斯提出第8轮制裁方案:9月1日消息,自俄乌冲突发生以来,欧盟已经对俄罗斯实施了7轮制裁措施。当地时间8月31日,德国联邦外交部长贝尔伯克表示,欧盟正在就第8轮制裁方案进行磋商,俄罗斯石油出口可能成为制裁的重点。贝尔伯克当天在布拉格举行的欧盟外长会议上透露称,德国政府正努力推动对俄罗斯实施第8轮制裁措施,并已就此向欧盟提出了建议。虽然贝尔伯克没有透露具体制裁的内容,但她强调,能够长期维持对俄罗斯的制裁非常重要。(央视新闻)[2022/9/1 13:00:54]
在这篇文章中,一方面我们会对区块链数据结构的基本概念进行讲解,例如哈希的工作原理,另一方面,也会以实际代码来构建一个区块链基本的数据结构,让你对区块链和Python的基础有个基本的理解。
说不多说,下面就进入正题!
英国外交大臣:正在研究(俄罗斯)可以用来破坏制裁的途径:3月1日消息,英国外交大臣特拉斯:我们正在研究(俄罗斯)可以用来破坏制裁的途径,包括加密货币。(金十)[2022/3/1 13:28:26]
从哈希函数说起
在区块链中,数据结构是十分重要的基本组成部分,尤其是比特币。虽然单一的数据结构无法构建成加密数字货币,但理解数据结构对于理解区块链的基本原理是非常有益处的。
但在讲数字结构之前,我们还是先从哈希讲起,以比特币的SHA-256哈希函数为例,讲讲如何利用Python去实现哈希的运算。
哈希函数,又称散列算法,是一种从任何一种数据中创建小的数字“指纹”的方法。散列函数把消息或数据压缩成摘要,使得数据量变小,将数据的格式固定下来。该函数将数据打乱混合,重新创建一个叫做散列值的指纹。散列值通常用一个短的随机字母和数字组成的字符串来代表。
声音 | 国家外汇管理局总会计师:有支付机构跨境向我国外贸企业提供支付服务 进行比特币、ICO交易:据和讯新闻消息,5月29日,在“2019金融街论坛年会”上,国家外汇管理局总会计师孙天琦表示,在我国实践中,“跨境交付”模式下跨境金融服务快速发展,“跨境交付”模式跨境金融服务便利了支付结算服务等金融服务,但也有一些非法的跨境金融服务掺杂其中。有境内居民跨境炒股票、期货和贵金属,支付机构跨境向我国外贸企业提供支付服务,进行比特币、ICO交易,通过互联网、APP等参与境外、球等现象。[2019/5/30]
对于任意长度的消息,SHA256都会产生一个256bit长的哈希值,称作消息摘要。
这个摘要相当于是个长度为32个字节的数组,通常用一个长度为64的十六进制字符串来表示。
国外媒体:下一代家将成为数字货币最大的支持者:国外有媒体发文认为,下一代家将成为数字货币最大的支持者。并列举了支持数字货币的年轻家,如美国36岁的共和党参议院候选人Austin Petersen、曾竞选美国新罕布什尔州州长的32岁的Andrew Hemingway 、29岁正在竞选国会议员的民主党人Patrick Nelson,28岁的意大利的Gian Luca Comandini。文章称亲数字货币的年轻家正在出现,但形成气候还需要4到6年,但全世界的议会早晚会充斥着支持比特币的家。[2018/3/4]
来看一个例子:
这句话,经过哈希函数SHA256后得到的哈希值为:
说回SHA-256,说白了,它就是一个哈希函数。那么我们如何用Python来实现呢?下面代码展示了用Python实现「helloworld」的过程:
国外某评级机构将NEO评为A暴露出其过于关注价格:近期,国外某评级机构将NEO评级为唯一的A,暴露出该机构的评级模型过于关注短期价格,国内某评级机构表示,评级时对于公链的考量,更应该关注与dAPP数、TPS、节点数及分布情况,而NEO在这些核心维度上的表现均差强人意,尤其是其出块节点过少,存在极大中心化风险。[2018/2/28]
看到这里你可能会问,SHA-256中的「256」究竟是什么意思?哈希算法是一个将任意文本转换为一个256位随机二进制字符串的过程。在上面的例子中,「helloworld」是一个11位的字符,经过哈希运算以后,变成了这样的一串字符:
b94d27b9934d3e08a52e52d7da7dabfac484efe37a5380ee9088f7ace2efcde9
同样,即使我的文本长度不是11位,生成的字符数也是一样的。例如:
在上面例子中,「Iamthebestpresident.Ever.」,哈希运算之后的字符串一样为64位。就算输入的文本是100位,哈希运算后的字符位数也是64位。
之所以这样,是因为字符是16进制的,如果我们把这样的字符串转换为2进制,那么就会得到一个256位的2进制字符串。如下图所示:
这就是SHA-256中,256这个数字的由来。
接下来我们就来看看哈希算法有哪些特征。哈希的特征之一就是「无冲突原则」。这个原则是指要得到一个256位的2进制字符串,显然有不止一个输入可以做到。
因为256位的输出长度是固定的,但输入的长度却没有限制,所以输入的范围要远大于输出,只要能够穷尽输入,就有可能得到2个一样的256位的输出。
话虽如此,不过要找到这样两个输入的难度却很大。即使是输入上改动了一点,输出的结果都会完全不同。如下图所示:
所以,想要找到2中一样的输出的唯一方法,是穷尽所有的字幕、数字组合,这几乎无法做到。几率为2的256次方。
这是个多大的数字?展开来就是酱婶儿的:
115792089237316195423570985008687907853269984665640564039457584007913129639936
几乎相当于10的77次方。这是个什么概念?在460亿光年的宇宙内,可见的原子数量也只有10的78次方。这个数字几乎相当于宇宙内的原子数量!
要运算这个数字需要多长时间?以英伟达Geforce1080Ti显卡,浮点运算11.3的算力来运算,每个哈希需要运算3000次,以每秒钟3766666666个哈希的速度来运算,找到两个相同的哈希运算结果,需要计算2的128次方个哈希。地球上所有的人一起计算,需要的时间如下:
这比地球存在的实时间都要长。
用Python创建第一个区块
了解了什么是哈希,我们接着就来说说什么是区块。实际上,区块链就是一个互相连接的序列。我们接下来创建第一个区块,也称为「创世区块」。代码如下所示:
区块链中会包含交易,交易很好理解,就是谁转了多少钱给谁。我们把区块进行序列,这样它就可以进行哈希运算:
这样,我们就得到了另一个区块,我们姑且称它为「区块2」:
再对区块2进行哈希运算:
得到了「区块3」。
再对区块3进行哈希运算,得到了「区块4」。
这样一来,想要确定区块上的数据没有被篡改,我只需要检查最后一个区块的哈希就行了。而不是从创世区块开始检查。这一原理也杜绝了区块链上数据被攒该的可能。
通过以上代码,可以得到下面结果:
这样,用Python实现简单的区块链开发的演示就结束了。Python是一门强大的语言,区块链是一个强大的信用工具,这两者结合,势必能创造出新的可能性。
怎么样,今天的内容你都学会了吗?还想看哪些技术教程,欢迎留言告诉营长!
参考链接:
https://medium.com/coinmonks/building-a-simple-blockchain-data-structure-with-python-e7ebd448647a
https://blog.csdn.net/u011583927/article/details/80905740
9月9日消息,英国税务海关总署、在线平台eToro和会计行业机构ICAEW最近在一次网络研讨会中联合向加密交易者提供税务建议.
1900/1/1 0:00:00一、产品方面1、上线KYC识别功能,用户可通过人脸、证件识别功能完成KYC认证。2、优化APP端交易深度图。3、优化APP自选交易币对,用户更新APP后仍可保留自选币对记录.
1900/1/1 0:00:00尊敬的ZDCoin用户:ZDPLUS第四、第五期和部分ZD手续费抵扣,共计销毁200万ZD,已于2019年9月9日全部销毁,目前ZD一共已销毁5.0352亿枚,剩余总量为5.7648亿.
1900/1/1 0:00:00摘要:DeFi需要更为复杂的金融工具。 虽然加密资产的主要用例仍然是投机,但我不认为这是一件坏事。投机是传统金融市场发展的一个关键驱动力,并在今天继续发挥着重要作用.
1900/1/1 0:00:00数据隐私是当今社会最受关注的问题之一,随着互联网应用的普及和人们对互联网的依赖,我们的一举一动都在产生着数据,从华住酒店房客信息泄露到facebook用户隐私的曝光,隐私泄露问题愈演愈烈.
1900/1/1 0:00:001.Bakkt官方推特宣布正式推出比特币存储服务Bakkt在其官方推特宣布,该公司正式向客户开放BakktWarehouse服务,并表示为在9月23日推出的Bakkt比特币每日和月度期货做准备.
1900/1/1 0:00:00