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
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态
案例
项目描述: 本实验项目抓住新媒体广告实验教学中最复杂的投放环节,克服广告真实投放实验困境,依托大数据、云计算、人工智能等信息技术,运用虚拟仿真、软件定义等多种形式再建新媒体广告生态圈与程序化投放全流程,集合广告投放四大端,即广告主、广告公司、媒体、受众,及其相关岗位角色,植入新媒体广告最核心的知识点,即技术、原理、方法、产业结构和行业术语,构建了一个“既立足于现实、又有行业前瞻、虚实互补互促、线上线下结合”的实验教学系统,实现了新媒体广告投放教学的智能化云端化和“理、虚、实”一体化,满足了多端多岗、全流程、数据化、时空融合、师生互动、高并发等虚拟仿真实验要求。 主要涉及人群画像构建、网站Se
1920mysqlredis虚拟仿真SaaS
项目描述: 营销云涵盖了包括百度、快手、腾讯、阿里、小米在内的多家主流媒体营销资源。包含:Atomic-账户管理平台、 OTD-批量广告创建平台、OIDB-跨渠道智能数据仪表盘、Ovation-创意聚合平台、AU-数据智能平台。实现了高效的全链路跨渠道广告营销和管理。 数据时效性问题:广告展点消之类表现数据是实时变化的,业务数据支持对数据实时性要求至少做到T-1级别,部分核心展点消数据需要做到小时T-1级别,加上数据来源多,数据类型多, 异构的数据同步程序问题繁多, 数据同步压力异常艰巨。 数据体量问题:庞大且杂乱的数据管理和使用是营销云的核心。8家主流媒体,即使排除视频、图片等数据,每年同
1910vuemysqlredissaas营销云
1. 独立完成后端,主要使用 gin, gorm, redis 构建服务 2. 后端包含福利卡管理, 淘宝电影票对接,京东商品对接,大麦票务对接,文轩网图书对接 3. 主要技术有 - 根据用户的福利卡的信息给用户不同的价格体系 - 对接第三方的数据的缓存处理以及同步处理 - 第三方数据的加速加载 - 根据个人地理位置距离商家以及电影院的排序
1290golang商城
云呼叫中心是腾讯企点客服的电话通路模块,帮助企业通过电话与客户建立沟通,并完成数据沉淀,为后续服务和二次营销提供数据支持。 腾讯企点本身是多租户SCRM,电话模块是其中一个垂直领域,包含管理站点,API 服务,出入网关,坐席管理,会话管理,推送服务等多个模块。 我是 web 后台部分的负责人,主要负责管理站点,出入网关,API 服务,推送服务等模块的开发维护,web 后台早期是用php, 使用一个内部基于 swoole 封装的web框架开发, 微服务架构, 中后期核心服务技术栈迁移到 Go。
1540VOIP 电话系统
手机号/微信号: 13136823696 加备注 主要涉及 pc前端(vue3) 微信小程序 android移动端 / HarmonyOS 跨平台: compose Multiplatform / uniapp
1250vueandroiduniappgolangJavaScript
当前共986个项目

评论