zoukankan      html  css  js  c++  java
  • GO1.6语言学习笔记1-基础篇

    一、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)。当系统异常发生(比如除零),往往会当掉整个程序,而不能进行状态回退与恢复操作。
  • 相关阅读:
    MySQL读写分离
    Error:(1, 1) java: 非法字符: ‘ufeff’
    Java 集合系列(四)—— ListIterator 源码分析
    Java 集合系列(三)—— LinkedList
    Java 集合系列(二)—— ArrayList
    Java 集合系列(一)
    Docker之进入容器(三)
    Docker之常用命令(二)
    Docker之初识(一)
    Redis可视化工具 Redis Desktop Manager
  • 原文地址:https://www.cnblogs.com/andrew-xie/p/5271453.html
Copyright © 2011-2022 走看看