并发的使用http.get获取内容,并打印出时间与内容

5年以前  |  阅读数:391 次  |  编程语言:Golang 

Fetchall fetches URLs in parallel and reports their times and sizes.

package main

import (
    "fmt"
    "io"
    "io/ioutil"
    "net/http"
    "os"
    "time"
)

func main() {
    start := time.Now()
    ch := make(chan string)
    for _, url := range os.Args[1:] {
        go fetch(url, ch) // start a goroutine
    }
    for range os.Args[1:] {
        fmt.Println(<-ch) // receive from channel ch
    }
    fmt.Printf("%.2fs elapsed\n", time.Since(start).Seconds())
}

func fetch(url string, ch chan<- string) {
    start := time.Now()
    resp, err := http.Get(url)
    if err != nil {
        ch <- fmt.Sprint(err) // send to channel ch
        return
    }

    nbytes, err := io.Copy(ioutil.Discard, resp.Body)
    resp.Body.Close() // don't leak resources
    if err != nil {
        ch <- fmt.Sprintf("while reading %s: %v", url, err)
        return
    }
    secs := time.Since(start).Seconds()
    ch <- fmt.Sprintf("%.2fs  %7d  %s", secs, nbytes, url)
}
 相关文章:
处理摄氏与华氏温度转换
Golang官方的HelloWorld
使用包tempconv进行摄氏与华氏温度的转换
并发的使用http.get获取内容,并打印出时间与内容
使用flag包打印命令行
最小HTTP服务器
使用strings包方法,计算文件名
统计并打印输入的内容
使用Golang进行HTTP的GET与POST请求
读取通过命令行传入的文件,打印多次出现的行
字符串运算示例之输出文件名
HTTP服务器,返回请求参数及HTTP头部
打印所有的命令行参数
从文件或标准输入中读取内容,统计并打印出现多次的行
HTTP服务器,通过URL接口输出请求次数
使用http.Get获取URL的内容并打印
格式化输出,打印水的温度
使用strings.Join打印所有的命令行参数