界说格局
函数构成代码履行的逻辑结构。在Go言语中,函数的根本组成为:关键字func、函数名、参数列表、回来值、函数体和回来语句。
Go言语函数界说格局如下:
funcFuncName(/*参数列表*/)(o1type1,o2type2/*回来类型*/){
//函数体、
returnv1,v2//回来多个值
}
函数界说说明:
func:函数由关键字func开端声明
funcName:函数名称,根据约定,函数名首字母小写即为private,大写即为public
参数列表:函数可以有0个或多个参数。
回来类型:① 上面回来值什么两个变量名,当然这不是必须的,可以有类型,没变量。② 假如只有一个回来值且不声明回来值变量,那么你可以省略,包含回来值的括号。③ 假如没有回来值,那么就直接省略最终的回来信息。④ 假如有回来值,那么必须在函数的内部添加return语句函数界说。
Aavegotchi关于关闭GHST联合曲线的提案已获投票通过:2月28日消息,Aave生态NFT游戏Aavegotchi关于关闭协议代币GHST联合曲线的提案已获得投票通过,该提案最终支持率为91.17%。
提案认为,AavegotchiDAO经过两年的发展已经具备足够的成熟度和流动性来满足项目发展,因此提议关闭GHST联合曲线,将GHST与DAI脱钩,固定其供应,并使GHST成为自由流通的代币。此外,曲线中的2000万枚DAI将用于项目的持续开发以及提高流动性,以促进GHST的推广使用。[2023/2/28 12:33:53]
无参无回来值
funcTest(){//无参无回来值函数界说
fmt.Println("thisisatestfunc")
数据:当前Polygon上总锁仓量为41.9亿美元:金色财经报道,数据显示,目前Polygon上总锁仓量41.9亿美元,净锁仓量32.2亿美元。锁仓资产排名前五分别为Aave(18亿美元)、QuickSwap(7.91亿美元)、Curve(4.40亿美元)、SushiSwap(3.31亿美元)、BalancerV2(1.69亿美元)。[2021/10/10 20:17:41]
}
funcmain(){
Test()//无参无回来值函数调用
}
有参无回来值
一般参数列表
funcTest01(v1int,v2int){//方法1
fmt.Printf("v1=%d,v2=%d\n",v1,v2)
}
funcTest02(v1,v2int){//方法2,v1,v2都是int类型
Ergo公链创始人:Ergo已破解比特币UTXO不能上智能合约难题:据官方消息,Ergo公链创始人Alexander Chepurnoy近日指出,随着SigmaUSD算法稳定币启动,Ergo拍卖正常运行,ErgoMixer即将代币化收入流,现在开发者们可入驻Ergo平台开发众筹、贷款、挖矿算力衍生品、彩票、利润分享机制、Email和Paper客户端、本地交易所交易系统和其他社区代币、去中心化交易所等DeFi应用。ErgoDEX团队正在开发委托单簿DEX和AMM DEX,但始终欢迎更多开发者参与,特别是DEX UI的开发。
Ergo已有开发工具包括Headless DApp Framework、ErgoAppKit、Ergo Playground、 Ergo JS Template等。[2021/5/3 21:20:15]
fmt.Printf("v1=%d,v2=%d\n",v1,v2)
}
funcmain(){
动态 | 韩国交易所Gopax获得ISMS认证:韩国虚拟货币交易所Gopax在韩国首次通过韩国网络振兴院(KISA)所运用的信息保护管理体系(ISMS,Information Security Management System)。ISMS是保证交易所网络安全的体系,以此可以评价交易所的信息与资产保护管理体系是否安全可信。[2018/10/22]
Test01(10,20)//函数调用
Test02(11,22)//函数调用
}
不定参数列表
不定参数类型
不定参数是指函数传入的参数个数为不定数量。为了做到这点,首先需要将函数界说为接受不定参数类型:
//形如...type格局的类型只能作为函数的参数类型存在,而且必须是最终一个参数funcTest(args...int){
for_,n:=rangeargs{//遍历参数列表
公告 | DragonEx交易所现支持VET Token切换:据Ambcrypto消息,VeChain主网VeChainThor已于六月底上线,DragonEx交易所现支持VET(VEN已改名为VET)Token切换。[2018/7/4]
fmt.Println(n)
}
}
funcmain(){
//函数调用,可传0到多个参数
Test()
Test(1)
Test(1,2,3,4)
}
不定参数的传递
funcMyFunc01(args...int){
fmt.Println("MyFunc01")
for_,n:=rangeargs{//遍历参数列表
fmt.Println(n)
}
}
funcMyFunc02(args...int){
fmt.Println("MyFunc02")
for_,n:=rangeargs{//遍历参数列表
fmt.Println(n)
}
}
funcTest(args...int){
MyFunc01(args...)//按原样传递,Test()的参数原封不动传递给MyFunc01
MyFunc02(args...)//Test()参数列表中,第1个参数及今后的参数传递给MyFunc02
}
funcmain(){
Test(1,2,3)//函数调用
}
无参有回来值
有回来值的函数,必须有清晰的终止语句,否则会引发编译过错。
一个回来值
funcTest01()int{//方法1
return250
}
//官方主张:最好命名回来值,由于不命名回来值,虽然使得代码愈加简练了,可是会造成生成的文档可读性差
funcTest02()(valueint){//方法2,给回来值命名
value=250
returnvalue
}
funcTest03()(valueint){//方法3,给回来值命名
value=250
return
}
funcmain(){
v1:=Test01()//函数调用
v2:=Test02()//函数调用
v3:=Test03()//函数调用
fmt.Printf("v1=%d,v2=%d,v3=%d\n",v1,v2,v3)
}
多个回来值
funcTest01()(int,string){//方法1
return250,"sb"
}
funcTest02()(aint,strstring){//方法2,给回来值命名
a=250
str="sb"
return
}
funcmain(){
v1,v2:=Test01()//函数调用
_,v3:=Test02()//函数调用,第一个回来值丢掉
v4,_:=Test02()//函数调用,第二个回来值丢掉
fmt.Printf("v1=%d,v2=%s,v3=%s,v4=%d\n",v1,v2,v3,v4)
}
有参有回来值
//求2个数的最小值和最大值
funcMinAndMax(num1int,num2int)(minint,maxint){
ifnum1>num2{//假如num1大于num2
min=num2
max=num1
}else{
max=num2
min=num1
}
return
}
funcmain(){
min,max:=MinAndMax(33,22)
fmt.Printf("min=%d,max=%d\n",min,max)//min=22,max=33
}
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。