GO1.6语言学习笔记1-基础篇

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

一、GO语言优势
 
  1. 可直接编译成机器码,Go编译生成的是一个静态可执行文件,除了glibc外没有其他外部依赖
  2. 静态类型语言,但是有动态语言的感觉
  3. 语言层面支持并发。Goroutine和channel使得编写高并发的服务端软件变得相当容易,很多情况下完全不需要考虑锁机制以及由此带来的各种问题。单个Go应用也能有效的利用多个CPU核,并行执行的性能好
  4. 内置runtime,支持垃圾回收
  5. 跨平台编译
  6. 内嵌C支持
  7. 简单易学,Go关键字是25个,但是表达能力很强大,几乎支持大多数你在其他语言见过的特性:继承、重载、对象等
  8. 保留但大幅度简化指针
  9. 多参数返回
  10. Array,slice,map等内置基本数据结构
  11. Interface 任何数据结构,只要实现了interface所定义的函数,自动就implement了这个interface
 
二、GO语言能胜任什么工作?
 
  1. 服务器编程,例如处理日志、数据打包、虚拟机处理、文件系统等
  2. 分布式系统,数据库代理器等
  3. 网络编程,包括Web应用、API应用、下载应用
  4. 内存数据库
  5. 云平台
 
三、GO语言缺陷
 
  1. Go的import包不支持版本,有时候升级容易导致项目不可运行
  2. Go的goroutine一旦启动之后,不同的goroutine之间切换不是受程序控制,runtime调度的时候,需要严谨的逻辑
  3. GC延迟大
 
四、成功案例
 
  1. Docker
 
五、深入了解GO的并发语法糖
 
     关于GO的并发语法糖,主要涉及大并发(massive concurrency)、竞争条件(race condition)、错误处理(error handling)这三个问题。
  1. 在大并发方面,Go解决得很好,本质就是user-space thread。
  2. Go启用Chan通道基本思路是保证每个逻辑流都使用独立的内存空间,限定一些受到约束的方法进行沟通。但出于效率的考量(传递消息需要复制操作),没有做任何强制性的保证,依然可以轻松地对共享内存进行访问。程序的正确性只依赖于程序员正确使用并严格遵守slogan。
  3. Go中对于创建的协程缺乏定位能力(no identity),协程之间也并不是完全独立的(no process isolation)。当系统异常发生(比如除零),往往会当掉整个程序,而不能进行状态回退与恢复操作。

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

本文来自:博客园

感谢作者:andrew-xie

查看原文:GO1.6语言学习笔记1-基础篇

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

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