本文实例讲述了Go语言排序与接口用法。分享给大家供大家参考。具体如下:
import "fmt" type Sorter interface { Len() int Less(i, j int) bool Swap(i, j int) } type Xi []int type Xs []string func (p Xi) Len() int { return len(p) } func (p Xi) Less(i int, j int) bool { return p[j] < p[i] } func (p Xi) Swap(i int, j int) { p[i], p[j] = p[j], p[i] } func (p Xs) Len() int { return len(p) } func (p Xs) Less(i int, j int) bool { return p[j] < p[i] } func (p Xs) Swap(i int, j int) { p[i], p[j] = p[j], p[i] } func Sort(x Sorter) { for i := 0; i < x.Len() - 1; i++ { for j := i + 1; j < x.Len(); j++ { if x.Less(i, j) { x.Swap(i, j) } } } } func main() { ints := Xi{44, 67, 3, 17, 89, 10, 73, 9, 14, 8} strings := Xs{"nut", "ape", "elephant", "zoo", "go"} Sort(ints) fmt.Printf("%v\n", ints) Sort(strings) fmt.Printf("%v\n", strings) }
希望本文所述对大家的Go语言程序设计有所帮助。
本文向大家介绍Go语言接口用法实例,包括了Go语言接口用法实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Go语言接口用法。分享给大家供大家参考。具体分析如下: 接口类型是由一组方法定义的集合。 接口类型的值可以存放实现这些方法的任何值。 希望本文所述对大家的Go语言程序设计有所帮助。
本文向大家介绍go语言睡眠排序算法实例分析,包括了go语言睡眠排序算法实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了go语言睡眠排序算法。分享给大家供大家参考。具体分析如下: 睡眠排序算法是一个天才程序员发明的,想法很简单,就是针对数组里的不同的数开多个线程,每个线程根据数的大小睡眠,自然睡的时间越长的,数越大,哈哈,搞笑吧,这种算法看起来很荒唐,但实际上很天才,它可以充分利用多
Go 语言提供了另外一种数据类型即接口,它把所有的具有共性的方法定义在一起,任何其他类型只要实现了这些方法就是实现了这个接口。 实例 /* 定义接口 */ type interface_name interface { method_name1 [return_type] method_name2 [return_type] method_name3 [return_type]
主要内容:使用sort.Interface接口进行排序,常见类型的便捷排序,对结构体数据进行排序排序操作和字符串格式化一样是很多程序经常使用的操作。尽管一个最短的快排程序只要 15 行就可以搞定,但是一个健壮的实现需要更多的代码,并且我们不希望每次我们需要的时候都重写或者拷贝这些代码。 幸运的是,sort 包内置的提供了根据一些排序函数来对任何序列排序的功能。它的设计非常独到。在很多语言中,排序算法都是和序列数据类型关联,同时排序函数和具体类型元素关联。 相比之下,Go语言的 sort.So
主要内容:error 基本用法,自定义错误类型错误处理在每个编程语言中都是一项重要内容,通常开发中遇到的分为异常与错误两种,Go语言中也不例外。本节我们主要来学习一下Go语言中的错误处理。 在C语言中通过返回 -1 或者 NULL 之类的信息来表示错误,但是对于使用者来说,如果不查看相应的 API 说明文档,根本搞不清楚这个返回值究竟代表什么意思,比如返回 0 是成功还是失败? 针对这样的情况,Go语言中引入 error 接口类型作为错误处理
本文向大家介绍go语言简单网络程序实例分析,包括了go语言简单网络程序实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例分析了go语言简单网络程序。分享给大家供大家参考。具体分析如下: 服务端代码如下: 客户端代码如下: 希望本文所述对大家的Go语言程序设计有所帮助。