教程集 www.jiaochengji.com
教程集 >  Golang编程  >  golang教程  >  正文 [go]基于协程的并发ping(2)

[go]基于协程的并发ping(2)

发布时间:2021-05-08   编辑:jiaochengji.com
教程集为您提供[go]基于协程的并发ping(2)等资源,欢迎您收藏本站,我们将为您提供最新的[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机制底层原理你了解吗?

[关闭]
~ ~