一Go语言学习预备
Posted hucheng1997
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一Go语言学习预备相关的知识,希望对你有一定的参考价值。
-
区块链研发工程师
-
Go服务器端/游戏软件工程师
-
Golang分布式/云计算软件工程师
-
区块链的应用开发
区块链技术,简称BT(Blockchain technology).也被称之为分布式账本技术,是一种互联网数据库技术,其特点是去中心化、公开透明,让每个人均可参与数据库记录。
-
后台服务器引用
如美团后台流量支撑程序、仙侠道游戏服务端
-
云计算/云服务后台应用
盛大云CDN(内容分发网络)、京东消息推送云服务和京东分布式文件系统
3、Golang诞生的原因
1)计算机硬件技术更新频繁,性能提高很快。目前主流的编程语言发展明显落后于硬件,不能合理利用多核多CPU的优势提升软件系统性能。
2)软件系统复杂度越来越高,维护成本越来越高,目前缺乏一个足够简洁高效的编程语言。[现有的编程语言: 1.风格不统一2. 计算能力不够3.处理大并发不够好之中]。
3)企业运行维护很多c/c++的项目,c/c++程序运行速度虽然很快,但是编译速度确很慢,同时还存在内存泄漏的一系列的困扰需要解决。
4、Golang语言的特点
Go语言保证了既能到达静态编译语言的安全和性能,又达到了动态语言开发维护的高效率,使用一个表达式来形容Go语言: Go=C + Python,说明Go语言既有C静态语言程序的运行速度,又能达到Python动态语言的快速开发。
-
从C语言中继承了很多理念,包括表达式语法,控制结构,基础数据类型,调用参数传值,指针等等,也保留了和C语言一样的编译执行方式及弱化的指针。
func testPtr(num *int) *num = 20
-
引入包的概念,用于组织程序结构,Go语言的一个文件都要归属于一一个包,而不能单独存在。
-
垃圾回收机制,内存自动回收,不需开发人员管理
-
天然并发(重要特点)
(1)从语言层面支持并发,实现简单
(2) goroutine,轻量级线程,可实现大并发处理,高效利用多核。
(3)基于CPS并发模型(Communicating Sequential Processes)实现
-
吸收了管道通信机制,形成Go语言特有的管道channel通过管道channel,可以实现不同的goroute之间的相互通信。
-
函数可以返回多个值
//函数实现同时返回和,差 func getSumAndSub(n1 int, n2 int) (int, int) sum:= n1 + n2 /o语句后面不要带分号 sub:=n1 -n2 return sum, sub
-
新的创新:比如切片slice、延时执行defer
5、Golang在Windows和Linux安装的步骤
-
Windows
下载SDK
go1.9.2.windows-amd64.zip
,直接解压。Window需配置3个环境变量,配置完环境变量后,cmd运行go version显示版本即安装成功。GOROOT 指定SDK的安装路径 PATH 指定SDK的bin目录 GOPATH go项目的工作路径 -
Linux
下载SDK
go1.9.2.linux-amd64.tar.gz
,解压,配置系统环境变量,source /etc/profile,执行go version显示版本即安装成功
vim /etc/profile export GOROOT=/opt/go ###SDK的安装目录 export PATH=$PATH:$GOROOT/bin export GOPATH=$HOME/goproject
以上是关于一Go语言学习预备的主要内容,如果未能解决你的问题,请参考以下文章