package mainimport ( "fmt" "net/http")type foo intfunc (m foo) Servehttp(w http.ResponseWriter,r *http.Request) { fmt.Fprintln(w,"Some text")}func main() { var bar foo http.ListenAndServe(":8080",bar)}
根据我的理解,添加Servehttp(w http.ResponseWriter,r * http.Request)作为函数方法,调用处理程序接口(如果我说的正确),现在foo也是类型处理程序.我也明白http.ListenAndServe接受类型处理程序的输入,这是我的变量栏发挥作用的地方.当我运行代码并在浏览器上转到localhost:8080时,我会看到“Some Text”.
编辑:实现接口是正确的术语NOT调用.
题:
这究竟如何运作?如何访问Servehttp功能?
我尝试查看库的源代码,但无法准确确定Servehttp的工作原理.我找到了这两段代码(不确定这是否适用),这让我觉得它正在实现一个功能,但需要澄清:
// The HandlerFunc type is an adapter to allow the use of// ordinary functions as http handlers. If f is a function// with the appropriate signature,HandlerFunc(f) is a// Handler that calls f.type HandlerFunc func(ResponseWriter,*Request)// Servehttp calls f(w,r).func (f HandlerFunc) Servehttp(w ResponseWriter,r *Request) { f(w,r)}
我从未见过类型声明,因为HandlerFunc在类型名称后面有一个函数.我还看到了如何声明方法,但不确定上面的代码中发生了什么.
解决方法 这究竟如何运作?如何访问Servehttp功能?要回答这个问题,我们需要了解http.ListenAndServe的工作原理:
func ListenAndServe(addr string,handler Handler) error { server := &Server{Addr: addr,Handler: handler} return server.ListenAndServe()}
在这里,我们创建一个具有给定地址和处理程序的服务器,并调用ListenAndServer方法,让我们来看看:
func (srv *Server) ListenAndServe() error { addr := srv.Addr if addr == "" { addr = ":http" } ln,err := net.Listen("tcp",addr) if err != nil { return err } return srv.Serve(tcpKeepAliveListener{ln.(*net.TCPListener)})}
这个方法只是开始监听给定的地址,并用我们新创建的监听器调用Server方法,所以让我们按照那里的路径:
func (srv *Server) Serve(l net.Listener) error { defer l.Close() ... for { rw,e := l.Accept() ... c := srv.newConn(rw) c.setState(c.rwc,StateNew) // before Serve can return go c.serve(ctx) }}
从Serve方法我们可以看出,这是我们接受新连接并开始在它自己的goroutine中处理它的点.
// Serve a new connection.func (c *conn) serve(ctx context.Context) { ... for { w,err := c.readRequest(ctx) ... serverHandler{c.server}.Servehttp(w,w.req) ... }}
在这里,我们最终调用了Servehttp方法,但正如我们所看到的,这还不是我们对该函数的实现,而是来自标准库的内容,所以让我们来看看serverHandler结构包含的内容:
// serverHandler delegates to either the server's Handler or// DefaultServeMux and also handles "OPTIONS *" requests.type serverHandler struct { srv *Server}func (sh serverHandler) Servehttp(rw ResponseWriter,req *Request) { handler := sh.srv.Handler if handler == nil { handler = DefaultServeMux } if req.RequestURI == "*" && req.Method == "OPTIONS" { handler = globalOptionsHandler{} } handler.Servehttp(rw,req)}
所以这里终于来了.如果我们没有提供任何Handler,将使用DefaultServeMux但是因为我们提供了来自foo get的foo处理程序Servehttp.
就是这样.所有这一切都可以在server.go找到
总结以上是内存溢出为你收集整理的go – ServeHTTP如何运作?全部内容,希望文章能够帮你解决go – ServeHTTP如何运作?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)