定义格式
函数构成代码执行的逻辑结构。在Go语言中,函数的基本组成为:关键字func、函数名、参数列表、返回值、函数体和返回语句。
Go语言函数定义格式如下:
funcFuncName(/*参数列表*/)(o1type1,o2type2/*返回类型*/){
//函数体、
returnv1,v2//返回多个值
}
函数定义说明:
func:函数由关键字func开始声明
FuncName:函数名称,根据约定,函数名首字母小写即为private,大写即为public
参数列表:函数可以有0个或多个参数,参数格式为:变量名类型,如果有多个参数通过逗号分隔,不支持默认参数
返回类型:
① 上面返回值什么两个变量名,当然这不是必须的,可以有类型,没变量。② 如果只有一个返回值且不声明返回值变量,那么你可以省略,包括返回值的括号。③ 如果没有返回值,那么就直接省略最后的返回信息。④ 如果有返回值,那么必须在函数的内部添加return语句
DEGO NFT流动性挖矿将于21:00开启:据官方消息,DEGO的NFT流动性挖矿将于北京时间21:00开启。[2020/9/29]
函数定义
无参无返回值
funcTest(){//无参无返回值函数定义
fmt.Println("thisisatestfunc")
}
funcmain(){
Test()//无参无返回值函数调用
}
有参无返回值
普通参数列表
funcTest01(v1int,v2int){//方式1
fmt.Printf("v1=%d,v2=%d\n",v1,v2)
}
funcTest02(v1,v2int){//方式2,v1,v2都是int类型
加密钱包 ZenGo 将推出跨链原子交换功能 JugglingSwap:加密钱包 ZenGo 提出一种新型跨链原子交换协议 JugglingSwap。ZenGo 表示,该种新型解决方案是基于原有的交易协议进行改进,允许更高的互操作性,将基于非托管的解决方案,利用 ZenGo 的创新型私钥解决方案的核心技术,可实现点对点的跨链交易功能,支持比特币、以太坊、Libra、Tezos 等区块链。目前 ZenGo 已发布该新型原子交换功能的白皮书以及演示版本。[2020/8/6]
fmt.Printf("v1=%d,v2=%d\n",v1,v2)
}
funcmain(){
Test01(10,20)//函数调用
Test02(11,22)//函数调用
}
不定参数类型
不定参数是指函数传入的参数个数为不定数量。为了做到这点,首先需要将函数定义为接受不定参数类型:
Argo Blockchain首席执行官Peter Wall增持0.2%公司股份:伦交所披露信息显示,Argo Blockchain首席执行官Peter Wall以每股0.2便士的价格增持了57万股公司股份,总价值约为19950英镑,占总股本的0.2%。[2020/7/8]
//形如...type格式的类型只能作为函数的参数类型存在,并且必须是最后一个参数funcTest(args...int){
for_,n:=rangeargs{//遍历参数列表
fmt.Println(n)
}
}
funcmain(){
//函数调用,可传0到多个参数
Test()
Test(1)
Test(1,2,3,4)
}
不定参数的传递
Argo Blockchain 2月开采337.5枚BTC,挖矿收入较1月增长56%:上市矿企Argo Blockchain更新2月挖矿业务:公司在2月份开采了337.5枚比特币,相较于1月份(247枚)增加了37%。根据当月的每日外汇汇率和加密货币价格计算,该公司的挖矿收入为254万英镑,较1月份(163万英镑)增长56%。公司的挖矿利润率达50%。2月份的挖矿条件和算法难度与上月基本持平。
该公司还宣布,它已经提前实现了到2020年第一季度末生产17000台机器的目标。自今年年初以来,该公司已经安装了10000台比特大陆Antminer T17矿机,总投资为744万英镑(约合951万美元),使Argo的挖矿能力达到了665 PH。该公司还订购了1000台Antminer S17+矿机,总成本为117万英镑(约合150万美元)。该项投资全部由内部产生的现金流提供资金,也是该公司维持资本支出的一部分。新矿机预计将在4月底交付和安装,将使Argo的BTC总挖矿能力达到730 PH左右,增长约10%。此外,公司在北美的挖矿业务没有受到冠状病疫情的影响。(Advfn)[2020/3/4]
funcMyFunc01(args...int){
动态 | Nebulas宣布成立社区协助平台Go Nebulas:3月26日,Nebulas官方推特宣布成立社区协助平台Go Nebulas。[2019/3/27]
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
}
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。