go语言是互联网时代的语言,融合了众多互联网时代程序设计的特征。

并行与分布式支持。多核化和集群化是互联网时代的典型特征。

并发执行的“执行体”

执行体是个抽象的概念,在操作系统层面有多个概念与之对应,如操作系统自己掌管的进程(process)、进程内的线程(thread)以及进程内的协程 (coroutine,也叫轻量级线程)。多数语言在语法层面并不直接支持协程,而通过库的方式支持的协程的功能也并不完整,比如仅仅提供协程的创建、销毁与切换等能力。如果在这样的协程中调用一个同步IO操作,比如网络通信、本地文件读写,都会阻塞其他的并发执行协程,从而无法真正达到协程本身期望达到的目标。 Go语言在语言级别支持协程,叫goroutine。Go语言标准库提供的所有系统调用(syscall)操作,当然也包括所有同步IO操作,都会出让CPU给其他goroutine,这让事情变得非常简单。

go语言异步程序示例:


func run(arg string) {// ...}func main() {go run("test")...}

关于进程、线程、协程的区别可以参考如下几篇文章:

谈谈并发编程中的协程

一个“蝇量级” C 语言协程库

编程中的进程、线程、协程、同步、异步、回调

执行体间的通信

执行体间通信的方式:

  • 执行体之间的互斥与同步

  • 执行体之间的消息传递

执行体之间的互斥与同步

当执行体之间存在共享资源(一般是共享内存)时,为保证内存访问逻辑的确定性,需要对访问该共享资源的相关执行体进行互斥。当多个执行体之间 的逻辑存在时序上的依赖时,也往往需要在执行体之间进行同步。

多数语言在库层面提供了线程间的互斥与同步支持,但却找不到协程的影子。

执行体之间的消息传递

两种并发编程模型:

  • 共享内存模型

  • 消息传递模型

go语言整合了两种并发编程模型,但其推荐“消息传递模型”。其建议适度使用“共享内存模型”。在Go语言中,内置了消息队列的支持,其叫通道(channel)。两个goroutine之间可以通过通道来进行交互。

软件工程支持。工程规模不断扩大是产业发展的必然趋势。

随着工程规模的变大,多数软件需要多人协作完成。所以编程规范化,对于多人协作编程是非常必要的。

go语言是非常规范化的语言,其规范化主要体现在一下几个方面:

  • 代码风格规范

  • 错误处理规范

  • 包管理

  • 契约规范(接口)

  • 单元测试规范

  • 功能开发的流程规范

【示例】go语言的错误处理规范:


f, err := os.Open(filename) if err != nil {log.Println("Open file failed:", err)return}defer f.Close()... // 操作已经打开的f文件

编程哲学的重塑

当今主要的编程范式:

  • 面向过程编程(C)

  • 面向对象编程(C++,Java)

  • 函数式编程(Python)

  • 面向消息编程(Erlang)

如果需要对“函数式编程”有所了解,阅读这篇文章:

函数式编程

go语言对所有这些编程思想做了一次梳理,融合众家之长,但时刻警惕特性复杂化,极力维持语言特性的简洁,力求小而精。

例如,Go语言接受了“函数式编程”的一些想法,支持匿名函数与闭包。再如,Go语言接受了以Erlang语言为代表的“面向消息编程”思想,支持goroutine和通道。

特性:

  1. 让并发拿来即用。
  2. 解决大系统编程问题。

TODO:

  1. GC机制(仅仅是GC)。
  2. int和int32不是同种类型。
  3. 同一个包的文件一起编译。
  4. 分段式栈。

go的编程哲学和设计理念相关推荐

  1. Unix编程哲学和软件设计方法

          Unix编程哲学: 1,模块原则:使用简洁的接口拼合简单的部件. 2,清晰原则:清晰胜于机巧. 3,组合原则:设计时考虑拼接组合. 4,分离原则:策略同机制分离,接口同实现引擎分离. 5, ...

  2. Java | 用Java实现选择排序算法(记录写程序全过程的编程哲学)

    最近听了马士兵老师的java算法课,感觉这不错,我很欣赏其中的编程哲学. 一.编程哲学 有简单到复杂 1.1 验证一步走一步 1.2 多打印中间结果 先局部后整体 先粗糙后精细 3.1 变量更名 3. ...

  3. 编程哲学之C#篇:02——学习思维

    <代码大全>的第二章:介绍隐喻(类比)的思维方式, <经济学原理>的第二章:介绍怎么像经济学家一样思考, <计算机的心智操作系统之哲学原理>的第一章:介绍学习操作系 ...

  4. 编程哲学之C#篇:01——创世纪

    我们能否像神一样地创建一个世界? 对于创建世界而言,程序员的创作能力最接近于神--相对于导演,作家,漫画家而言,他们创建的世界(作品)一旦完成,就再也不会变化,创建的角色再也不会成长.而程序员创建的世 ...

  5. 张砷镓:我所信奉的编程哲学

    从去年到今年,陆陆续续看完了<代码大全>.<重构>.<代码整洁之道>.<程序员修炼之道>以及<The Art of Readable Code&g ...

  6. 编程哲学之 C# 篇:007——如何创造万物

    上帝拥有创建万物的能力,本文介绍创造万物的道,让你也拥有上帝般创造万物的能力! 道 中国哲学家,道家学派创始人--老子,在<道德经>写到: 道生一,一生二,二生三,三生万物 那么,是什么 ...

  7. 编程哲学-13条左右人生的金科玉律

    墨菲定律.二八法则.马太效应.手表定理."不值得"定律.彼得原理.零和游戏.华盛顿合作规律.酒与污水定律.水桶定律.蘑菇管理原理.钱的问题.奥卡姆剃刀等13条是左右人生的金科玉律. ...

  8. Programming Languages PartA Week5学习笔记——SML进阶与编程哲学

    文章目录 Week5 Introduction What is Type Inference ML Type Inference Type Inference Examples Polymorphic ...

  9. 一切都是对象,一切都是指针,一切都是东西(python的编程哲学)

    终于把1000多页的python学习手册啃完了.从来没有从深层次上去理解一门编程语言,学习c是如此,学习java也是如此.总觉得这些语言就是拿来用的.不用管它为什么要创造出来. 这几天认真系统的学习了 ...

  10. Go 语言编程 — Overview

    目录 文章目录 目录 缘起 我们为什么选择 Golang? Golang 是云时代的宠儿! Golang 的吉祥物 Golang 的特性 语法简单 原生支持并发编程 内存分配 自动垃圾回收 使用静态链 ...

最新文章

  1. 高级数据结构讲解与案例分析
  2. 请你要幸福 这是 你唯一能为我做到的
  3. 使用Scala-IDE构建Maven项目
  4. 互联网协议IP抓包分析 -- wireshark
  5. DHCP+TFTP+VSFTP+pxelinux+kickstart实现RedHat的自动安装
  6. 如何根据SAP Spartacus的页面快速找到实现的Angular Component
  7. 使用Java Stream摘要统计
  8. 音视频播放、录音、拍照
  9. 2.3 logistic 回归损失函数
  10. packmol建模流程-计算
  11. tq2440修改默认串口不支持打印控制台
  12. 数据库索引的作用以及索引基本原理
  13. 课后作业3:软件分析与用户体验分析
  14. 简单的个人介绍网页【附代码】
  15. 显示杂谈(1)-Gamma到底是个什么鬼
  16. 连续分配存储的四种管理方式
  17. 1051 复数乘法 分数 15
  18. http-杂货铺.md
  19. z3 android os,尖Phone:旗舰之争 索尼Z3对比iPhone 6
  20. oracle exp导出很慢,oracleexp导出慢

热门文章

  1. python面向对象基础知识_面向对象的一些基本知识(python)
  2. css实现圆球旋像水波波动_66 个超有用的CSS 特效!
  3. Spring框架的本质:4那些高曝光率的Annotation
  4. 10分钟体验一把Kafka[测试用例]
  5. Spring的注解 @Bean用法
  6. Flutter:布局
  7. K8S-删除Terminating状态的namespace
  8. 博客主之自我介绍(不长,随便瞅瞅)
  9. XQuery FLWOR 表达式
  10. 转:python命令行解析工具Argparse