Go 语言官方包函数中文翻译

Go官方包函数中文翻译




import "strings"

  1. func Join(a []string, sep string) string
  1. Join concatenates the elements of a to create a single string. The separator string sep is placed between elements in the resulting string.
  2. 翻译: 根据切片a中的元素生成一个字符串, sep分割字符串被放置在生成的字符串中间.
    例如:
    s := []string{"hah", "nihao", "wode"} fmt.Println(strings.Join(s, ",, ")) fmt.Println(strings.Join(s, "")) 输出: hah,, nihao,, wode hahnihaowode







Go内建函数

  1. func append(s []T, vs …T) []T
  1. append 的第一个参数 s 是一个元素类型为 T 的切片, 其余类型为 T 的值将会追加到该切片的末尾。
  2. append 返回值: 一个包含原切片所有元素加上新添加元素的切片。
  3. 当 s 的底层数组太小,不足以容纳所有给定的值时,它就会分配一个更大的数组。 返回的切片会指向这个新分配的数组。
  1. func make([]T, len, cap) []T
  1. 切片可以使用内置函数 make 创建;
  2. 参数: []T: T 为切片中元素的类型;
    len : 该切片的长度;
    cap : 该切片的容量;
    当参数为 2个时, 第二个参数即为长度,也是容量. 即len == cap
  3. 返回值: 为该数组对应的切片;
  4. 使用内置函数 len 和 cap 获取切片的长度和容量信息。
    例如:
    s := make([]byte, 5) len(s) == 5 cap(s) == 5
  1. func copy(dst, src []T) int
  1. copy 函数将源切片的元素复制到目的切片。 它返回复制元素的数目。
    copy 函数支持不同长度的切片之间的复制(它只复制较短切片的长度个元素), 所以保证 src的容量 <= dst的容量.
    此外, copy 函数可以正确处理源和目的切片有重叠的情况。
    例如:
    func AppendByte(slice []byte, data ...byte) []byte { m := len(slice) n := m + len(data) if n > cap(slice) { // if necessary, reallocate // allocate double what's needed, for future growth. newSlice := make([]byte, (n+1)*2) copy(newSlice, slice) slice = newSlice } slice = slice[0:n] copy(slice[m:n], data) fmt.Println(slice) return slice }
  1. func append(s []T, x ...T) []T
  1. append 函数将 x 追加到切片 s 的末尾,并且在必要的时候增加容量。
  2. 如果是要将一个切片追加到另一个切片尾部,需要使用 ... 语法将第2个参数展开为参数列表。
    例如:
    a := []string{"John", "Paul"} b := []string{"George", "Ringo", "Pete"} a = append(a, b...) // equivalent to "append(a, b[0], b[1], b[2])" // a == []string{"John", "Paul", "George", "Ringo", "Pete"}
  1. Range
  1. for 循环的 range 形式可遍历切片或映射
  2. 当使用 for 循环遍历切片时,每次迭代都会返回两个值。 第一个值为当前元素的下标,第二个值为该下标所对应元素的一份副本.
  3. 可以将下标或值赋予 _ 来忽略它
  4. 若你只需要索引,去掉 , value 的部分即可
    例如:
    func main() { var result = []int{1, 2, 4, 8, 16, 32, 64, 128} for i, v := range result { fmt.Printf("i = %d, value = %d\n", i, v) } for i:= range result { fmt.Printf("i = %d\n", i) } } 输出: i = 0, value = 1 i = 1, value = 2 i = 2, value = 4 i = 3, value = 8 i = 4, value = 16 i = 5, value = 32 i = 6, value = 64 i = 7, value = 128 i = 0 i = 1 i = 2 i = 3 i = 4 i = 5 i = 6 i = 7
  5. 当使用 for 循环遍历 map结构(即映射)时, 返回两个值:第一个值为 key, 第二个值为key对应的value.
    当map结构中无元素时, 该循环不会进入.直接跳过.







import "io/ioutil"

  1. func ReadFile(filename string) ([]byte, error)
  1. ReadFile reads the file named by filename and returns the contents. A successful call returns err == nil, not err == EOF. Because ReadFile reads the whole file, it does not treat an EOF from Read as an error to be reported.
  2. 翻译: 读取filename 文件, 返回出文件文件全部内容. 成功: err == nil; 失败: err == EOF;
    注意: 因为ReadFile() 读取的是整个文件, 所以在正常读取过程中, 文件末尾的EOF并不会当做错误进行报告.







import "net"

  1. func ResolveTCPAddr(net, addr string) (*TCPAddr, error)
  1. ResolveTCPAddr parses addr as a TCP address of the form "host:port" or "[ipv6-host%zone]:port" and resolves a pair of domain name and port name on the network net, which must be "tcp", "tcp4" or "tcp6". A literal address or host name for IPv6 must be enclosed in square brackets, as in "[::1]:80", "[ipv6-host]:http" or "[ipv6-host%zone]:80".
    Resolving a hostname is not recommended because this returns at most one of its IP addresses.
  2. 翻译: 该函数将参数 addr解析为TCP格式的地址块, 并且根据net参数解析一对域名和端口, net必须为: TCP..., 自满地址或主机名为IPV6的解析结果必须包含在括号中. 解析一个主机名不推荐使用该函数,因为它最多返回一个IP地址.
  1. func (c *IPConn) Read(b []byte) (int, error)
  1. Read implements the Conn Read method.
  2. 翻译:该函数实现了从套接字中读取数据, 返回读取的长度和出错信息. 读取的内容拷贝在参数b中. 当该套接字关闭或出错, err被赋值错误信息返回. 接收成功, err为nil.
  1. func (c *TCPConn) LocalAddr() Addr
  1. LocalAddr returns the local network address. The Addr returned is shared by all invocations of LocalAddr, so do not modify it.
  2. 翻译: 该函数返回一个本地的网路地址. 这个调用函数返回的地址被所有调用共享,不要去修改它..
  1. func (c *IPConn) RemoteAddr() Addr
  1. RemoteAddr returns the remote network address. The Addr returned is shared by all invocations of RemoteAddr, so do not modify it.
  2. 翻译: 该函数返回一个 远程的网络地址. 该掉用函数返回的地址 被整台机器共享, 不要去修改它.
  1. func Dial(network, address string) (Conn, error)
  1. Dial connects to the address on the named network.
    Known networks are "tcp", "tcp4" (IPv4-only), "tcp6" (IPv6-only), "udp", "udp4" (IPv4-only), "udp6" (IPv6-only), "ip", "ip4" (IPv4-only), "ip6" (IPv6-only), "unix", "unixgram" and "unixpacket".
    For TCP and UDP networks, addresses have the form host:port. If host is a literal IPv6 address it must be enclosed in square brackets as in "[::1]:80" or "[ipv6-host%zone]:80". The functions JoinHostPort and SplitHostPort manipulate addresses in this form. If the host is empty, as in ":80", the local system is assumed.
  2. 翻译: 该函数依据 network 链接address指向的地址.
    network标志有...
    对于 TCP,UDP标识, address格式为host:port, 如果host为IPV6, 则必须被包含在方括号中. 函数JoinHostPort和SplitHostPort控制host格式. 如果host为空, 默认为本机.
    注意: 1.当network == TCP 时, client链接address地址, 服务器未监听时, 该函数调用会立即报错.因为 TCP协议的server端, 有socket(), bind(), listen(), accept(), 随后才会在链接上的套接字接收信息.
    注意: 2.当network == UDP 时, client链接address地址, 即使服务器未开启, 该函数也会成功.因为 UDP协议的server端, 只有socket(), bind(), 然后即在该套接字端口接收来自客户端的信息






import "runtime"

  1. func Caller(skip int) (pc uintptr, file string, line int, ok bool)
  1. Caller reports file and line number information about function invocations on the calling goroutine's stack. The argument skip is the number of stack frames to ascend, with 0 identifying the caller of Caller. (For historical reasons the meaning of skip differs between Caller and Callers.) The return values report the program counter, file name, and line number within the file of the corresponding call. The boolean ok is false if it was not possible to recover the information.
  2. 翻译:返回调用函数的行号和文件名






import "os"

  1. func Exit(code int)
  1. Exit causes the current program to exit with the given status code. Conventionally, code zero indicates success, non-zero an error. The program terminates immediately; deferred functions are not run.
  2. 翻译: exit函数使当前程序退出,code为退出状态. 同常: 0标识正常退出, 非0 标识错误.. 作用为: 程序立即终止, 并且,并且,注意:defer 关键字中的函数不会被执行.
  1. func






声明:本人学习期间持续翻译中,水平不高,只能这么生硬的翻译。有不对的请指正:yyxyong@163.com

posted on 2017-03-16 16:19  路之遥_其漫漫  阅读(299)  评论(0编辑  收藏  举报

导航