[go]基于协程的并发ping(2)
直接按目标ip并发的方式,将ping封装为协程函数
go本身没有提供等待协程join的方法,需要自己实现
/*简单协程版*/ package main import ( "ping" "fmt" "time" //"os" "strconv" ) var fin chan string; //用于实现jionall func pingr(host string,timeout int){ t1:=time.Now().UnixNano() alive,err:=ping.Ping(host,timeout) //alive,err:=true,0 t2:=time.Now().UnixNano() fmt.Println(host,alive,(t2-t1)/1000000,err); fin <- host } var iplist [253]string func main() { fin = make(chan string) //数组赋值 for i := 0; i < len(iplist); i { iplist[i]="192.168.99." strconv.Itoa(i 1) go pingr(iplist[i],1000) } for i := 0; i < len(iplist); i { <-fin //fmt.Println(ip,"joined") } }
版权声明:本文为博主原创文章,未经博主允许不得转载。
到此这篇关于“[go]基于协程的并发ping(2)”的文章就介绍到这了,更多文章或继续浏览下面的相关文章,希望大家以后多多支持JQ教程网!
您可能感兴趣的文章:
[go]基于协程的并发ping(2)
go test 如何输出到控制台_深度剖析 Go 中的 Go 协程 (goroutines) -- Go 的并发
Golang教程:goroutine协程
golang channel的使用以及调度原理
Golang并发:并发协程的优雅退出
探索Golang协程实现——从v1.0开始
mysql driver的bug的深入分析
如何在golang中关闭bufio.reader_golang 并发编程
GO 依赖管理工具go Modules(官方推荐)
Go语言潜力有目共睹,但它的Goroutine机制底层原理你了解吗?