全球以英國(guó)倫敦格林威治作為零度經(jīng)線的起點(diǎn),每隔15經(jīng)度為一個(gè)時(shí)區(qū),15度經(jīng)線為該時(shí)區(qū)的中央經(jīng)線,共分為24個(gè)時(shí)區(qū)。由西向東每隔15經(jīng)度增加一個(gè)時(shí)區(qū),相反的,每向西15經(jīng)度減少一個(gè)時(shí)區(qū)。中國(guó)所在時(shí)區(qū)為東8區(qū)。

創(chuàng)新互聯(lián)建站是一家專業(yè)提供洛陽(yáng)企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、H5技術(shù)、小程序制作等業(yè)務(wù)。10年已為洛陽(yáng)眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站建設(shè)公司優(yōu)惠進(jìn)行中。
當(dāng)前時(shí)間 time.Now() 返回的是當(dāng)?shù)貢r(shí)區(qū)的時(shí)間:
CST可以代表如下四個(gè)不同的時(shí)區(qū):
time.Now() 返回的 +0800 CST 表示的就是中國(guó)標(biāo)準(zhǔn)時(shí)間,與UTC時(shí)間有如下的轉(zhuǎn)化:
Wall Clocks表示掛鐘時(shí)間,存儲(chǔ)的是自1970 年 1 月 1 日 0 時(shí) 0 分 0 秒以來(lái)的時(shí)間戳,當(dāng)系統(tǒng)和授時(shí)服務(wù)器進(jìn)行校準(zhǔn)時(shí)間時(shí)間操作時(shí),有可能造成這一秒是2018-1-1 00:00:00,而下一秒變成了2017-12-31 23:59:59的情況。
Monotonic Clocks,意思是單調(diào)時(shí)間的,所謂單調(diào),就是只會(huì)不停的往前增長(zhǎng),不受校時(shí)操作的影響,這個(gè)時(shí)間是自進(jìn)程啟動(dòng)以來(lái)的秒數(shù)。
time.Now() 返回的 m=+0.004002201 就是表示Monotonic Clocks
go語(yǔ)言中如果不設(shè)置指定的時(shí)區(qū),通過(guò) time.Now() 獲取到的就是本地時(shí)區(qū)
設(shè)置時(shí)區(qū)有兩種方式:
固定時(shí)區(qū)到東八區(qū)。但這種不是對(duì)程序的全局設(shè)置,每次獲取時(shí)都需要固定時(shí)區(qū)
加載指定時(shí)區(qū)。但如果沒(méi)有g(shù)o環(huán)境使用這種方式就會(huì)加載失敗,因?yàn)闀r(shí)區(qū)信息是放在go的安裝包中的。
如果你用第二種方式加載時(shí)區(qū),在打docker鏡像時(shí)就需要進(jìn)行時(shí)區(qū)相關(guān)的配置,配置文件如下:
參考文章:
是 go 語(yǔ)言 自帶 的 測(cè)試 工具,
其中包含的是 兩類 ,
通過(guò) go help test 可以看到 go test 的 使用 說(shuō)明:
go test [-c] [-i] [build flags] [packages] [flags for test binary]
參數(shù)解讀:
-test.v : 是否輸出全部的單元測(cè)試用例(不管成功或者失敗),默認(rèn)沒(méi)有加上,所以只輸出失敗的單元測(cè)試用例。
-test.run pattern: 只跑哪些單元測(cè)試用例
-test.bench patten: 只跑那些性能測(cè)試用例
-test.benchmem : 是否在性能測(cè)試的時(shí)候輸出內(nèi)存情況
-test.benchtime t : 性能測(cè)試運(yùn)行的時(shí)間,默認(rèn)是1s
-test.cpuprofile cpu.out : 是否輸出cpu性能分析文件
-test.memprofile mem.out : 是否輸出內(nèi)存性能分析文件
-test.blockprofile block.out : 是否輸出內(nèi)部goroutine阻塞的性能分析文件
-test.memprofilerate n : 內(nèi)存性能分析的時(shí)候有一個(gè)分配了多少的時(shí)候才打點(diǎn)記錄的問(wèn)題。這個(gè)參數(shù)就是設(shè)置打點(diǎn)的內(nèi)存分配間隔,也就是profile中一個(gè)sample代表的內(nèi)存大小。默認(rèn)是設(shè)置為512 * 1024的。如果你將它設(shè)置為1,則每分配一個(gè)內(nèi)存塊就會(huì)在profile中有個(gè)打點(diǎn),那么生成的profile的sample就會(huì)非常多。如果你設(shè)置為0,那就是不做打點(diǎn)了。
你可以通過(guò)設(shè)置memprofilerate=1和GOGC=off來(lái)關(guān)閉內(nèi)存回收,并且對(duì)每個(gè)內(nèi)存塊的分配進(jìn)行觀察。
-test.blockprofilerate n: 基本同上,控制的是goroutine阻塞時(shí)候打點(diǎn)的納秒數(shù)。默認(rèn)不設(shè)置就相當(dāng)于-test.blockprofilerate=1,每一納秒都打點(diǎn)記錄一下
-test.parallel n : 性能測(cè)試的程序并行cpu數(shù),默認(rèn)等于GOMAXPROCS。
-test.timeout t : 如果測(cè)試用例運(yùn)行時(shí)間超過(guò)t,則拋出panic
-test.cpu 1,2,4 : 程序運(yùn)行在哪些CPU上面,使用二進(jìn)制的1所在位代表,和nginx的nginx_worker_cpu_affinity是一個(gè)道理
-test.short : 將那些運(yùn)行時(shí)間較長(zhǎng)的測(cè)試用例運(yùn)行時(shí)間縮短
作為一個(gè)測(cè)試,作為一個(gè)測(cè)試開(kāi)發(fā), 全棧化+管理 是我們未來(lái)的發(fā)展方向。已經(jīng)掌握了Java、Python、HTML的你,是不是也想了解下最近異常火爆的Go語(yǔ)言呢?來(lái)吧,讓我們一起了解下。
Go 是一個(gè)開(kāi)源的編程語(yǔ)言 ,它能讓構(gòu)造簡(jiǎn)單、可靠且高效的軟件變得容易。
Go是從2007年末由Robert Griesemer, Rob Pike, Ken Thompson主持開(kāi)發(fā),后來(lái)還加入了Ian Lance Taylor, Russ Cox等人,并最終于2009年11月開(kāi)源,在2012年早些時(shí)候發(fā)布了Go 1穩(wěn)定版本。現(xiàn)在Go的開(kāi)發(fā)已經(jīng)是完全開(kāi)放的,并且擁有一個(gè)活躍的社區(qū)。這三個(gè)人都是計(jì)算機(jī)界的大神,有的參與了C語(yǔ)言的編寫(xiě),有的還是數(shù)學(xué)大神,有的還獲得了計(jì)算機(jī)最高榮譽(yù)-圖靈獎(jiǎng)。
接下來(lái)說(shuō)說(shuō) Go語(yǔ)言的特色 :
簡(jiǎn)潔、快速、安全
并行、有趣、開(kāi)源
內(nèi)存管理、數(shù)組安全、編譯迅速
Go語(yǔ)言的用途 :
Go 語(yǔ)言被設(shè)計(jì)成一門(mén)應(yīng)用于搭載 Web 服務(wù)器,存儲(chǔ)集群或類似用途的巨型中央服務(wù)器的系統(tǒng)編程語(yǔ)言。
對(duì)于高性能分布式系統(tǒng)領(lǐng)域而言,Go 語(yǔ)言無(wú)疑比大多數(shù)其它語(yǔ)言有著更高的開(kāi)發(fā)效率。它提供了海量并行的支持,這對(duì)于 游戲 服務(wù)端的開(kāi)發(fā)而言是再好不過(guò)了。
Go語(yǔ)言的環(huán)境安裝:
建議直接打開(kāi) 官方地址因?yàn)閴Φ脑虼虿婚_(kāi)
因?yàn)槲矣玫氖莣indows系統(tǒng),這里主要講下Windows系統(tǒng)上使用Go語(yǔ)言來(lái)編程。
Windows 下可以使用 .msi 后綴(在下載列表中可以找到該文件,如go1.17.2.windows-amd64.msi)的安裝包來(lái)安裝。
默認(rèn)情況下 .msi 文件會(huì)安裝在 c:Go 目錄下。你可以將 c:Gobin 目錄添加到 Path 環(huán)境變量中。添加后你需要重啟命令窗口才能生效。個(gè)人建議還是安裝到 Program Files文件夾中。
使用什么開(kāi)發(fā)工具來(lái)對(duì)Go語(yǔ)言進(jìn)行編寫(xiě):
個(gè)人建議用VS code, 也可以用Sublime Text來(lái)編輯。如果你之前看了我講的HTML語(yǔ)言的學(xué)習(xí),肯定已經(jīng)下載了VS code. 那么這時(shí)你需要在VS code中下載Go語(yǔ)言的擴(kuò)展插件。
這里有一個(gè)巨大的坑,就是在下載Go的插件和依賴包時(shí),會(huì)提示一些包沒(méi)有。主要是因?yàn)橄螺d的依賴包部分被墻了,只能想別的辦法去下載。
建議參考網(wǎng)頁(yè):
解決vscode中g(shù)olang插件安裝失敗方法
在學(xué)習(xí)go的過(guò)程中,使用的是vscode,但是一直提示安裝相關(guān)插件失敗,然后上網(wǎng)查方法,基本上是叫你建立golang.org目錄什么的,結(jié)果全是錯(cuò)的,而且都是抄襲,很煩。無(wú)意之中看到一位博主分享的方法,他也是飽受上述的垃圾博文困擾,然后找到了解決方法,這里向他致敬,秉著讓更多人看到正確解決方法的心,我寫(xiě)下正確的解決方法,希望對(duì)你有所幫助,也可以點(diǎn)開(kāi)原博主鏈接參考:
Go有一個(gè)全球模塊代理,設(shè)置代理再去安裝golang的插件,就可以安裝成功了。步驟有,首先Windows用戶打開(kāi)Powershell,一個(gè)藍(lán)色的界面,注意不是cmd!不知道的直接打開(kāi)window下面的搜索,然后輸入powershell,搜索出來(lái)就可以了。
$env:GO111MODULE=“on”
$env:GOPROXY=“”
go env -w GOPROXY=
go env -w GOPRIVATE=*.corp.example.com
然后我們打開(kāi)VsCode界面,下面會(huì)提示安裝插件,我們選擇Install ALL,就會(huì)安裝成功
當(dāng)你在運(yùn)行Go語(yǔ)言程序時(shí),提示所有的插件包都已經(jīng)安裝成功了時(shí),就可以正常使用了,要不然一堆報(bào)錯(cuò)會(huì)讓你非常心煩。
好了,今天先到這里,晚安、下班~
通過(guò)runtime.GOMAXPROCS函數(shù),應(yīng)用程序何以在運(yùn)行期間設(shè)置運(yùn)行時(shí)系統(tǒng)中得P最大數(shù)量。但這會(huì)引起“Stop the Word”。所以,應(yīng)在應(yīng)用程序最早的調(diào)用。并且最好的設(shè)置P最大值的方法是在運(yùn)行Go程序之前設(shè)置好操作程序的環(huán)境變量GOMAXPROCS,而不是在程序中調(diào)用runtime.GOMAXPROCS函數(shù)。
最后記住,無(wú)論我們傳遞給函數(shù)的整數(shù)值是什么值,運(yùn)行時(shí)系統(tǒng)的P最大值總會(huì)在1~256之間。
runtime.Goexit函數(shù)被調(diào)用后,會(huì)立即使調(diào)用他的Groution的運(yùn)行被終止,但其他Goroutine并不會(huì)受到影響。runtime.Goexit函數(shù)在終止調(diào)用它的Goroutine的運(yùn)行之前會(huì)先執(zhí)行該Groution中還沒(méi)有執(zhí)行的defer語(yǔ)句。
runtime.Gosched函數(shù)的作用是暫停調(diào)用他的Goroutine的運(yùn)行,調(diào)用他的Goroutine會(huì)被重新置于Gorunnable狀態(tài),并被放入調(diào)度器可運(yùn)行G隊(duì)列中。
runtime.NumGoroutine函數(shù)在被調(diào)用后,會(huì)返回系統(tǒng)中的處于特定狀態(tài)的Goroutine的數(shù)量。這里的特指是指Grunnable\Gruning\Gsyscall\Gwaition。處于這些狀態(tài)的Groutine即被看做是活躍的或者說(shuō)正在被調(diào)度。
注意:垃圾回收所在Groutine的狀態(tài)也處于這個(gè)范圍內(nèi)的話,也會(huì)被納入該計(jì)數(shù)器。
前者調(diào)用會(huì)使調(diào)用他的Goroutine與當(dāng)前運(yùn)行它的M鎖定到一起,后者調(diào)用會(huì)解除這樣的鎖定。
注意:
debug.SetMaxStack函數(shù)的功能是約束單個(gè)Groutine所能申請(qǐng)的棧空間的最大尺寸。
debug.SetMaxThreads函數(shù)的功能是對(duì)go語(yǔ)言運(yùn)行時(shí)系統(tǒng)所使用的內(nèi)核線程的數(shù)量(確切的說(shuō)是M的數(shù)量)進(jìn)行設(shè)置
會(huì)讓運(yùn)行時(shí)系統(tǒng)進(jìn)行一次強(qiáng)制性的垃圾收集,
用于設(shè)置一個(gè)比率(垃圾收集比率),前面所說(shuō)的單元增量與前一次垃圾收集時(shí)的歲內(nèi)存的單元數(shù)量和此垃圾手機(jī)比率有關(guān)。
觸發(fā)垃圾收集的堆內(nèi)存單元增量=上一次垃圾收集完的堆內(nèi)存單元數(shù)量*(垃圾收集比率/100)
是說(shuō)?20060102150405 這個(gè)嗎,原因大致如下:
可讀性高,所見(jiàn)即所得
實(shí)現(xiàn)簡(jiǎn)單,排除二義性(15或3代表時(shí),4代表分,5代表秒,06或2006代表年)
請(qǐng)參考源代碼:
187 case?'3':
188 return?layout[0:i],?stdHour12,?layout[i+1:]
189
190 case?'4':
191 return?layout[0:i],?stdMinute,?layout[i+1:]
192
193 case?'5':
194 return?layout[0:i],?stdSecond,?layout[i+1:]
195
基本設(shè)計(jì)思路:
類型轉(zhuǎn)換、類型斷言、動(dòng)態(tài)派發(fā)。iface,eface。
反射對(duì)象具有的方法:
編譯優(yōu)化:
內(nèi)部實(shí)現(xiàn):
實(shí)現(xiàn) Context 接口有以下幾個(gè)類型(空實(shí)現(xiàn)就忽略了):
互斥鎖的控制邏輯:
設(shè)計(jì)思路:
(以上為寫(xiě)被讀阻塞,下面是讀被寫(xiě)阻塞)
總結(jié),讀寫(xiě)鎖的設(shè)計(jì)還是非常巧妙的:
設(shè)計(jì)思路:
WaitGroup 有三個(gè)暴露的函數(shù):
部件:
設(shè)計(jì)思路:
結(jié)構(gòu):
Once 只暴露了一個(gè)方法:
實(shí)現(xiàn):
三個(gè)關(guān)鍵點(diǎn):
細(xì)節(jié):
讓多協(xié)程任務(wù)的開(kāi)始執(zhí)行時(shí)間可控(按順序或歸一)。(Context 是控制結(jié)束時(shí)間)
設(shè)計(jì)思路: 通過(guò)一個(gè)鎖和內(nèi)置的 notifyList 隊(duì)列實(shí)現(xiàn),Wait() 會(huì)生成票據(jù),并將等待協(xié)程信息加入鏈表中,等待控制協(xié)程中發(fā)送信號(hào)通知一個(gè)(Signal())或所有(Boardcast())等待者(內(nèi)部實(shí)現(xiàn)是通過(guò)票據(jù)通知的)來(lái)控制協(xié)程解除阻塞。
暴露四個(gè)函數(shù):
實(shí)現(xiàn)細(xì)節(jié):
部件:
包: golang.org/x/sync/errgroup
作用:開(kāi)啟 func() error 函數(shù)簽名的協(xié)程,在同 Group 下協(xié)程并發(fā)執(zhí)行過(guò)程并收集首次 err 錯(cuò)誤。通過(guò) Context 的傳入,還可以控制在首次 err 出現(xiàn)時(shí)就終止組內(nèi)各協(xié)程。
設(shè)計(jì)思路:
結(jié)構(gòu):
暴露的方法:
實(shí)現(xiàn)細(xì)節(jié):
注意問(wèn)題:
包: "golang.org/x/sync/semaphore"
作用:排隊(duì)借資源(如錢(qián),有借有還)的一種場(chǎng)景。此包相當(dāng)于對(duì)底層信號(hào)量的一種暴露。
設(shè)計(jì)思路:有一定數(shù)量的資源 Weight,每一個(gè) waiter 攜帶一個(gè) channel 和要借的數(shù)量 n。通過(guò)隊(duì)列排隊(duì)執(zhí)行借貸。
結(jié)構(gòu):
暴露方法:
細(xì)節(jié):
部件:
細(xì)節(jié):
包: "golang.org/x/sync/singleflight"
作用:防擊穿。瞬時(shí)的相同請(qǐng)求只調(diào)用一次,response 被所有相同請(qǐng)求共享。
設(shè)計(jì)思路:按請(qǐng)求的 key 分組(一個(gè) *call 是一個(gè)組,用 map 映射存儲(chǔ)組),每個(gè)組只進(jìn)行一次訪問(wèn),組內(nèi)每個(gè)協(xié)程會(huì)獲得對(duì)應(yīng)結(jié)果的一個(gè)拷貝。
結(jié)構(gòu):
邏輯:
細(xì)節(jié):
部件:
如有錯(cuò)誤,請(qǐng)批評(píng)指正。
本文題目:go語(yǔ)言顯示運(yùn)行時(shí)間,go語(yǔ)言獲取當(dāng)前時(shí)間
瀏覽地址:http://chinadenli.net/article47/dsesgej.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、用戶體驗(yàn)、Google、建站公司、域名注冊(cè)、面包屑導(dǎo)航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)