国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

腳本之家,腳本語(yǔ)言編程技術(shù)及教程分享平臺(tái)!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Golang - Golang Cron 定時(shí)任務(wù)的實(shí)現(xiàn)示例

Golang Cron 定時(shí)任務(wù)的實(shí)現(xiàn)示例

2020-06-09 11:00jihite Golang

這篇文章主要介紹了Golang Cron 定時(shí)任務(wù)的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

開門見山寫一個(gè)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
package main
 
import (
  "fmt"
  "github.com/robfig/cron"
  "log"
  "strings"
  "time"
)
 
func CronTask() {
  log.Println("******** ******* *******")
}
 
func CronTest() {
  log.Println("Starting Cron...")
 
  c := cron.New()
  c.AddFunc("* * * * * *", CronTask) //2 * * * * *, 2 表示每分鐘的第2s執(zhí)行一次
  c.Start()
 
  t1 := time.NewTimer(time.Second * 10) // ?time.Second * 10 啥意思? *100行嗎?
  for {
    select {
    case <-t1.C:
      fmt.Println("Time now:", time.Now().Format("2006-01-02 15:04:05")) // 為何要專門制定這個(gè)時(shí)間
      t1.Reset(time.Second * 10)
    }
  }
}
 
func main() {
  fmt.Println(strings.Repeat("START ", 15))
  CronTest()
  fmt.Println(strings.Repeat("END ", 15))
}

核心的定時(shí)器代碼就3行

?
1
2
3
c := cron.New()
c.AddFunc("* * * * * *", CronTask)
c.Start()

那后面那些代碼時(shí)作甚的?

一開始看到示例代碼時(shí),有個(gè)疑惑,如代碼中注釋

?
1
t1 := time.NewTimer(time.Second * 10)

這里time.Second*10是干啥的? 是否可以寫成*100呢, 改了后原來(lái)是可以的,那更疑惑了既然都行為啥還要寫個(gè)這個(gè)?

還有后面的for-select-case也是一臉懵逼~~~~

運(yùn)行代碼,從結(jié)果反推下原理吧,一次執(zhí)行結(jié)果

START START START START START START START START START START START START START START START
2020/05/01 07:38:07 Starting Cron...
2020/05/01 07:38:08 ********  *******  *******
2020/05/01 07:38:09 ********  *******  *******
2020/05/01 07:38:10 ********  *******  *******
2020/05/01 07:38:11 ********  *******  *******
2020/05/01 07:38:12 ********  *******  *******
2020/05/01 07:38:13 ********  *******  *******
2020/05/01 07:38:14 ********  *******  *******
2020/05/01 07:38:15 ********  *******  *******
2020/05/01 07:38:16 ********  *******  *******
2020/05/01 07:38:17 ********  *******  *******
Time now: 2020-05-01 07:38:17
2020/05/01 07:38:18 ********  *******  *******
2020/05/01 07:38:19 ********  *******  *******
2020/05/01 07:38:20 ********  *******  *******
2020/05/01 07:38:21 ********  *******  *******
2020/05/01 07:38:22 ********  *******  *******
2020/05/01 07:38:23 ********  *******  *******
2020/05/01 07:38:24 ********  *******  *******
2020/05/01 07:38:25 ********  *******  *******
2020/05/01 07:38:26 ********  *******  *******
2020/05/01 07:38:27 ********  *******  *******
Time now: 2020-05-01 07:38:27
2020/05/01 07:38:28 ********  *******  *******

以上是運(yùn)行的片段,有兩大發(fā)現(xiàn)

  1. 有START START START。。。沒有END END END 。。。。:說(shuō)明了代碼在執(zhí)行時(shí)阻塞在定時(shí)器里,定時(shí)器沒有執(zhí)行完,永遠(yuǎn)不會(huì)執(zhí)行END
  2. Time now打出來(lái)的間隔正好是10s

哦,原來(lái)time.NewTimer是個(gè)定時(shí)器,當(dāng)這個(gè)時(shí)間間隔完了后再重新打開一個(gè)。for-select-case 這一塊目的是阻塞流程,不讓程序結(jié)束。 理解對(duì)嗎

如果是這樣,去掉for-select-case 執(zhí)行第一個(gè)定時(shí)器時(shí)也可以停10s,是這樣嗎?試驗(yàn)下:屏蔽掉for-select-case, 輸出

START START START START START START START START START START START START START START START
2020/05/01 07:56:22 Starting Cron...
END END END END END END END END END END END END END END END

打臉了,看來(lái)阻塞主要靠for-select-case實(shí)現(xiàn),那原理是什么呢?

去掉t1.Reset效果咋樣呢?

?
1
2
3
4
5
6
7
8
t1 := time.NewTimer(time.Second * 10) // ?time.Second * 10 啥意思? *100行嗎?
  for {
    fmt.Println("hihihihi")
    select {
    case <-t1.C:
      fmt.Println("hello")
    }
  }

輸出

START START START START START START START START START START START START START START START
2020/05/01 08:12:21 Starting Cron...
hihihihi
2020/05/01 08:12:22 ********  *******  *******
2020/05/01 08:12:23 ********  *******  *******
2020/05/01 08:12:24 ********  *******  *******
2020/05/01 08:12:25 ********  *******  *******
2020/05/01 08:12:26 ********  *******  *******
2020/05/01 08:12:27 ********  *******  *******
2020/05/01 08:12:28 ********  *******  *******
2020/05/01 08:12:29 ********  *******  *******
2020/05/01 08:12:30 ********  *******  *******
2020/05/01 08:12:31 ********  *******  *******
hello
hihihihi
2020/05/01 08:12:32 ********  *******  *******
2020/05/01 08:12:33 ********  *******  *******
2020/05/01 08:12:34 ********  *******  *******
2020/05/01 08:12:35 ********  *******  *******
2020/05/01 08:12:36 ********  *******  *******

更蒙了,去掉reset, 運(yùn)行完第一個(gè)定時(shí)器10s, 非但沒聽,還直接執(zhí)行起來(lái)了,沒停了

for 循環(huán)里的print不是刷刷的一大片,而是和case命中時(shí)一期打,看來(lái)是時(shí)候了解下select-case的原理了

select case

按慣例先上個(gè)例子

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
package main
 
import (
  "fmt"
  "strings"
)
 
func SelectTest() {
  intChan := make(chan int, 1)
  stringChan := make(chan string, 1)
  intChan <- 123456
  stringChan <- "hello"
 
  select {
  case value := <-intChan:
    fmt.Println(value)
  case value := <- stringChan:
    fmt.Println(value)
  }
}
 
func main() {
  fmt.Println(strings.Repeat("START ", 15))
  SelectTest()
  fmt.Println(strings.Repeat("END ", 15))
}

執(zhí)行多次可以看到,輸出的結(jié)果是 123456、"hello"不定

select 語(yǔ)法

每個(gè)case都必須是個(gè)通信

如果一個(gè)通信可進(jìn)行它就執(zhí)行,其他被忽略

如果有多個(gè)case可執(zhí)行,就會(huì)隨機(jī)的選擇一個(gè)執(zhí)行

如果沒有case可執(zhí)行,如果如果有default,執(zhí)行default語(yǔ)句;否則就阻塞,直到有某個(gè)通信可行

這里還是有很多問題, 單開一節(jié)弄清楚 select語(yǔ)句

再回到一開始的定時(shí)任務(wù)

回顧正題,定時(shí)原理解析

?
1
2
3
4
5
6
7
8
t1 := time.NewTimer(time.Second * 10)
  for {
    select {
    case <-t1.C:
      fmt.Println("Time now:", time.Now().Format("2006-01-02 15:04:05"))
      t1.Reset(time.Second * 10)
    }
  }
  • 生成一個(gè)定時(shí)器t1, 執(zhí)行for循環(huán),一開始定時(shí)時(shí)間(10s)未到, 也沒有阻塞任務(wù),它就阻塞在case中;
  • 定時(shí)時(shí)間到了,則執(zhí)行case中語(yǔ)句;
  • 然后又重新恢復(fù)定時(shí)時(shí)長(zhǎng)
  • 重新走for循環(huán),還是重復(fù)上面的故事

上面代碼中嘗試把case中的t1.Reset去掉,結(jié)果也是定時(shí)任務(wù)不同的執(zhí)行,原因是執(zhí)行case中的語(yǔ)句后,接著執(zhí)行for循環(huán),由于沒有新通信過(guò)來(lái)(case語(yǔ)句永遠(yuǎn)無(wú)法滿足),同時(shí)沒有default語(yǔ)句,所以同樣可以阻塞再次。

相比在case中t1 Reset, t1 Reset更靈活些,因?yàn)榭梢栽倜看沃匦聺M足case時(shí)做一些靈活的操作,比如跳出循環(huán),做一些統(tǒng)計(jì)打印等。

 到此這篇關(guān)于Golang Cron 定時(shí)任務(wù)的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Golang Cron 定時(shí)任務(wù)內(nèi)容請(qǐng)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://www.cnblogs.com/kaituorensheng/p/12812469.html

延伸 · 閱讀

精彩推薦
  • GolangGolang中Bit數(shù)組的實(shí)現(xiàn)方式

    Golang中Bit數(shù)組的實(shí)現(xiàn)方式

    這篇文章主要介紹了Golang中Bit數(shù)組的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧...

    天易獨(dú)尊11682021-06-09
  • Golanggolang 通過(guò)ssh代理連接mysql的操作

    golang 通過(guò)ssh代理連接mysql的操作

    這篇文章主要介紹了golang 通過(guò)ssh代理連接mysql的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧...

    a165861639710342021-03-08
  • Golanggo日志系統(tǒng)logrus顯示文件和行號(hào)的操作

    go日志系統(tǒng)logrus顯示文件和行號(hào)的操作

    這篇文章主要介紹了go日志系統(tǒng)logrus顯示文件和行號(hào)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧...

    SmallQinYan12302021-02-02
  • Golanggo語(yǔ)言制作端口掃描器

    go語(yǔ)言制作端口掃描器

    本文給大家分享的是使用go語(yǔ)言編寫的TCP端口掃描器,可以選擇IP范圍,掃描的端口,以及多線程,有需要的小伙伴可以參考下。 ...

    腳本之家3642020-04-25
  • Golanggolang json.Marshal 特殊html字符被轉(zhuǎn)義的解決方法

    golang json.Marshal 特殊html字符被轉(zhuǎn)義的解決方法

    今天小編就為大家分享一篇golang json.Marshal 特殊html字符被轉(zhuǎn)義的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧 ...

    李浩的life12792020-05-27
  • Golanggolang的httpserver優(yōu)雅重啟方法詳解

    golang的httpserver優(yōu)雅重啟方法詳解

    這篇文章主要給大家介紹了關(guān)于golang的httpserver優(yōu)雅重啟的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,...

    helight2992020-05-14
  • GolangGolang通脈之?dāng)?shù)據(jù)類型詳情

    Golang通脈之?dāng)?shù)據(jù)類型詳情

    這篇文章主要介紹了Golang通脈之?dāng)?shù)據(jù)類型,在編程語(yǔ)言中標(biāo)識(shí)符就是定義的具有某種意義的詞,比如變量名、常量名、函數(shù)名等等,Go語(yǔ)言中標(biāo)識(shí)符允許由...

    4272021-11-24
  • Golanggolang如何使用struct的tag屬性的詳細(xì)介紹

    golang如何使用struct的tag屬性的詳細(xì)介紹

    這篇文章主要介紹了golang如何使用struct的tag屬性的詳細(xì)介紹,從例子說(shuō)起,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看...

    Go語(yǔ)言中文網(wǎng)11352020-05-21
主站蜘蛛池模板: 99爱在线观看 | 亚洲一区二区免费视频 | 午夜久久久 | 成人高清网站 | 亚洲一区二区三区免费视频 | 羞羞av| 久久精品亚洲 | 欧美日韩国产一区二区三区不卡 | 99精品免费 | 精品无码三级在线观看视频 | 午夜大片男女免费观看爽爽爽尤物 | 欧美亚洲天堂 | 久久精品国产99国产 | 免费国产黄色大片 | 99综合在线 | 一级黄色大片 | 君岛美绪一区二区三区 | 国产探花在线精品一区二区 | 成人免费一区二区三区视频软件 | 九九九久久国产免费 | 无码一区二区三区视频 | 91无吗 | 四虎中文字幕 | 成人刺激视频在线 | 精品国产一区二区三区四区 | 国产一级黄片毛片 | 韩日中文字幕 | 亚洲成人在线播放视频 | 亚洲婷婷一区二区三区 | 精品在线一区二区 | 欧美日韩一级视频 | 91精品久久久久久久 | 国产精品美女久久久久久久久久久 | 亚洲国产成人av | 91 久久| 国产美女久久 | 黄网站色大毛片 | 欧美黄色www| 一区二区三区 在线 | 国产精品成人一区二区三区夜夜夜 | 黄视频网站免费观看 |