什么是Soilidity?
Solidity是一种面向合约的高级编程语言,用于实现智能合约。Solidity已经被设计用于以太坊虚拟机。
Solidity===智能合约。
Solidity的代码封装在合约中。合约是以太坊应用程序的基本构建块——所有变量和函数都属于一个合约,这将是所有项目的起点。
pragmasolidity>=0
studentpublicstudents;//createsanarraynamedstudentsofstudenttypeobjects
函数声明
functioneatHamburgers(stringmemory_name,uint_amount)public{}
函数的可见性是公开的。有两种方式可以传递参数给Solidity函数:
按值和按引用
eatHamburgers(“vitalik”,100);
私人/公共函数
在Solidity中,函数默认是公共的,因此任何人都可以在网络中调用公共函数。然而,出于安全考虑,我们将函数设为私有,这样只有所有者才能调用函数。
function_eatHamburgers(stringmemory_name,uint_amount)private{?
}
按照惯例,私有函数的开头带有下划线。
内部/外部关键字
美国说唱歌手Megan Thee Stallion与Cash App合作发布比特币科普视频:美国说唱歌手Megan Thee Stallion与由Square开发的移动支付服务Cash App合作发布了一段名为“Bitcoin for Hotties”的视频。该视频从她的角度解释了什么是比特币,为什么比特币有价值等内容。Megan Thee Stallion在Instagram上拥有超过2410万粉丝,在 Twitter上拥有640万粉丝。(Bitcoin News)[2021/8/8 1:41:10]
还有两种类型的函数可见性。内部类似于私有,除了它可以被继承的合约访问,即继承。
外部类似于公共。除了声明了这个函数的联系人之外,所有的合约都可以调用这个函数。
在函数中返回
函数声明包含返回值的类型。
functionsayHi()publicview/purereturns(stringmemory){?
return“Hi”;
}
这些函数可以标记为pure/view。当我们甚至没有访问传递的数据时,我们就将函数标记为pure。如果函数不修改数据,只查看数据,那么它将被标记为view。
类型转换
数据类型之间的转换称为类型转换。
uint8a=5;?
uintb=6;
//linebelowthrowsanerrorbecausea*breturnsauint,notuint8:?
TRON数字钱包科普资料《波场钱包的现在过去与未来》已上线:据最新消息显示,由TokenPocket联合波场TRON官方,以及 TokenPocket 社区志愿者共同撰写的《波场钱包的现在过去与未来》已正式上线。《波场钱包的现在过去与未来》又称为波场钱包小白书,详细介绍了当前TRON钱包与TRON生态密切结合的实例,是目前市面上最为详细的TRON数字钱包科普资料。波场钱包作为波场公链生态中极为重要的入口,是波场生态的重要构成要素。波场钱包从一开始只提供权限管理、转账收款、节点投票等基础功能,到如今不仅可以为用户提供法币交易、闪兑和去中心化交易所等方便快捷的交易服务,还能让用户直接在钱包上体验波场上DApp,挖矿、DeFi、Staking等资产增值服务。详情见原文链接。[2020/8/20]
uint8c=a*b;
//wehavetotypecastbasauint8tomakeitwork:?
uint8c=a*uint8(b);
事件
事件用于向前端传达后端区块链网络上发生了一些事情。
//declaretheevent?
eventNotifyOnFrontend(uintx);?
functionadd(uint_x,uint_y)publicreturns(uint){?
uintresult=_x+_y;?
//fireaneventtoletthefrontendknowthefunctionwascalled?
人民数字FINTECH推出区块链科普动画:人民日报数字传播发布微博称,人民数字FINTECH出品《趣味科普|区块链动画》。[2020/3/31]
emitNotifyOnFrontend(result);?
returnresult;?
}
我们的前端代码应该已经安装了web3,并且应该监听“NotifyOnFrontend”事件,这样才能工作。我们的JavaScript框架或普通JS将不得不监听这个事件来接收它:
YourContract
functiongetUserInfo(string?name)publicviewreturns(uint,string){?
return(allusers.age,allusers.dob);?
}?
}
现在,如果可以用不同的值多次调用setUserInfo,比如:
setuserInfo("Vivek",26,25/05/1995)setuserInfo("Supu",23,01/09/1998)
要获得这些值,只需传递名称:
getUserInfo("Vivek");//2625/05/1995?
getuserInfo("Supu");//2401/09/1998
全局变量
这些变量可用于像msg.sender这样的所有函数。我们所编写的任何Solidity程序,都应该由所有者调用。发送者的地址存储在msg.sender全局变量中。
动态 | 区块链技术入选科普杂志《科学美国人》2019十大突破性技术榜单:据新浪网今日新闻报道,美国科普杂志《科学美国人》公布 2019 十大突破性技术榜单。区块链技术因在保障食品安全中的作用而上榜。 入选榜单具体原因:区块链技术的发展应用将显著改善食品污染源数据追踪的困境。利用区块链云端系统,食品制造商可以依次在计算机储存各类过程的信息。[2019/9/29]
require
require用于验证这两个语句,并据此做出决定。如果条件为真,则代码成功运行,否则就抛出错误
functionsayHi(stringmemory?name)publicreturns(stringmemory){/Comparesif_nameequals“Vivek”Throwsanerrorandexitsifnottrue.Soliditydoesn’thavenativestringcomparison,sowecomparetheirkeccak256hashestoseeifthestringsareequaq?/?
require(keccak256(abi.encodePacked(name))==keccak256(abi.encodePacked(“Vivek”)));
//Ifit’strue,proceedwiththefunction:?
return“Hi!”;
}?
sayHi(“Vivek”)//executessuccessfully?
sayHi(“Supu”)//throwsanerror
动态 | 浙江卫视节目科普支付宝区块链防伪溯源产品:昨日,在浙江卫视播出的科普综艺栏目《智造将来》现场,支付宝首次展示了支付宝区块链防伪溯源产品,以接地气的方式公开向大众展示区块链在生活中的应用。[2019/3/4]
因此,require对于在运行函数之前验证某些条件必须为真非常有用。
继承
有时候,与其制定一个非常长的合约,还不如将代码逻辑拆分为多个合约来组织代码。
contractAnimal{
functioncatchphrase()publicreturns(stringmemory){?
return“Animal”;
}?
}contractCatisAnimal{
functionanotherCatchphrase()publicreturns(stringmemory){?
return“CatisanAnimal”;
}
}
import
将代码拆分为多个文件,并使用import来使用另一个文件中的功能。
这通常是在Solidity项目中处理长代码库的方式。
存储和内存
存储是指永久存储在区块链上的变量。内存变量是临时的,在对合约的外部函数调用之间会被删除。可以把它想象成电脑的硬盘与内存。
与区块链网络中的其他合约交互
关于这一点,我将写一篇单独的文章。现在,保持简短:
为了与其他合约交互,我们声明了一个类似object的接口。我们创建了一个合约,并在里面声明了一个函数,我们想要从另一个合约调用或使用它。函数只是骨架,它不包含主体。
contractGetNumber{?
functiongetNum(uint_num)publicreturns(uint){?
return_num;?
}
假设有一个合约,我们想要使用上面的getNum函数。为此,我们将在项目中创建一个合约,并声明一个getNum函数框架(没有函数体)。
contractNumberInterface{?
functiongetNum(uint_num)publicreturns(uint);?
}
现在我们可以从NumberInterface合约中调用getNum函数。
在将合约部署到以太坊后,它就变成了不可变的,也就是说它不能被修改。部署到合约中的初始代码将永久地停留在区块链上。这就是安全性在Solidity中如此重要的原因之一。如果我们的合约代码中有一个缺陷,就没有办法在以后修补它。必须告诉我们的用户开始使用具有修复功能的不同智能合约地址。
函数修饰符
函数修饰符看起来就像函数,但是使用关键字修饰符而不是关键字函数。这些用于特殊情况,例如当您只希望您的所有者而不是所有人做某事时。
这有助于更新DApp的关键部分,同时防止其他用户破坏我们的合约。我处理过的一个用例是——当我们想在执行任何用例之前验证语句时。
gas
用户支付gas费来在以太坊网络上运行合约。gas以以太(以太坊上的货币)为单位计算。我们的函数的总gas成本等于它所有单独操作的总gas成本。
更多关于存储的内容
存储内存被永久写入到区块链中。全世界成千上万的节点需要将这些数据存储在它们的硬盘上,并且随着区块链的增长,这些数据量也会随着时间的推移而增长。所以这样做是有代价的。
为了降低成本,我们希望避免将数据写入存储,除非绝对必要。有时,这涉及到看似低效的编程逻辑——比如每次调用函数时都要在内存中重新构建数组,而不是简单地将该数组保存在全局存储变量中以便快速查找。
因此,建议尽可能使用内存类型,这样数据就不会永久存储,从而节省成本。循环在Solidity中将比使用存储更便宜。所以尽可能for循环中使用内存。这与Java、Python等语言中所做的完全相反,因为for循环的计算成本更高。
For循环
Syntax类似于Javascript。
for(uinti=1;i<=10;i++){//body}
应付修饰符
支付功能是使Solidity和以太坊如此酷的部分原因——它们是一种可以接收以太坊的特殊类型的功能。当我们在一个普通的web服务器上调用一个API函数时,我们不能在调用函数的同时发送美元——也不能发送比特币。
但在以太坊中,因为货币(以太坊)、数据(交易有效载荷)和合约代码本身都在以太坊上,所以我们可以同时调用一个函数并向合约支付费用。
这允许一些非常有趣的逻辑,比如为了执行一个函数,需要向合约支付一定的费用。
注意:
在以太坊中,当我们在合约上调用一个函数时,我们将其作为交易广播到网络上的一个或多个节点。节点在网络上收集一些交易,试图成为第一个解决计算密集型数学问题的“工作证明”,然后将这组交易连同他们的工作证明发布为一个块到网络的其余部分。
代币
所以基本上,代币只是一个合约,它记录了谁拥有多少代币,以及一些函数,以便这些用户可以将他们的代币转移到其他地址。
assert与require的差异
Assert类似于require,如果为false则抛出错误。assert和require之间的区别是,当一个函数失败时,require会退还用户剩余的gas,而assert不会。
Metamask
这是Chrome和Firefox的浏览器扩展,允许用户安全地管理他们的以太坊账户和私钥,并使用这些账户与使用Web3.js的网站进行交互。
应用程序二进制接口。
在部署的合约之后,它会在以太坊上得到一个固定的地址,在那里它将永远存在。在以太坊网络中部署智能合约后,还会生成一个ABI。基本上,它是以JSON格式表示的合约方法,告诉Web3.js如何以我们的合约能够理解的方式格式化函数调用。
Web3Js
以太坊的JS前端库被称为web3.js。
Source:https://medium.com/coinmonks/learn-all-about-solidity-ethereum-45d709c4de77
原文:北青网 和著名歌手林俊杰做邻居,在现实中很难,在元宇宙中却容易得多。11月23日,林俊杰在推特上展示了他购买的三个虚拟地块,共花费约12.3万美元.
据Newsbitcoin11月10日消息,机构数字资产托管和交易解决方案提供商Copper.co宣布与科幻电影《沙丘》女演员RebeccaFerguson合作推出名为TheUnfairAdvan.
据新京报11月17日消息,B站董事长兼CEO陈睿称,元宇宙是个概念,而不是一个产品,元宇宙包含的一些要素,比如游戏内的生态系统、虚拟现实、社交关系等,这些并不新奇,有些公司已经实现了一部分.
据Blockworks11月25日消息,根据本周早些时候的报道,印度议会最近提交的一项法案提到寻求禁止印度的所有私人加密货币,仅允许某些例外情况来促进加密货币的基础技术及其用途.
巴比特讯,11月12日,在今天华艺国际“NFT数字艺术专场”中,NFT数字艺术家Pak作品Leonardo’sVision《莱奥纳多的愿景》经过现场藏家多轮踊跃竞价.
前言 上一篇文章中,我们在"F_101"上找到了17个点满足椭圆曲线方程,他们构成一个循环。那么在"F_101"中元素作为坐标的点中还有没有其他的点也满足方程呢?换句话说,上篇文章列出的17个点.