前段時(shí)間,我們實(shí)驗(yàn)室用go作為后臺開發(fā)語言開發(fā)了一個(gè)web項(xiàng)目,由于這是自己第一次使用go語言進(jìn)行開發(fā),在開發(fā)過程中,一味著追求完成任務(wù),在編碼的時(shí)候沒有太注重性能,雖然勉強(qiáng)實(shí)現(xiàn)了功能,但是對go語言的理解還是比較淺顯的。下面來談?wù)勛约簩o語言中函數(shù)與方法的理解。
成都創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),新蔡企業(yè)網(wǎng)站建設(shè),新蔡品牌網(wǎng)站建設(shè),網(wǎng)站定制,新蔡網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,新蔡網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
普通函數(shù):
go函數(shù)可以返回多個(gè)值
值傳遞: 值傳遞是指在調(diào)用函數(shù)時(shí)將實(shí)際參數(shù)復(fù)制一份傳遞到函數(shù)中,這樣函數(shù)中如果對參數(shù)進(jìn)行修改,將不會影響到實(shí)際參數(shù)
引用傳遞: 引用傳遞是指在調(diào)用函數(shù)將實(shí)際參數(shù)的地址傳遞到函數(shù)中,那么在函數(shù)中對參數(shù)進(jìn)行的修改,將影響到實(shí)際參數(shù)。
一般來說go語言函數(shù)的 接收者(也就是形參)一般放在函數(shù)名后面 ,不能將指針類型的數(shù)據(jù)直接傳遞,也就是說函數(shù)形參如果是值類型,調(diào)用者必須使用值作為實(shí)參過來,如果函數(shù)形參是指針類型,則函數(shù)調(diào)用者需使用指針作為實(shí)參來調(diào)用。
普通方法:
接收者是在func關(guān)鍵字后面,而不是在函數(shù)名稱后面,接收者可以是自己定義的一個(gè)類型,這個(gè)類型可以是struct、interface,一個(gè)方法就是一個(gè)包含了接收者的函數(shù),接收者可以是命名類型或者是結(jié)構(gòu)體類型的一個(gè)值或者是一個(gè)指針。
下面是一個(gè)例子來說明方法和函數(shù)的區(qū)別(重點(diǎn))
1.可以用DateDiff函數(shù),返回值表示兩個(gè)指定日期間的時(shí)間間隔。
2.也可以把兩個(gè)日期直接相減:
a = Now - CDate("2014-1-1") '2014年1月1日到今天,共這么多天。
b = CDate("2014-3-1") - CDate("2014-1-1") '2014年1月1日到2014年3月1日,共這么多天。
vb的函數(shù)是強(qiáng)大的,閏年和平年它自己會處理,無需擔(dān)心。
追問:
那需要什么控件,能詳細(xì)說一下嗎
回答:
不需要任何控件呢,是系統(tǒng)自帶的函數(shù)呢,你寫到代碼里面試試就可以了。
你稍等,我給你寫代碼:
'窗體弄一個(gè)按鈕Command1,加入以下代碼,你試試看:
Private Sub Command1_Click()
Dim a As Long
Dim b As Long
a = Now - CDate("2014-1-1")'2014年1月1日到今天,共這么多天。
b = CDate("2014-3-1") - CDate("2014-1-1")'2014年1月1日到2014年3月1日,共這么多天。
Print "2014年1月1日到今天,共" a "天。"
Print "2014年1月1日到2014年3月1日,共" b "天。"
End Sub
選擇單元格區(qū)域中的一列日期或時(shí)間,或者確?;顒訂卧裨诎掌诨驎r(shí)間的表列中。
選擇單元格區(qū)域或表中的一列日期或時(shí)間。
在“開始”選項(xiàng)卡上的“編輯”組中,單擊“排序和篩選”,然后執(zhí)行下列操作之一:
若要按從早到晚的順序?qū)θ掌诨驎r(shí)間排序,請單擊“從最舊到最新排序”。
若要按從晚到早的順序?qū)θ掌诨驎r(shí)間排序,請單擊“從最新到最舊排序”。
問題:檢查日期和時(shí)間是否存儲為日期或時(shí)間 如果結(jié)果不是您所希望的,可能是因?yàn)樵摿兄邪鎯槲谋荆ǘ皇侨掌诨驎r(shí)間)的日期或時(shí)間。要使 Excel 正確地對日期和時(shí)間進(jìn)行排序,該列中的所有日期和時(shí)間都必須存儲為日期或時(shí)間系列數(shù)值。如果 Excel 無法將值識別為日期或時(shí)間值,就會將該日期或時(shí)間存儲為文本。有關(guān)詳細(xì)信息,請參閱將存儲為文本的日期轉(zhuǎn)換為日期。
注釋 如果要按星期日期進(jìn)行排序,請?jiān)O(shè)置單元格格式以顯示星期日期。如果要按星期日期進(jìn)行排序,而不考慮日期,請使用 TEXT 函數(shù)將它們轉(zhuǎn)換為文本。但是,TEXT 函數(shù)會返回一個(gè)文本值,因此排序操作將基于字母數(shù)字?jǐn)?shù)據(jù)。有關(guān)詳細(xì)信息,請參閱按星期日期顯示日期。
GO是編譯性語言,所以函數(shù)的順序是無關(guān)緊要的,為了方便閱讀,建議入口函數(shù) main 寫在最前面,其余函數(shù)按照功能需要進(jìn)行排列
GO的函數(shù) 不支持嵌套,重載和默認(rèn)參數(shù)
GO的函數(shù) 支持 無需聲明變量,可變長度,多返回值,匿名,閉包等
GO的函數(shù)用 func 來聲明,且左大括號 { 不能另起一行
一個(gè)簡單的示例:
輸出為:
參數(shù):可以傳0個(gè)或多個(gè)值來供自己用
返回:通過用 return 來進(jìn)行返回
輸出為:
上面就是一個(gè)典型的多參數(shù)傳遞與多返回值
對例子的說明:
按值傳遞:是對某個(gè)變量進(jìn)行復(fù)制,不能更改原變量的值
引用傳遞:相當(dāng)于按指針傳遞,可以同時(shí)改變原來的值,并且消耗的內(nèi)存會更少,只有4或8個(gè)字節(jié)的消耗
在上例中,返回值 (d int, e int, f int) { 是進(jìn)行了命名,如果不想命名可以寫成 (int,int,int){ ,返回的結(jié)果都是一樣的,但要注意:
當(dāng)返回了多個(gè)值,我們某些變量不想要,或?qū)嶋H用不到,我們可以使用 _ 來補(bǔ)位,例如上例的返回我們可以寫成 d,_,f := test(a,b,c) ,我們不想要中間的返回值,可以以這種形式來舍棄掉
在參數(shù)后面以 變量 ... type 這種形式的,我們就要以判斷出這是一個(gè)可變長度的參數(shù)
輸出為:
在上例中, strs ...string 中, strs 的實(shí)際值是b,c,d,e,這就是一個(gè)最簡單的傳遞可變長度的參數(shù)的例子,更多一些演變的形式,都非常類似
在GO中 defer 關(guān)鍵字非常重要,相當(dāng)于面相對像中的析構(gòu)函數(shù),也就是在某個(gè)函數(shù)執(zhí)行完成后,GO會自動這個(gè);
如果在多層循環(huán)中函數(shù)里,都定義了 defer ,那么它的執(zhí)行順序是先進(jìn)后出;
當(dāng)某個(gè)函數(shù)出現(xiàn)嚴(yán)重錯誤時(shí), defer 也會被調(diào)用
輸出為
這是一個(gè)最簡單的測試了,當(dāng)然還有更復(fù)雜的調(diào)用,比如調(diào)試程序時(shí),判斷是哪個(gè)函數(shù)出了問題,完全可以根據(jù) defer 打印出來的內(nèi)容來進(jìn)行判斷,非??焖伲@種留給你們?nèi)?shí)現(xiàn)
一個(gè)函數(shù)在函數(shù)體內(nèi)自己調(diào)用自己我們稱之為遞歸函數(shù),在做遞歸調(diào)用時(shí),經(jīng)常會將內(nèi)存給占滿,這是非常要注意的,常用的比如,快速排序就是用的遞歸調(diào)用
本篇重點(diǎn)介紹了GO函數(shù)(func)的聲明與使用,下一篇將介紹GO的結(jié)構(gòu) struct
本文題目:go語言時(shí)間函數(shù),go語言函數(shù)定義
分享鏈接:http://chinadenli.net/article38/heeisp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、網(wǎng)站導(dǎo)航、網(wǎng)站維護(hù)、移動網(wǎng)站建設(shè)、外貿(mào)建站、定制開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)