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. 实时数仓:canal/flinkCDC/flume/flink + zk + kafka /hadoop(hdfs) + hudi/hbase(OLAP:Clickhouse)/Springboot Scheduler) 2. 离线数仓: flume + zk + hadoop/hive/impala + DolphinS
1630springclouddocker数据中台
慧眼安全检测平台是基于行业化合规的主动安全管理产品。可作为行业监管部门的监督检查工具,快速摸排资产、精准定位风险隐患,及时响应通报并推动整改;可作为行业化关键信息基础设施的管理和监控平台,结合安全事件,帮助用户进行资产梳理,评估漏洞影响,快速处置,形成安全管理闭环。 我负责检测引擎开发
HTTP->RTMP推流Proxy 基于http+ffmpeg开发的RTMP推流代理,解决普通HTTP音/视频无法直接推流到RTMP服务器问题 解决的问题 ffmpeg推流需要手动执行shell命令 客户端上传的数据为base64编码过的二进制数据 nginx-rtmp-module安全问题,目前只会使用allow publish来限制
Halia Halia是一个基于组件化的网络应用框架,用于快速开发可维护的高性能协议服务器和客户端。 Features 组件化 可扩展 高性能
项目介绍:统一各大AI模型接口格式为openAi接口调用方式,提供聚合化的Ai接口调用。 1.对接各大Ai模型接口,统一按照格式进行处理返回 2.同时使用同步调用以及异步调用方式,异步调用通过任务队列进行处理任务并返回结果。 3.对于多并发控制进行处理,利用数据库行级锁进行扣费处理,并实现账单计费,对于失败的调用需要返回冻结金额。 4.实现多种精细计费模式,并详细展示使用详情数据。 5.实现自定义视频模型接口,通过ffmpeg对视频素材进行处理合并为可用短视频。
130vuemysqlgolang
当前共986个项目

评论