func 的基本構成元素
func (p myType ) funcName ( a, b int , c string ) ( r , s int ) { return }
其中:
關鍵字———func // 這個是定義函數的關鍵字
函數擁有者—(p myType) // 這個是此函數的擁有者,下面解釋(此項可省略)
方法名———funcName // 這個是定義函數的名字
入參———— a,b int,b string // 這個是定義函數的入參
返回值——— r,s int // 這個是定義函數的返回值,golang可以返回多個值
函數體——— { }
重點說說這個函數擁有者(p myType),這個是相較於C/C++比較特殊的地方。
為特定類型定義函數,即為類型對象定義方法
在Go中通過給函數標明所屬類型,來給該類型定義方法,上面的 (p myType) 即表示給myType聲明了一個方法, p myType 不是必須的。如果沒有,則純粹是一個函數。
下面就是為Mssql類型定義了一個Open函數。
func (m *Mssql) Open() (err error) { var conf []string conf = append(conf, "Provider=SQLOLEDB") conf = append(conf, "Data Source="+m.dataSource) if m.windows { // Integrated Security=SSPI 這個表示以當前WINDOWS系統用戶身去登錄SQL SERVER服務器(需要在安裝sqlserver時候設置), // 如果SQL SERVER服務器不支持這種方式登錄時,就會出錯。 conf = append(conf, "integrated security=SSPI") } conf = append(conf, "Initial Catalog="+m.database) conf = append(conf, "user id="+m.sa.user) conf = append(conf, "password="+m.sa.passwd) m.DB, err = sql.Open("adodb", strings.Join(conf, ";")) if err != nil { return err } return nil }
用屬下方式來調用,先實例化一個Mssql類型,再調用Open
db := Mssql{ dataSource: "hddf021.my3w.com", database: "hds1sf21_db", // windwos: true 為windows身份驗證,false 必須設置sa賬號和密碼 windows: false, sa: SA{ user: "hdssdf021", passwd: "", }, } // 連接數據庫 err := db.Open() if err != nil { fmt.Println("sql open:", err) return 0 } defer db.Close()