咖啡伴侶

          呆在上海
          posts - 163, comments - 156, trackbacks - 0, articles - 2

          2013年11月19日

          package main

          import (
              "fmt"
              "time"
          )

          var ch chan int = make(chan int, 1)

          func main() {
              go aaa()

              select {
              case <-ch: //拿到鎖
                  fmt.Println("call")
              case <-time.After(5 * time.Second): //超時5s
                  fmt.Println("5 sec call")
              }
          }

          func aaa() {
              time.Sleep(time.Second * 3)
              ch <- 1
          }

          posted @ 2013-12-24 13:03 oathleo 閱讀(7293) | 評論 (0)編輯 收藏

          conn, err = ln.Accept()
          go handleConnection(conn)
          看到這里我曾經有個疑問,為什么不是  handleConnection(&conn) ?

          下面這個例子解釋這個問題

          package main

          import (
              "fmt"
          )

          type Interface interface {
              say() string
          }

          type Object struct {
          }

          func (this *Object) say() string {
              return "hello"
          }

          func do(i Interface) string {
              return i.say()
          }

          func main() {
              o := Object{}
              fmt.Println(do(&o))
              fmt.Printf("CCCCCCCCCCC:%T", o)
          }

          函數的參數以接口定義,編譯器會自己判斷參數是對象還是對象的指針
          比如,say是指針上的方法,所以do只接受Object的指針做參數,do(o)是編譯不過的

          所以看到庫里接口做參數類型定義的時候,可以簡單認為,這個接口肯定是個對象指針(雖然也可以用對象,單估計沒有哪個類庫會用)

          例如:
          conn, err = ln.Accept()
          go handleConnection(conn)

          這里conn是個接口,不需要 go handleConnection(&conn)

          posted @ 2013-12-22 12:45 oathleo 閱讀(4396) | 評論 (1)編輯 收藏

          package main

          import (
              "fmt"
              "mag/common"
              "time"
          )

          func main() {
              c := make(chan bool, 10)

              tt := common.GetTodayGivenTime("161300")
              dd := common.SinceNow(tt)
              time.AfterFunc(dd, func() { //非阻塞
                  
          //后續每24小時建立目錄
                  ticker24h := time.NewTicker(5 * time.Second)
                  for {
                      select {
                      case <-ticker24h.C:
                          fmt.Println("print")
                      }
                  }
              })

              <-c
          }

          posted @ 2013-12-19 16:15 oathleo 閱讀(5370) | 評論 (0)編輯 收藏

          聲明:
          源slice= src
          添加slice = app
          結果slice=tar
          append時
          len tar === len src +   len app
          1)如果len(src) + len(app) <= cap(src)    cap tar  =   cap(src)
          2)否則 
                a) len(src) + len(app) > 2* cap(src)     cap tar  =   len(src) + len(app)
                b) cap(src) < len(src) + len(app) <= 2* cap(src)    cap tar = 2* cap(src)
              data := make([]int, 10, 20)
              data[0] = 1
              data[1] = 2

              dataappend := make([]int, 12, 30)//修改這個len 
              dataappend[0] = 1
              dataappend[1] = 2

              result := append(data, dataappend)

              result[0] = 99
              result[11] = 98

              fmt.Println("length:", len(data), "cap:", cap(data), ":", data)
              fmt.Println("result length:", len(result), "cap:", cap(result), ":", result)
              fmt.Println("length:", len(dataappend), "cap:", cap(dataappend), ":", dataappend)

          posted @ 2013-11-20 18:48 oathleo 閱讀(5259) | 評論 (1)編輯 收藏

          1.slice1:= slice[0:2]
          引用,非復制,所以任何對slice1或slice的修改都會影響對方
          data := []int{1, 2, 3, 4, 5, 6, 7, 8, 9, 0}
          data1 := data[0:2]
          data1[0] = 99
          fmt.Println(data1)
          fmt.Println(data)
          [99 2]
          [99 2 3 4 5 6 7 8 9 0]
          2.append
          append 比較特殊
          聲明:
          源slice= src
          添加slice = app
          結果slice=tar
          1)如果len(src) + len(app) <= cap(src)  src和tar 是指向同一數據引用 ,即修改src或tar,會影響對方
          2)否則 tar 是copy的方式 src + app ,即修改src或tar,不會影響對方
          無論哪種情況不會影響app,因為app都會用copy的方式進入tar
           
          func test2() {
          data := make([]int, 10, 20)
          data[0] = 1
          data[1] = 2
          dataappend := make([]int, 10, 20)//len <=10 則  result[0] = 99 會 影響源Slice
          dataappend[0] = 1
          dataappend[1] = 2
          result := append(data, dataappend...)
          result[0] = 99
          result[11] = 98
          fmt.Println("length:", len(data), ":", data)
          fmt.Println("length:", len(result), ":", result)
          fmt.Println("length:", len(dataappend), ":", dataappend)
          }

          posted @ 2013-11-20 18:46 oathleo 閱讀(6667) | 評論 (1)編輯 收藏

          index := bytes.IndexByte(buf_PN, 0)
          rbyf_pn := buf_PN[0:index]

          posted @ 2013-11-19 10:16 oathleo 閱讀(9007) | 評論 (0)編輯 收藏

          主站蜘蛛池模板: 常州市| 原平市| 仪陇县| 玛多县| 洞头县| 嵩明县| 女性| 句容市| 襄樊市| 红原县| 瑞丽市| 平罗县| 乐山市| 临颍县| 利津县| 巴彦淖尔市| 平塘县| 海原县| 黄平县| 凌海市| 拉孜县| 平顶山市| 集安市| 秀山| 平舆县| 杂多县| 太和县| 增城市| 扎鲁特旗| 十堰市| 沙田区| 罗源县| 临高县| 鄯善县| 元朗区| 依安县| 丰都县| 贡嘎县| 镇远县| 铜梁县| 嘉鱼县|