GO语言

开源公司:谷歌公司

作品详情

外文名
go
展开
发布于
2009年
展开
特点
数组安全、编译迅速
展开
软件版本
1.20.1[2]
展开
软件授权
BSD license[3]
展开
属性
编程语言
展开
作用
开发Android应用的一种BASIC语言
展开
开发公司
谷歌[1]
展开
软件大小
25 至 145 MB[2]
展开

1发展历程

Go是谷歌2009年发布的第二款编程语言。2009年7月份,谷歌曾发布了Simple语言,它是用来开发Android应用的一种BASIC语言。

谷歌资深软件工程师罗布·派克(RobPike)表示,“Go让我体验到了从未有过的开发效率。”派克表示,和今天的C++或C一样,Go是一种系统语言。他解释道,“使用它可以进行快速开发,同时它还是一个真正的编译语言,我们之所以现在将其开源,原因是我们认为它已经非常有用和强大。”

2007年,谷歌把Go作为一个20%项目开始研发,即让员工抽出本职工作之外时间的20%,投入在该项目上。除了派克外,该项目的成员还有其它一些谷歌工程师。

派克表示,编译后Go代码的运行速度与C语言非常接近,而且编译速度非常快,就像在使用一个交互式语言。

现有编程语言均未专门对多核处理器进行优化。派克表示,Go就是谷歌工程师为这类程序编写的一种语言。它不是针对编程初学者设计的,但学习使用它也不是非常困难。Go支持面向对象,而且具有真正的封装(closures)和反射(reflection)等功能。

在学习曲线方面,派克认为Go与Java类似,对于Java开发者来说,应该能够轻松学会Go。

之所以将Go作为一个开源项目发布,目的是让开源社区有机会创建更好的工具来使用该语言,例如EclipseIDE中的插件。目前还没有支持Go的IDE。

在目前谷歌公开发布的所有网络应用中,均没有使用Go。但是谷歌已经使用该语言开发了几个内部项目。

派克表示,Go是否会对谷歌即将推出的ChromeOS产生影响,现在还言之尚早,不过Go的确可以和NativeClient配合使用。他表示,“Go可以让应用完美的运行在浏览器内。”例如,使用Go可以更高效的实现Wave,无论是在前端还是后台。

Go语言是一种新的语言,一种并发的、带垃圾回收的、快速编译的语言。它具有以下特点:

1.它可以在一台计算机上用几秒钟的时间编译一个大型的Go程序。

2.Go语言为软件构造提供了一种模型,它使依赖分析更加容易,且避免了大部分C风格include文件与库的开头。

3.Go语言是静态类型的语言,它的类型系统没有层级。因此用户不需要在定义类型之间的关系上花费时间,这样感觉起来比典型的面向对象语言更轻量级。

4.Go语言完全是垃圾回收型的语言,并为并发执行与通信提供了基本的支持。

按照其设计,Go打算为多核机器上系统软件的构造提供一种方法。

Go语言是一种编译型语言,它结合了解释型语言的游刃有余,动态类型语言的开发效率,以及静态类型的安全性。它也打算成为现代的,支持网络与多核计算的语言。要满足这些目标,需要解决一些语言上的问题:一个富有表达能力但轻量级的类型系统,并发与垃圾回收机制,严格的依赖规范等等。这些无法通过库或工具解决好,因此Go也就应运而生了。

2版本记录

go1.20.1

go1.19.6

go1.20

go1.19.5

go1.19.4

go1.19.3

go1.19.2[2]

3运行环境

Windows

Windows 7 or later, Intel 64-bit processor

macOS

Apple macOS (ARM64)

macOS 10.13 or later, Intel 64-bit processor

Linux

Linux 2.6.32 or later, Intel 64-bit processor[2]

4特色

简洁快速安全并行有趣开源支持泛型编程,内存管理,数组安全,编译迅速

5目标

Go的目标是希望提升现有编程语言对程序库等依赖性(dependency)的管理,这些软件元素会被应用程序反复调用。由于存在并行编程模式,因此这一语言也被设计用来解决多处理器的任务。

6词条图册

声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态
案例
1.saas 平台系统重构,通过 DDD 理论指导,代码层面端口适配器架构、洋葱架构、领域模型、分层架构等。实现代码可阅读性,业务分层清晰。 2.教学实训平台的工作流引擎业务板块,长时间轮询的工作流机制。 3.攻防演练平台的多模块拆分。模块化管理业务相关的领域模型。 4.系统资源管理的 openstack Havana 项目的维护,本地部署搭建相关。 5.系统平台以golang为基本服务,python为底层服务 6.使用kafka消息队列,实现消息微服务间的消息通知。 7.搭建jenkin实现CICD全流程。 8.搭建gitlab代码仓库管理。 9.git版本多分支多标签管理。 10.redi
腾讯微卡项目主力开发。电子工卡,基于众多普教/ K12 学生无法使用手机的情况,腾讯微校通过让学生使用的物理设备与家长使用的电子卡联动,助力学校建设以一卡通为核心的 K12 智慧校园场景,并让家长可以实时掌握孩子在校动态。
800电子工卡
产品简介:基于设备流量代理和路由转发能力,通过服务端划分组别网段及对终端的交互管理,实现各终端设备跨区域互联互通(TURN+P2P模式),接入终端的外部设备可像局域网内一样相互访问。产品适用于设备远程监控调试、个人或企业组建 SDN 网络,为用户提供了远程访问或跨区域组网十分便捷的途径。 职责描述:独立负责相关软件设计、开发及测试,包含嵌入式终端软件开发(Go),windows 终端软件开发(Go + Vue),服务器端软件开发(Go),以及服务端管理 APP (uni-app),以及整个产品各端联调及优化。
5230vueandroid网络协议
数据库 UI 运维工具的核心目标是数据库运维效率,实现数据风险的前置管理,发现并规避数据使用问题,提高DBA优 化和排错效率,保证数据库的稳定运行。 主要功能包括但不限于:数据库的安装、扩容、数据分析、巡检、状态监控、异常告警、数据导入、SQL 编辑器等。
项目分为市场交易、藏品管理、平台社区、个人中心、支付相关和AI藏品等板块。对于用户而言,用户可以发行、购买、出售、合成和置换数字藏品,可以向钱包中充值现金或从钱包中提取现金到银行卡。用户可以使用AI作画功能制作AI藏品,并铸造成数字藏品进行发行。用户可以在社区中与其他数字藏品爱好者一同交流最近的数字藏品行业发展趋势。
1180redisdocker
当前共986个项目

评论