GO语言语言框架

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

作品详情

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
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态
案例
1. 面向对象及问题解决(占比 30%): 赛凡智慧云盘面向政府机关、企事业单位及教育科研机构,解决其在“数据归集不统一、跨部门协作困难、文件权限混乱、安全合规要求高”的现实问题。通过构建统一的私有云存储平台,实现结构化与非结构化数据的集中管理与安全共享,助力组织实现内部知识沉淀与高效流转。 2. 相比市场常规方案的特点(占比 50%): 支持本地部署、国密认证算法、SM2/SM3/SM4 加密,满足政企对数据主权与安全的高要求。 基于“多租户 + 多角色”权限架构,灵活适配组织内部多部门协作流程。 原生集成全文检索引擎、OCR 文件解析、版本管理与审计追踪。 支持 Web / PC
2670vueMysqlMongoelectron私有化存储
Docker作为容器化技术的核心工具已成为开发者必备利器。然而传统的命令行操作和国外开源Web工具(如Portainer)存在学习成本高、汉化不全、扩展性受限等问题。为此,我们基于国内广泛应用的GVA(Gin+Vue+Admin)go框架,研发了一款功能强大的国产Docker Web GUI管理插件,助力开发者轻松驾驭容器化运维! 二、功能亮点速览 1. 多维度管理能力 功能模块 核心能力 技术亮点 多主机管理 支持同时接入多个docker主机 同时管理多个主机 容器管理 启停/日志查看/资源监控/执行命令 可视化CPU/内存监控图表 镜像管理 远程下载,管理镜像 多仓库下载镜像 终端管理
1460golanggormGin
将本人负责在大型公司(10000人+)内部的框架进行简化,发布为一个开源的go语言框架: - 利用grpc+grpc-gateway,支持gRPC和HTTP的通信,并支持自动生成文档、参数校验 - 使用gorm对接MySQL,实现数据持久化 - 开发相关自动生成代码的套件,大幅提升规范性、自动化 - 代码分层设计,方便概念抽象
1290golang微服务框架gRPCgormGinGolang
事件总线服务(Event Bus Service,简称为 EBS)是实现了事件总线协议的服务实例。 事件总线能很方便的让微服务按事件(如同业务领域标记)分类解耦,也让微服务的连接配置简化为只需配置连接事件总线服务的配置即可。其特性如下: 1. 支持TCP连接。 2. 支持consul服务注册和发现。 3. 支持直接导向、随机、哈希、轮询数据传输模型。
1230微服务golangTCP
1. 【30%】本方案面向谁,解决了什么问题 面向对象:聚焦企业人力资源管理部门、培训管理者,覆盖制造、互联网、服务等需员工技能提升与规范化管理的行业 。 解决问题:解决员工培训资源分散(文档、视频难集中管理)、学习进度难量化跟踪、考试流程线下化低效、人员身份核验繁琐问题,通过一体化平台整合培训资源、自动记录学习轨迹、线上化考试流程,结合人脸识别保障身份真实,提升培训管理效率与效果,助力人才能力标准化建设。 2. 【50%】相比于市场常规方案,本方案有哪些特点 资源与学习管理:常规培训系统资源类型单一、学习路径粗放。本方案支持 多格式资源深度整合(文档在线预览、视频断点续播、支持 SCORM
2090Ginphp
当前共1126个项目

评论