您现在的位置是:亿华云 > IT科技类资讯
Go编程语言的简单介绍
亿华云2025-10-03 02:22:24【IT科技类资讯】8人已围观
简介以下内容是我的硕士论文的摘录,几乎是整个 2.1 章节,向具有 CS 背景的人快速介绍 Go)Go 是一门用于并发编程的命令式编程语言,它主要由创造者 Google 进行开发,最初主要由 Robert
(以下内容是编程我的硕士论文的摘录,几乎是简单介整个 2.1 章节,向具有 CS 背景的编程人快速介绍 Go)
Go 是一门用于并发编程的命令式编程语言,它主要由创造者 Google 进行开发,简单介最初主要由 Robert Griesemer、编程Rob Pike 和 Ken Thompson 开发。简单介这门语言的编程设计起始于 2007 年,并在 2009 年推出最初版本;而***个稳定版本是简单介 2012 年发布的 1.0 版本。1
Go 有 C 风格的编程语法(没有预处理器)、垃圾回收机制,简单介而且类似它在贝尔实验室里被开发出来的编程前辈们:Newsqueak(Rob Pike)、Alef(Phil Winterbottom)和 Inferno(Pike、简单介Ritchie 等人),编程使用所谓的简单介 Go 协程goroutines和信道channels(一种基于 Hoare 的“通信顺序进程”理论的协程)提供内建的并发支持。2
Go 程序以包的编程形式组织。包本质是一个包含 Go 文件的高防服务器文件夹。包内的所有文件共享相同的命名空间,而包内的符号有两种可见性:以大写字母开头的符号对于其他包是可见,而其他符号则是该包私有的:
func PublicFunction() { fmt.Println("Hello world")}func privateFunction() { fmt.Println("Hello package")}类型
Go 有一个相当简单的类型系统:没有子类型(但有类型转换),没有泛型,没有多态函数,只有一些基本的类型:
基本类型:int、int64、int8、uint、float32、float64 等 struct interface:一组方法的集合 map[K, V]:一个从键类型到值类型的映射 [number]Type:一些 Type 类型的元素组成的数组 []Type:某种类型的切片(具有长度和功能的数组的指针) chan Type:一个线程安全的队列 指针 *T 指向其他类型 函数具名类型:可能具有关联方法的其他类型的别名(LCTT 译注:这里的别名并非指 Go 1.9 中的新特性“类型别名”):
type T struct { foo int } type T *T type T OtherNamedType具名类型完全不同于它们的服务器租用底层类型,所以你不能让它们互相赋值,但一些操作符,例如 +,能够处理同一底层数值类型的具名类型对象们(所以你可以在上面的示例中把两个 T 加起来)。
映射、切片和信道是类似于引用的类型——它们实际上是包含指针的结构。包括数组(具有固定长度并可被拷贝)在内的其他类型则是值传递(拷贝)。
类型转换类型转换类似于 C 或其他语言中的类型转换。它们写成这样子:
TypeName(value) 常量Go 有“无类型”字面量和常量。
1 // 无类型整数字面量const foo = 1 // 无类型整数常量const foo int = 1 // int 类型常量无类型值可以分为以下几类:UntypedBool、UntypedInt、UntypedRune、UntypedFloat、UntypedComplex、UntypedString 以及 UntypedNil(Go 称它们为基础类型,其他基础种类可用于具体类型,如 uint8)。一个无类型值可以赋值给一个从基础类型中派生的具名类型;例如:
type someType intconst untyped = 2 // UntypedIntconst bar someType = untyped // OK: untyped 可以被赋值给 someTypeconst typed int = 2 // intconst bar2 someType = typed // error: int 不能被赋值给 someType接口和对象
正如上面所说的,接口是一组方法的集合。香港云服务器Go 本身不是一种面向对象的语言,但它支持将方法关联到具名类型上:当声明一个函数时,可以提供一个接收者。接收者是函数的一个额外参数,可以在函数之前传递并参与函数查找,就像这样:
type SomeType struct { ... }type SomeType struct { ... }func (s *SomeType) MyMethod() { }func main() { var s SomeType s.MyMethod()}如果对象实现了所有方法,那么它就实现了接口;例如,*SomeType(注意指针)实现了下面的接口 MyMethoder,因此 *SomeType 类型的值就能作为 MyMethoder 类型的值使用。最基本的接口类型是 interface{ },它是一个带空方法集的接口 —— 任何对象都满足该接口。
type MyMethoder interface { MyMethod()}合法的接收者类型是有些限制的;例如,具名类型可以是指针类型(例如,type MyIntPointer *int),但这种类型不是合法的接收者类型。
控制流
Go 提供了三个主要的控制了语句:if、switch 和 for。这些语句同其他 C 风格语言内的语句非常类似,但有一些不同:
条件语句没有括号,所以条件语句是 if a == b { } 而不是 if (a == b) { }。大括号是必须的。 所有的语句都可以有初始化,比如这个 if result, err := someFunction(); err == nil { // use result } switch 语句在分支里可以使用任何表达式 switch 语句可以处理空的表达式(等于 true) 默认情况下,Go 不会从一个分支进入下一个分支(不需要 break 语句),在程序块的末尾使用 fallthrough 则会进入下一个分支。 循环语句 for 不仅能循环值域:for key, val := range map { do something }Go 协程
关键词 go 会产生一个新的 Go 协程goroutine,这是一个可以并行执行的函数。它可以用于任何函数调用,甚至一个匿名函数:
func main() { ... go func() { ... }() go some_function(some_argument)}信道
Go 协程通常和信道channels结合,用来提供一种通信顺序进程的扩展。信道是一个并发安全的队列,而且可以选择是否缓冲数据:
var unbuffered = make(chan int) // 直到数据被读取时完成数据块发送var buffered = make(chan int, 5) // 最多有 5 个未读取的数据块运算符 <- 用于和单个信道进行通信。
valueReadFromChannel := <- channelotherChannel <- valueToSend语句 select 允许多个信道进行通信:
select { case incoming := <- inboundChannel: // 一条新消息 case outgoingChannel <- outgoing: // 可以发送消息}defer 声明
Go 提供语句 defer 允许函数退出时调用执行预定的函数。它可以用于进行资源释放操作,例如:
func myFunc(someFile io.ReadCloser) { defer someFile.close() /* 文件相关操作 */}当然,它允许使用匿名函数作为被调函数,而且编写被调函数时可以像平常一样使用任何变量。
错误处理
Go 没有提供异常类或者结构化的错误处理。然而,它通过第二个及后续的返回值来返回错误从而处理错误:
func Read(p []byte) (n int, err error)// 内建类型:type error interface { Error() string}必须在代码中检查错误或者赋值给 _:
n0, _ := Read(Buffer) // 忽略错误n, err := Read(buffer)if err != nil { return err}有两个函数可以快速跳出和恢复调用栈:panic() 和 recover()。当 panic() 被调用时,调用栈开始弹出,同时每个 defer 函数都会正常运行。当一个 defer 函数调用 recover()时,调用栈停止弹出,同时返回函数 panic() 给出的值。如果我们让调用栈正常弹出而不是由于调用 panic() 函数,recover() 将只返回 nil。在下面的例子中,defer 函数将捕获 panic() 抛出的任何 error 类型的值并储存在错误返回值中。第三方库中有时会使用这个方法增强递归代码的可读性,如解析器,同时保持公有函数仍使用普通错误返回值。
func Function() (err error) { defer func() { s := recover() switch s := s.(type) { // type switch case error: err = s // s has type error now default: panic(s) } }}数组和切片
正如前边说的,数组是值类型,而切片是指向数组的指针。切片可以由现有的数组切片产生,也可以使用 make() 创建切片,这会创建一个匿名数组以保存元素。
slice1 := make([]int, 2, 5) // 分配 5 个元素,其中 2 个初始化为0slice2 := array[:] // 整个数组的切片slice3 := array[1:] // 除了首元素的切片除了上述例子,还有更多可行的切片运算组合,但需要明了直观。
使用 append() 函数,切片可以作为一个变长数组使用。
slice = append(slice, value1, value2)slice = append(slice, arrayOrSlice...)切片也可以用于函数的变长参数。
映射
映射maps是简单的键值对储存容器,并支持索引和分配。但它们不是线程安全的。
someValue := someMap[someKey]someValue, ok := someMap[someKey] // 如果键值不在 someMap 中,变量 ok 会赋值为 `false`someMap[someKey] = someValue很赞哦!(1)
上一篇: 回顾数据中心架构的演进
下一篇: 数据中心和热泵:一个成功的组合
相关文章
- 如何设计、建造和运营更环保的数据中心
- 最后提醒我们,域名到期后要及时更新域名,否则可能会丢掉域名,每次抢先注册都不会成功。
- ④注册门槛低
- 为了避免将来给我们的个人站长带来的麻烦,在选择域名后缀时,我们的站长最好省略不稳定的后缀域名,比如n,因为我们不知道策略什么时候会改变,更不用说我们将来是否还能控制这个域名了。因此,如果站长不是企业,或者有选择的话,如果不能选择域名的cn类,最好不要选择它。
- 昇腾AI异构计算架构CANN 6.0全新开放升级,全面释放AI生产力
- 6、提示添加成功,点击确认进行最后的确定操作。一般10分钟就解析生效,可以用域名进行访问了。
- 审核通过的域名将显示在域名竞拍页面,并进入正式拍卖期,买家可以在拍卖周期内出价,加价幅度与拍卖保证金说明,点此查看。
- 其次,一般域名注册有一个获取密码的按钮,域名注册商点击后会向您发送密码。在得到域名注册商发送的密码后,将其传输到域名服务提供商网站,然后输入密码,此时域名呈现申请状态。提交申请后,原注册人通常会向您发送一封电子邮件,询问您是否同意转让。此时,您只需点击同意转移按钮,域名注册商就可以成功转移。
- 亚马逊推出新 AI 量子芯片 Trainium2 及 Graviton4 处理器,以应对微软竞争
- 4、企业无形资产:通用网站已成为企业网络知识产权的重要组成部分,属于企业的无形资产,也有助于提升企业的品牌形象和技术领先形象。它是企业品牌资产不可或缺的一部分。
热门文章
站长推荐
【昇思生态城市行】南京站圆满举办, 昇腾携手伙伴见证多项重磅发布!
前面这两个步骤都是在本机完成的。到这里还没有涉及真正的域名解析服务器,如果在本机中仍然无法完成域名的解析,就会真正请求域名服务器来解析这个域名了。
互联网其实拼的也是人脉,域名投资也是一个时效性很强的东西,一个不起眼的消息就会引起整个域名投资市场的动荡,因此拓宽自己的人脉圈,完善自己的信息获取渠道,让自己能够掌握更为多样化的信息,这样才更有助于自己的域名投资。
公司和个人选域名方法一样吗?有什么不同?
以“新”促“高”,以“数”强“实”,戴尔科技双驱升级致胜未来
四、一定要仔细阅读细节
其次,一般域名注册有一个获取密码的按钮,域名注册商点击后会向您发送密码。在得到域名注册商发送的密码后,将其传输到域名服务提供商网站,然后输入密码,此时域名呈现申请状态。提交申请后,原注册人通常会向您发送一封电子邮件,询问您是否同意转让。此时,您只需点击同意转移按钮,域名注册商就可以成功转移。
如果你的潜在终端必须是这个米(域名),那么潜在终端并不多,也没有硬通货,那么你的域名应该在终端有兴趣购买时出售。否则,你可能得自己留着吃。