标签:process 组织 分发 成本 系统性能 实现 不能 系统 focus
区块链研发工程师
Go服务器端/游戏软件工程师
Golang分布式/云计算软件工程师
区块链的应用开发
区块链技术,简称BT(Blockchain technology).也被称之为分布式账本技术,是一种互联网数据库技术,其特点是去中心化、公开透明,让每个人均可参与数据库记录。
后台服务器引用
如美团后台流量支撑程序、仙侠道游戏服务端
云计算/云服务后台应用
盛大云CDN(内容分发网络)、京东消息推送云服务和京东分布式文件系统
1)计算机硬件技术更新频繁,性能提高很快。目前主流的编程语言发展明显落后于硬件,不能合理利用多核多CPU的优势提升软件系统性能。
2)软件系统复杂度越来越高,维护成本越来越高,目前缺乏一个足够简洁高效的编程语言。[现有的编程语言: 1.风格不统一2. 计算能力不够3.处理大并发不够好之中]。
3)企业运行维护很多c/c++的项目,c/c++程序运行速度虽然很快,但是编译速度确很慢,同时还存在内存泄漏的一系列的困扰需要解决。
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
Windows
下载SDKgo1.9.2.windows-amd64.zip
,直接解压。Window需配置3个环境变量,配置完环境变量后,cmd运行go version显示版本即安装成功。
GOROOT | 指定SDK的安装路径 |
---|---|
PATH | 指定SDK的bin目录 |
GOPATH | go项目的工作路径 |
Linux
下载SDKgo1.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
标签:process 组织 分发 成本 系统性能 实现 不能 系统 focus
原文地址:https://www.cnblogs.com/hucheng1997/p/11594298.html