Compare commits

...

4 Commits

Author SHA1 Message Date
a8496afb35 add: 锁的使用 2022-02-13 14:13:10 +08:00
ea348b07a6 add: 模仿gin框架 2022-02-13 11:46:56 +08:00
6633420cf6 add: 模仿gin框架 2022-02-13 11:34:46 +08:00
xiaowei
500c147acb add: web基本知识 2022-02-13 10:34:46 +08:00
10 changed files with 361 additions and 0 deletions

View File

@@ -0,0 +1,34 @@
package main
import (
"fmt"
"sync"
"time"
)
type Sth struct {
x int64
wg sync.WaitGroup
lock sync.Mutex
}
func (s *Sth) add() {
for i := 0; i < 10000; i++ {
s.lock.Lock()
s.x++
s.lock.Unlock()
}
s.wg.Done()
}
func main() {
var s Sth
s.wg.Add(2)
go s.add()
go s.add()
s.wg.Wait()
fmt.Println(s)
time.Sleep(time.Second)
fmt.Println("xiaowei zhaodandan")
}

View File

@@ -0,0 +1,47 @@
package main
import (
"fmt"
"sync"
"time"
)
var (
x int64
wg sync.WaitGroup
rwlock sync.RWMutex
lock sync.Mutex
)
func main() {
start := time.Now()
for i := 0; i < 10; i++ {
wg.Add(1)
go write()
}
for i := 0; i < 100; i++ {
wg.Add(1)
go read()
}
wg.Wait()
fmt.Println("cost:", time.Since(start))
}
func read() {
//lock.Lock()
rwlock.RLock()
time.Sleep(time.Millisecond)
//lock.Unlock()
rwlock.RUnlock()
wg.Done()
}
func write() {
rwlock.Lock()
//lock.Lock()
x = x + 1
time.Sleep(10 * time.Millisecond)
//lock.Unlock()
rwlock.Unlock()
wg.Done()
}

View File

@@ -0,0 +1,26 @@
package main
import (
"fmt"
"net/http"
)
func main() {
// 路由1
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
fmt.Fprint(w, "hello basic web!")
})
// 路由2
http.HandleFunc("/xiaowei", func(w http.ResponseWriter, r *http.Request) {
headers := r.Header
for k, v := range headers {
fmt.Fprintf(w, "[%v]-[%v]\n", k, v)
}
})
// 启动一个httpserver
if err := http.ListenAndServe(":9000", nil); err != nil {
panic(err)
}
}

View File

@@ -0,0 +1,67 @@
package gee
import (
"encoding/json"
"fmt"
"net/http"
)
type H map[string]interface{}
type Context struct {
Writer http.ResponseWriter
Req *http.Request
Path string
Method string
StatusCode int
}
func newContext(w http.ResponseWriter, r *http.Request) *Context {
return &Context{
Writer: w,
Req: r,
Path: r.URL.Path,
Method: r.Method,
}
}
func (c *Context) PostForm(key string) string {
return c.Req.FormValue(key)
}
func (c *Context) Query(key string) string {
return c.Req.URL.Query().Get(key)
}
func (c *Context) Status(code int) {
c.StatusCode = code
c.Writer.WriteHeader(code)
}
func (c *Context) SetHeader(key string, value string) {
c.Writer.Header().Set(key, value)
}
func (c *Context) String(code int, format string, values ...interface{}) {
c.SetHeader("Content-Type", "text/plain")
c.Status(code)
_, _ = c.Writer.Write([]byte(fmt.Sprintf(format, values...)))
}
func (c *Context) JSON(code int, obj interface{}) {
c.SetHeader("Content-Type", "application/json")
c.Status(code)
encoder := json.NewEncoder(c.Writer)
if err := encoder.Encode(obj); err != nil {
http.Error(c.Writer, err.Error(), 500)
}
}
func (c *Context) Data(code int, data []byte) {
c.Status(code)
_, _ = c.Writer.Write(data)
}
func (c *Context) HTML(code int, html string) {
c.SetHeader("Content-Type", "text/html")
c.Status(code)
_, _ = c.Writer.Write([]byte(html))
}

View File

@@ -0,0 +1,38 @@
package gee
import (
"net/http"
)
type HandlerFunc func(*Context)
type Engine struct {
router *router
}
func New() *Engine {
return &Engine{
router: newRouter(),
}
}
func (e *Engine) addRoute(method string, pattern string, handler HandlerFunc) {
e.router.addRoute(method, pattern, handler)
}
func (e *Engine) GET(pattern string, handler HandlerFunc) {
e.addRoute("GET", pattern, handler)
}
func (e *Engine) POST(pattern string, handler HandlerFunc) {
e.addRoute("POST", pattern, handler)
}
func (e *Engine) Run(addr string) error {
return http.ListenAndServe(addr, e)
}
func (e *Engine) ServeHTTP(writer http.ResponseWriter, request *http.Request) {
context := newContext(writer, request)
e.router.handle(context)
}

View File

@@ -0,0 +1,29 @@
package gee
import (
"log"
"net/http"
)
type router struct {
handlers map[string]HandlerFunc
}
func newRouter() *router {
return &router{handlers: make(map[string]HandlerFunc)}
}
func (r *router) addRoute(method string, pattern string, handler HandlerFunc) {
log.Printf("[Route ] %4s - %s", method, pattern)
key := method + "-" + pattern
r.handlers[key] = handler
}
func (r *router) handle(c *Context) {
key := c.Method + "-" + c.Path
if handler, ok := r.handlers[key]; ok {
handler(c)
} else {
c.String(http.StatusNotFound, "404 not found:%s\n", c.Path)
}
}

View File

@@ -0,0 +1,26 @@
package main
import (
"golanglearn/web/framework/framework-context/gee"
)
func main() {
engine := gee.New()
engine.GET("/", func(c *gee.Context) {
c.HTML(200, "<h1>hello</h1>")
})
engine.GET("/hello", func(c *gee.Context) {
c.String(200, "hello,%v", c.Query("name"))
})
engine.POST("/login", func(c *gee.Context) {
//c.JSON(200, gee.H{
// "username": "xxxx",
// "password": "1234",
//})
c.JSON(200, gee.H{
"username": c.PostForm("username"),
"password": c.PostForm("password"),
})
})
_ = engine.Run(":9000")
}

View File

@@ -0,0 +1,46 @@
package gee
import (
"fmt"
"log"
"net/http"
)
type HandlerFunc func(w http.ResponseWriter, r *http.Request)
type Engine struct {
router map[string]HandlerFunc
}
func New() *Engine {
return &Engine{
router: make(map[string]HandlerFunc),
}
}
func (e *Engine) addRoute(method string, pattern string, handler HandlerFunc) {
key := method + "-" + pattern
e.router[key] = handler
log.Println(e.router)
}
func (e *Engine) GET(pattern string, handler HandlerFunc) {
e.addRoute("GET", pattern, handler)
}
func (e *Engine) POST(pattern string, handler HandlerFunc) {
e.addRoute("POST", pattern, handler)
}
func (e *Engine) Run(addr string) error {
return http.ListenAndServe(addr, e)
}
func (e *Engine) ServeHTTP(writer http.ResponseWriter, request *http.Request) {
key := request.Method + "-" + request.URL.Path
if handler, ok := e.router[key]; ok {
handler(writer, request)
} else {
_, _ = fmt.Fprintf(writer, "404 not found:%v\n", request.URL)
}
}

View File

@@ -0,0 +1,19 @@
package main
import (
"fmt"
"golanglearn/web/framework/framework/gee"
"net/http"
)
func main() {
engine := gee.New()
engine.GET("/", func(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "hello web frame work")
})
engine.GET("/hello", func(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "hello web frame work")
})
engine.Run(":9000")
}

View File

@@ -0,0 +1,29 @@
package main
import (
"fmt"
"net/http"
)
// Engine 定义一个结构体
type Engine struct {
}
// 实现Handler的ServerHTTP方法
func (e *Engine) ServeHTTP(w http.ResponseWriter, r *http.Request) {
switch r.URL.Path {
case "/":
fmt.Fprint(w, "hello handler-basic")
case "/web":
for k, v := range r.Header {
fmt.Fprintln(w, k, "-->", v)
}
}
}
func main() {
engine := new(Engine)
if err := http.ListenAndServe(":9000", engine); err != nil {
panic(err)
}
}