golang的func的一些笔记

毛毛v5 · · 1324 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

先看一看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()

如上代码,实例化一个 Mssql 类型变量db ,就可以调用db.Open来执行这个Mssql类型专属函数。


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:毛毛v5

查看原文:golang的func的一些笔记

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1324 次点击  
加入收藏 微博
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传