GO语言语言框架

谷歌公司2023年11月30日
11583阅读

作品详情

1发展历程

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

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

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

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

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

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

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

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

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

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

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

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

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运行环境

Widows

Widows 7 or later, Itel 64-bit processor

macOS

Apple macOS (ARM64)

macOS 10.13 or later, Itel 64-bit processor

Liux

Liux 2.6.32 or later, Itel 64-bit processor[2]

4特色

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

5目标

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

6词条图册

功能介绍

Go是开发Android应用的一种BASIC语言,发布于2009年。

声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态
案例
系统分为新老架构: - 老架构(Python 微服务)**:参与大型 KA 客户定制化开发,支持城市急配业务场景,涵盖订单履约、合作商入驻、分账、对账等模块 - 新架构(Golang 微服务)**:参与 SaaS 核心模块的重构与迁移,基于 gRPC 实现服务通信,结合 Kafka 构建异步解耦链路,提升系统稳定性与扩展性 - 主导商品、订单、分拣、配送、WMS 仓储、财务、报表等核心微服务开发,支撑高并发、高可用业务访问 - 基于 Redis 实现分布式锁,解决任务调度多Pod并发问题,确保库存扣减、账单同步等业务的一致性,支持锁有效时长控制与重试机制、幂等保障。 - 报表系统
1490SAASKafkagRPCK8S生鲜配送
面向学校家长教育局,解决家校舍协同育人的场景,包含一个小程序,一个后台,若干个大屏项目,对不同的学校定制开发。技术框架,后端采用docker+postgresql+golang,支持高并发,数据库采用触发器+分表的形式处理数据分类,使类似于被逻辑删除的数据不会被检索到,提高查询效率。教师评语根据教师对学生的打分,利用ai智能生成评语
运输管理ERP,从合同管理,运单管理,结算管理,结账,财务,开票 全流程系统,涉及多项业财核心算法,支持金蝶 等自动数据传输,内包含多个子模块,机器人,RPA自动审核及报表服务! 本项目由我带领团队研发而成,主要框架搭建,逻辑涉及,产品涉及,功能设计和开发,采用前后端分离。 本项目由我带领团队研发而成,主要框架搭建,逻辑涉及,产品涉及,功能设计和开发,采用前后端分离。
1570redisERPXORM物流
项目介绍 silc-client 是一个基于 Vue 3 + TypeScript 构建的现代化前端应用项目。该项目使用了最新的前端技术栈,提供了一个响应式、高性能的用户界面。 技术栈 框架: Vue 3.5.13 (Composition API) 语言: TypeScript 5.8.0 构建工具: Vite 6.2.4 状态管理: Pinia 3.0.2 路由: Vue Router 4.5.0 UI组件库: Element Plus 2.9.9 图表库: ECharts 5.6.0 HTTP客户端: Axios 1.9.0 工具函数: Lodash 4.17.21 日期处理: D
1. 通过网页可对存储中的文件和目录进行创建,重命名,移动,拷贝, 压缩,解压,权限设置,上传下载等等操作; 2. 通过gin框架编写RestfulApi实现前后端交互; 3. 注册的用户信息存储在mysql中,账号密码认证时获取信息校验; 4. 使用os/exec 包调用linux命令进行文件操作、文件搜索和权限管理; 5. 并发分片上传,通过文件唯一标识uuid分片,最后合并分片; 6. 通过zip包实现文件目录流式压缩下载;
当前共1120个项目

评论