我正在构建一个代码如下的简单路由器。
我有一个回调,它将Res类型作为参数。最初我的印象是type Res http.ResponseWriter
只是意味着Res是http.ResponseWriter的别名,因为将http.ResponseWriter传递给回调并且Res param运行正常。
我后来决定将自己的功能包含在提供给回调的响应中,因此将type Res http.ResponseWriter
更改为type Res response.Response
- 响应是我自己的包(请查看注释掉的内容)在下面的源中)。在这样做后,我得到“不能使用newResponse(类型response.Response)作为urlCallback参数中的类型Res”
我查看了http.ResponseWriter源代码并注意到它是一个接口,而我的response.Response是一个结构,这是问题所在吗?
将类型设置为其他类型不一定是别名吗?如果没有,那么为什么最初在http.ResponseWriter中传递Res类型的工作呢?
package Router
import (
"fmt"
"net/http"
"net/url"
"log"
// "./response"
)
// type Res response.Response
type Res http.ResponseWriter
type Req *http.Request
type RouteMap map[string]func(Res, Req)
type MethodMap map[string]RouteMap
type Router struct {
Methods MethodMap
}
func (router *Router) Get(urlString string, callback func(Res, Req)) {
parsedUrl, err := url.Parse(urlString)
if(err != nil) {
panic(err)
}
router.Methods["GET"][parsedUrl.Path] = callback
}
func (router *Router) initMaps() {
router.Methods = MethodMap{}
router.Methods["GET"] = RouteMap{}
}
func (router Router) determineHandler(w http.ResponseWriter, r *http.Request) {
methodMap := router.Methods[r.Method]
urlCallback := methodMap[r.URL.Path]
// newResponse := response.NewResponse(w)
if(urlCallback != nil) {
// urlCallback(newResponse, r)
urlCallback(w, r)
}
}
func (router Router) Serve(host string, port string) {
fullHost := host + ":" + port
fmt.Println("Router is now serving to:" + fullHost)
http.HandleFunc("/", router.determineHandler)
err := http.ListenAndServe(fullHost, nil)
if err == nil {
fmt.Println("Router is now serving to:" + fullHost)
} else {
fmt.Println("An error occurred")
log.Fatal(err)
}
}
注释掉的代码描述了我正在尝试做什么的问题
答案 0 :(得分:2)
否则
type Res response.Response
您定义的新类型与原始
不可互换转换你应该做
newResponse := Res(response.NewResponse(w))
当你做
时type Res http.ResponseWriter
你的类型Res是一个接口,http.ResponseWriter实现它,因此可以在func中用作arg,其中Res想要