Goroutine给出了错误

时间:2014-01-30 08:56:21

标签: go goroutine

我试图多次浏览一个网站,但我得到了:

  

panic:运行时错误:内存地址无效或nil指针取消引用

     

[signal 0xb code = 0x1 addr = 0x38 pc = 0x400cca]

package main

import (
    "fmt"
    "net/http"
)

var urls = []string{
    "http://site-centos-64:8080/examples/abc1.jsp",
}

type HttpResponse struct {
    url      string
    response *http.Response
    err      error
}
var ch = make(chan *HttpResponse, 1000) // buffered

func abc(i int){
        for _, url := range urls {
                resp, err := http.Get(url)
                resp.Body.Close()
                ch <- &HttpResponse{url, resp, err}
        }
}
func asyncHttpGets(urls []string) []*HttpResponse {
    responses := []*HttpResponse{}
    for i:=0;i<1000;i++{
        go abc(i)
    }
    for {
        select {
        case r := <-ch:
            responses = append(responses, r)
            if len(responses) == 1000 {
                return responses
            }

        }
    }

    return responses

}

func main() {
    results := asyncHttpGets(urls)
    for _, result := range results {
        fmt.Printf("%s status: %s\n", result.url,
            result.response.Status)
    }
}

当我这样做500次时,工作绝对正常。

1 个答案:

答案 0 :(得分:1)

go stacktrace包含代码的哪一行导致了恐慌。可能有很多goroutines正在运行,但你可以grep你的文件名。 我假设您的服务器存在一些连接问题。

正确处理err功能中的abc应该会告诉您更多信息 如果出现错误,请不要致电resp.Body.Close()。在您的main函数result.response.Status中也不起作用。