Go语言认识

Go语言认识

  • 1. Go语言的设计背景
  • 2. Go语言的历程
  • 3. Go语言对比分析
  • 4. Go语言未来的发展规划
  • 5. 要不要选择Go

关注 go博客 直接了解第一手资料。
go文档 了解go的全貌。

1. Go语言的设计背景

Go语言(也称为Golang)是由Google开发的一种编程语言。它的设计背景源于对现有编程语言的不足之处的反思和对新兴需求的追求。以下是Go语言的设计背景的详细解释:

  1. 并发编程需求:随着计算机硬件的发展,多核处理器和分布式系统变得越来越普遍。传统的编程语言在处理并发编程时存在一些困难,如共享内存并发模型的复杂性和线程安全问题。Go语言通过引入轻量级的Goroutine和通道(Channel)机制,使并发编程变得更加简单和安全。

  2. 大规模软件开发:在大规模软件开发中,代码的可维护性和可读性非常重要。然而,一些传统的编程语言在这方面存在一些问题,如复杂的语法和过多的语言特性。Go语言通过简洁的语法和清晰的设计原则,鼓励编写简洁、可读性强的代码,以提高软件的可维护性。

  3. 快速编译和执行:在软件开发过程中,快速的编译和执行速度可以提高开发效率。一些编程语言在编译和执行速度方面存在一些问题,如编译时间长或执行效率低。Go语言通过优化编译器和运行时,以及采用静态链接的方式,实现了快速的编译和执行速度。

  4. 内存管理:传统的编程语言在内存管理方面存在一些问题,如手动内存管理容易出错,自动垃圾回收机制可能导致性能问题。Go语言引入了一种称为"垃圾回收器"的自动内存管理机制,可以在不牺牲性能的情况下自动回收不再使用的内存。

  5. 跨平台支持:在现代软件开发中,跨平台支持变得越来越重要。一些编程语言在不同平台上的兼容性和可移植性方面存在一些问题。Go语言通过提供跨平台的编译器和运行时环境,使得开发者可以轻松地在不同的操作系统和硬件平台上开发和部署应用程序。

  6. 开发者友好性:Go语言的设计目标之一是提供一种开发者友好的编程语言。它通过提供简洁的语法、清晰的错误信息和丰富的标准库,使得开发者可以更轻松地学习和使用该语言。

总结起来,Go语言的设计背景可以归结为对并发编程需求、大规模软件开发、快速编译和执行、内存管理、跨平台支持和开发者友好性的关注。这些设计原则使得Go语言成为一种简洁、高效、可靠和易于使用的编程语言。

  1. Go语言官方网站:https://golang.org/
  2. “The Go Programming Language”(Go语言官方书籍):https://golang.org/doc/
  3. “Go at Google: Language Design in the Service of Software Engineering”(关于Go语言设计的论文):https://talks.golang.org/2012/splash.article
  4. “Go: A Systems Programming Language”(关于Go语言设计的演讲视频):https://www.youtube.com/watch?v=rKnDgT73v8s

2. Go语言的历程

  • 2007年:Go语言的起源可以追溯到2007年。当时,Google的工程师们(包括Robert Griesemer、Rob Pike和Ken Thompson)开始思考如何设计一种新的编程语言,以解决一些现有编程语言的问题,并满足Google内部的需求。

  • 2009年:Go语言的首个公开版本(Go 1)于2009年11月发布。这个版本是一个实验性版本,用于收集反馈和改进语言设计。Go语言的设计目标是提供一种简洁、高效、可靠和易于使用的编程语言,适用于大规模软件开发和并发编程。

  • 2010年:Go语言的发展开始引起广泛关注。在2010年,Go语言的用户社区开始形成,许多开发者开始尝试使用Go语言进行项目开发,并提供了一些开源项目和库。

  • 2012年:Go语言的发展进入了一个新的阶段。在2012年3月,Go语言的第一个稳定版本(Go 1)发布。这个版本的发布标志着Go语言的正式进入生产环境,并承诺向后兼容性。

  • 2014年:Go语言的发展继续迅速。在2014年,Go语言的第一个大版本升级(Go 1.4)发布。这个版本引入了一些重要的改进,如增强的垃圾回收器、更好的并发性能和更好的工具链。

  • 2016年:Go语言的发展持续推进。在2016年,Go语言的第二个大版本升级(Go 1.7)发布。这个版本引入了一些新特性,如上下文(Context)包、并发安全的Map类型和更好的编译器优化。

  • 2018年:Go语言的发展继续取得重要进展。在2018年,Go语言的第三个大版本升级(Go 1.11)发布。这个版本引入了一些重要的改进,如模块化支持、WebAssembly支持和更好的性能优化。

  • 2020年:Go语言的发展仍在继续。在2020年,Go语言的第四个大版本升级(Go 1.15)发布。这个版本引入了一些新特性,如更快的编译速度、更好的垃圾回收和更好的错误处理。

  • 2022年:Go语言支持了泛型。在2022年,Go 1.18 发布,让Go语言支持了泛型,在开发通用性的逻辑时,不在使用interface{}万能类型来传参,更好的处理通用逻辑中的类型。

Go语言的发展历程可以追溯到其诞生的初期,经历了多个版本的迭代和改进。随着时间的推移,Go语言在开发者社区中获得了广泛的认可和使用,并在许多领域得到了应用,包括网络服务、分布式系统、云计算和人工智能等。

比较有意思的是,如果你开发过Java,那么你一定知道NPE异常,在2023年8月发布的Go 1.21.0 中,新增了一个错误*runtime.PanicNilError,可以认为这是Go版本的NPE。(大道同归~)

“A brief history of Go”(关于Go语言历史的官方博客文章):https://blog.golang.org/10years

go 发布历史 查看全部版本,以及每个版本go的特性。

3. Go语言对比分析

  1. 性能:
    Go语言:Go语言以高性能而闻名,其编译器和运行时系统的设计使其能够有效地利用多核处理器。它具有轻量级线程(goroutine)和通信机制(channel),使并发编程变得简单而高效。
    Java:Java的性能通常比Go语言稍低,但它具有强大的即时编译器和优化技术,可以在运行时进行性能优化。
    C和C++:C和C++是编译型语言,执行效率非常高。它们可以直接操作内存,提供了底层控制的能力,适合开发对性能要求较高的应用程序。

  2. 并发支持:
    Go语言:Go语言原生支持轻量级线程(goroutine)和通信机制(channel),使得并发编程变得简单而高效。
    Java:Java通过线程和锁机制来支持并发编程,但相对于Go语言的goroutine和channel,Java的并发编程模型更为复杂。
    Python:Python的并发支持相对较弱,但通过使用第三方库(如concurrent.futures和asyncio)可以实现并发编程。
    C和C++:C和C++本身没有原生的并发支持,但可以使用线程库(如pthread)来实现并发编程。
    JavaScript:JavaScript通过事件循环和异步编程模型来支持并发操作,使得在浏览器中处理大量并发请求变得容易。

  3. 生态系统和库支持:
    Go语言:尽管Go语言的生态系统相对较年轻,但它拥有丰富的标准库和活跃的开源社区。许多知名的项目和库(如Docker、Kubernetes和gin)都是使用Go语言开发的。
    Java:Java拥有庞大而成熟的生态系统,具有丰富的类库和框架,适用于各种应用场景。一些知名的Java框架包括Spring、Hibernate和Apache Struts。
    Python:Python拥有强大的第三方库和框架,可以快速实现各种功能。一些知名的Python库和框架包括NumPy、Django和Flask。
    C和C++:C和C++拥有丰富的类库和工具,可以用于系统级编程、嵌入式开发和游戏开发等领域。
    JavaScript:JavaScript在前端开发中具有广泛的应用,拥有丰富的类库和框架,如React、Angular和Vue.js。
    PHP:PHP在网页开发领域具有广泛的应用,拥有许多成熟的框架和类库,如Laravel和Symfony。

  4. 学习曲线:
    Go语言:Go语言的语法简洁明了,学习曲线相对较低,适合初学者入门。
    Java:Java是一种面向对象的语言,学习曲线较陡峭,需要掌握面向对象的概念和复杂的语法规则。
    Python:Python的语法简单易读,学习曲线相对较低,适合初学者入门。
    C和C++:C和C++的语法相对较复杂,需要掌握指针、内存管理等底层概念,学习曲线较陡峭。
    JavaScript:JavaScript的语法相对较简单,但在处理异步编程和浏览器API时可能会有一些复杂性。
    PHP:PHP的语法相对较简单,学习曲线较低,适合快速入门。

Go语言比Java快,比c/c++简单,不需要直接管理内存,比Python更容易实现大型项目,只有25个关键字,更容易上手等等的优点;
但是也存在不足,比如没有Java那么强大的生态,没有c/c++那么深的基础,没有php和js以及Python的动态特性,糟糕的异常处理等等。
没有最好的语言,只有合适不合适。

4. Go语言未来的发展规划

提高性能和并发能力:
Go语言以其出色的性能和并发能力而闻名。未来,Go语言的发展将继续致力于提高性能和并发处理能力,以满足不断增长的需求。这包括改进编译器、优化运行时、提高垃圾回收机制等方面的工作。
而且事实上每一次Go版本的发布,都伴随着编译和运行时的性能优化,或者是内存回收的优化。

扩展应用领域:
目前,Go语言已经在许多领域得到了广泛应用,包括网络服务、云计算、容器技术等。未来,Go语言将继续扩展其应用领域,进一步深入到人工智能、大数据、区块链等新兴领域。
(我个人认为云原生可能是一个方向)

生态系统的发展:
Go语言拥有一个活跃的开源社区,其中包括许多优秀的第三方库和框架。未来,Go语言的生态系统将继续发展壮大,为开发者提供更多的工具和资源。这将有助于提高开发效率,加速应用的开发和部署。
相比较Java,Go的生态还是差距非常大,而且基本上Go的第三方库都是来自github,可能会出现第三方库的维护问题,水平参差不齐问题等等。相较于Java,Go的生态缺少一些权威支持的第三方库,比如Java里面的apache,spring,等等现象级的框架。

支持更多平台和架构:
目前,Go语言已经支持多个平台和架构,包括Windows、Linux、macOS等。
在当下环境中,跨平台可以算是每一种编程语言的基本能力了,从Java的Write Once, Run anywhere. 甚至现在不仅仅包括三大主流系统:windows,mac,linux,还包含一些硬件嵌入式等系统的支持。

提供更好的工具和开发体验:
Go语言注重简洁、易用和高效的设计理念。未来,Go语言将继续改进工具链,提供更好的开发体验,包括更友好的IDE集成、更强大的调试工具等。
Go开发团队在最新的2年一次的开发者调查中,已经初步确定在24年中,将会把工具链和错误堆栈等作为将会解决的问题了。期待~
Go23年h2开发者调查报告-工具链错误

相较于Python的版本不兼容问题,比如Python2和Python3虽然大致上相同,但是仍然存在相当数量的SDK不兼容问题,比如最常用来举例的print "helloWorld"print("helloWorld")
SDK版本不兼容不仅仅只有Python,Scala也是其中之一,Scala2和Scala3就是不兼容的,比如spark发行物中,就有4种(也许现在不是了),spark2&&spark3,spark2,spark3,source code 。
SDK版本不兼容就会出现同样的代码逻辑需要开发两次,当然更多的是做适配,而不是核心逻辑也写两份,除此之外,还会出现同样的环境针对同一种语言需要依赖两种SDK,在开发的时候时候需要不断的切换SDK的版本。
幸运的是,目前为止,仅仅是目前为止,在Go的开发计划中,Go 2和Go 1 是高度兼容的,但是Go 的开发团队也没有做出完全保证,说Go 2和Go 1完全100%兼容。
Go 2计划

在这里插入图片描述

5. 要不要选择Go

语言只是一种工具而已,实现一个功能,只要不是特定领域的特定功能,我相信绝大部分编程语言都能实现。那么,为什么选择Go呢,看了看网上的资料,各有各的说法,不过确实有些说法很中肯。
比如Go语言背靠Google,其发展稳定性能得到一定的保障,不会出现烂尾的风险,当然现在也不能绝对。只是就目前来说,随着大环境的整体变差,降本增效是大主流,相比Java的大资源消耗,Go对于硬件资源的要求确实基本上做到了c/c++的程度,毕竟运行一个jvm就需要很大的资源。
有人认为Go是站在前人的肩膀上的一门语言,毕竟Go语言核心开发者,是c,c++,jvm,操作系统的作者或者参与者,重新设计一门全新的语言,那么一定会将之前成功的经验发扬光大,失败的问题提前避免。
比如相比c/c++,Go实现了自动内存回收,大大的解决了c/c++的内存管理难题。当然所谓的难题也只是对语言的深度不够导致的。
站在云原生和低资源消耗这两个角度,我认为学习Go有一定的必要,但还是看工作的需要和个人未来的发展规划。

没有哪一种语言是永恒的,但是其思想可以长存。 ~共勉

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/346018.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Maven】006-Maven 依赖传递和依赖冲突

【Maven】006-Maven 依赖传递和依赖冲突 文章目录 【Maven】006-Maven 依赖传递和依赖冲突一、依赖传递1、概述2、案例:jackson 依赖引入依赖Maven 仓库详情页IDEA 中查看 Maven 依赖关系 二、依赖冲突1、概述2、冲突解决的两种方式 一、依赖传递 1、概述 概念&am…

重生奇迹mu敏弓加点攻略

1. 选择正确的属性点分配 在重生奇迹mu游戏中敏弓的属性点分配非常重要。建议将主要属性点分配在敏捷和力量上这样可以提高敏弓的攻击力和闪避能力。适当加点在体力和魔力上可以提高敏弓的生存能力和技能释放次数。不要忘记适当加点在智力上可以提高敏弓的技能威力和命中率。 …

七通道NPN 达林顿管GC2003,专为符合标准 TTL 而制造

GC2003 内部集成了 7 个 NPN 达林顿晶体管,连接的阵列,非常适合逻辑接口电平数字电路(例 如 TTL,CMOS 或PMOS 上/NMOS)和较高的电流/电压,如电灯电磁阀,继电器,打印机或其他类似的负…

代码随想录算法训练营第四天 |链表总结

1、每次先加判断: if (head null) {return head;} 2、ListNode dummy new ListNode(-1, head);和ListNode dummy new ListNode(-1);区别: 在Java中,ListNode dummy new ListNode(-1, head); 和 ListNode dummy new ListNode(-1); 的主…

Redis管道操作

文章目录 1. 问题提出2. 解决方案3. 案例演示4. 总结 1. 问题提出 如何优化频繁命令往返造成的性能瓶颈? Redis是一种基于C/S一级请求响应协议的TCP服务,一个请求会遵循一下步骤: 客户端向服务端发送命令分四步(发送命令-> …

【NI-DAQmx入门】LabVIEW中DAQmx同步

1.同步解释 1.1 同步基础概念 触发器:触发器是控制采集的命令。您可以使用触发器来启动、停止或暂停采集。触发信号可以源自软件或硬件源。 时钟:时钟是用于对数据采集计时的周期性数字信号。根据具体情况,您可以使用时钟信号直接控制数据采…

金蝶云星空与金蝶云星空对接集成逐个单据查询连通员工新增(3009-销售退货清理卡片)

金蝶云星空与金蝶云星空对接集成逐个单据查询连通员工新增(3009-销售退货清理卡片) 来源系统:金蝶云星空 金蝶K/3Cloud(金蝶云星空)是移动互联网时代的新型ERP,是基于WEB2.0与云技术的新时代企业管理服务平台。金蝶K/3Cloud围绕着“生态、人人…

每日一题——LeetCode1160.拼写单词

方法一 个人方法: 先统计chars里每个字符出现的次数,再对words里每个字符串统计每个字符出现的字符,当: 1、字符串里出现chars里没有的字符 2、字符串里某个字符出现的次数大于该字符在chars里出现的次数 以上两种情况则不符合…

Open CASCADE学习|基于visual studio 2022编译源码

目录 1、简介 2、下载 2.1下载visual studio 2022 community 2.2下载下载cmake工具 2.3下载源码 2.4下载第三方插件 3、安装 3.1安装visual studio 2022 community 3.2安装cmake 4、编译源码 5、测试 1、简介 Open CASCADE(简称…

工作每天都在用的 DNS 协议,你真的了解么?

我们经常访问一些网址的时候,浏览器里输入类似于 www.baidu.com 这样的地址,那么在浏览器里输入这个地址---> 百度服务器给我们返回这个百度的页面,中间的过程是什么样的呢? 带着这个问题,我们一起来解析一下其中的…

使用numpy处理图片——基础操作

大纲 准备工作图片像素大小修改透明度 numpy是一款非常优秀的处理多维数组的Python基础包。在现实中,我们最经常接触的多维数组相关的场景就是图像处理。本系列将通过若干篇对图像处理相关的探讨,来介绍numpy的使用方法,以获得直观的体验。 本…

怎么理解接口幂等,项目中如何保证的接口幂等

都 2024 年了,竟然还有人不知道接口幂等是什么东西。 hi,大家好,我是 浮生 今天正好有空,给大家分享一下 幂等的实现。 什么是幂等? 一、问题解析 简单来说,就是一个接口,使用相同的参数重复执…