golang项目目录结构


<golang_proj>

├─README
                 ├─AUTHORS
                 ├─<bin>
                 ├─<pkg>
                 ├─<src>

golang工程不需要任何的工程文件,一个完整的工程通常会在项目根目录下放置上面所示的文件或目录。它们的作用如下:

 README : 简单介绍本项目的目标和主要注意事项,通常第一次使用时应该先阅读此文档。

 LICENSE  : 本工程采用的分发协议,所有开源项目通常都拥有该文档。

 src           : src目录用于存放所有的源代码。

pkg         : pkg目录用于存放编译后的包文件,无需手动创建。

bin          : bin目录用于存放编译后的可执行文件,无需手动创建。

• src目录

 目录src用于包含所有的源代码,是go tool一个强制的规则。

 构建过程中,go tool对包结构的理解完全依赖于src下面的目录结构

 go get命令下载的第三方源码将放置于GOPATH环境变量中第一个路径之中。

以《golang之package》中提及的calc实例来说明的话,其目录结构一开始如下:

<calcproj>
           ├─<src>
                   ├─<calc>
                            ├─calc.go
                   ├─<simplemath>
                            ├─add.go
                            ├─add_test.go
                            ├─sqrt.go
                            ├─sqrt_test.go
           ├─<bin>
           ├─<pkg>

那么在命令行中,我们在工程路径下,使用go install simplemath命令对simplemath进行打包,可以在pkg目录下找到simplemath.a文件。

如果我们希望simplemath.a的路径带有一个命名空间,即在在使用时希望以import "myns/simplemath"这样的方式导入,那么需要将目录结构调整为如下形式:

<calcproj>
           ├─<src>
                   ├─<calc>
                            ├─calc.go
                   ├─<simplemath>

├─<myns>
                                      ├─add.go
                                      ├─add_test.go
                                      ├─sqrt.go
                                      ├─sqrt_test.go
           ├─<bin>
           ├─<pkg>

那么在命令行中,我们在工程路径下,使用go install myns/simplemath命令对simplemath进行打包,可以在pkg目录下找到simplemath.a文件。

如果在命令行中,我们在工程路径下,执行go install calc命令,那么不仅可以在bin目录下找到calc.exe可执行文件,还可以在pkg目录下找到simplemath.a打包文件。

• bin目录

 目录bin用于存放编译后的可执行文件。

• pkg目录

 目录pkg用于存放编译后的包文件。

golang多个项目管理


• 方案一

该方案就是设置多个GOPATH路径,即将多个项目工程的路径都加入到GOPATH中,例如设置GOPATH为形如下面路径:

D:\workspace\golang\calcproj;D:\workspace\golang\golearning;D:\workspace\golang\rpcclient;D:\workspace\golang\rpcserver

优点:项目目录结构清晰,干净,每个工程下面只拥有自己相关的文件。

缺点:使用类似go get的命令时,受影响的仅仅是GOPATH路径下的第一个路径,譬如使用go get取得第三方源码时,取得的源码只能下载到GOPATH路径下的第一个路径。

• 方案二

该方案就是始终设置一个GOPATH路径,多个项目都放置在该路径下的src目录,并按照工程划分目录,例如设置GOPATH为形如下面路径:

D:\workspace\golang

优点:GOPATH只需要设置一个目录就可以管理多个工程,也不用烦恼第三方源码存放位置。

缺点:这种目录结构下工程文件夹也是一个包名路径,即内部工程文件在import时候需要加上工程文件夹名。以上述为例,protoc-gen-go在import其他包时候,需要加上基于src的相对路径:

[golang note] 工程组织的更多相关文章

  1. vue.js不仅是一种模式,也是一种工程组织方式

    vue.js不仅是一种模式,也是一种工程组织方式

  2. [golang note] 环境搭建

    LiteIDE(windows) • golang安装 ▶ 下载对应操作系统的版本并安装,下载地址:http://www.golangtc.com/download,譬如这里下载的是go1.6.win ...

  3. [golang note] 网络编程 - RPC编程

    net包 • 官方文档 http://godoc.golangtc.com/pkg/net/ Package net provides a portable interface for network ...

  4. golang (5) ---工程管理

    1. go mod 添加本地package依赖 go mod 作为golang新的版本管理工具,减少了对GOPATH的依赖. 但是对本地文件的依赖的时候,提示 build server: cannot ...

  5. [golang note] 变量常量

    变量 • 变量声明 √ golang变量声明的关键字为var. √ golang变量声明时类型信息放置在变量名之后. ▶ 单个变量声明 ▪ 语法如下 var name type ▪ 示例如下 var ...

  6. [golang note] 包和导入

    package的作用        √ package是golang最基本的分发单位和工程管理中依赖关系的体现.        √ 每个golang源代码文件开头都拥有一个package声明,表示该g ...

  7. go工程组织规范

    go编码以workspace形式管理,一个workspace包含所有的Go编码,包含多个版本控制仓库(例如使用git管理的多个仓库).每个仓库包含多个包package,每个package是一个单独的路 ...

  8. 【GoLang】GoLang GOPATH 工程管理 最佳实践

    参考资料: MAC下 Intellij IDEA GO语言插件安装及简单案例:http://blog.csdn.net/fenglailea/article/details/53054502 关于wi ...

  9. [golang note] 协程通信

    channel基本语法 • channel介绍 √ golang社区口号:不要通过共享内存来通信,而应该通过通信来共享内存. √ golang提供一种基于消息机制而非共享内存的通信模型.消息机制认为每 ...

随机推荐

  1. makefile--参数传递、条件判断、include (五)

    原创博文,转载请标明出处--周学伟http://www.cnblogs.com/zxouxuewei/ 在多个Makefile嵌套调用时,有时我们需要传递一些参数给下一层Makefile.比如我们在顶 ...

  2. Mongodb 与sql 语句对照

    此处用mysql中的sql语句做例子,C# 驱动用的是samus,也就是上文中介绍的第一种. 引入项目MongoDB.dll //创建Mongo连接 var mongo = new Mongo(&qu ...

  3. swift开发之 -- 自动轮播图(UIScrollView+UIPageControl+Timer)

    比较简单,原理就不说了,这里只做记录: 代码如下: 1,准备 var pageControl:UIPageControl? var myscrollView:UIScrollView? var myT ...

  4. 批量执行命令:fabric

    Fabric 可以通过 SSH 在多台客户端主机上批量执行任务,是基于 paramiko 封装开发的,paramiko 更底层一些,安装方法如下: [root@localhost ~]$ yum in ...

  5. 最简单的VS-Qt-CMake项目框架

    使用qtcreator新建一个空工程,可以得到main.cpp,mainwindow.cpp,mainwindow.h和mainwindow.ui四个文件 下面主要介绍CMakeLists.txt的内 ...

  6. Unity随机Prefab,自动前往某点处理

    对与U3D  AI,看了下,自己做了小功能,以备后用啊! 一,在某区域随机产生某个对象 C# 文件名称为RadomAPoint.cs using UnityEngine; using System.C ...

  7. [SQL]躺着也中枪的datetime类型

    写在前面 本来这个东西,我是不想在这里总结的,今天有初学者的朋友问我了,那就不得不说说了,你肯定也踩过这样的坑,没遇到,说明你运气好,编码习惯好.那还是言归正传吧.避免你中枪,还是扫一眼这篇文章吧. ...

  8. 浅谈Nutch插件机制(含开发实例)

    plugin(插件)为nutch提供了一些功能强大的部件,举个例子,HtmlParser就是使用比较普遍的用来分析nutch抓取的html文件的插件. 为什么nutch要使用这样的plugin系统? ...

  9. HTML 解析

    xml,json都有大量的库来解析,我们如何解析html呢? TFHpple是一个小型的封装,可以用来解析html,它是对libxml的封装,语法是xpath.今天我看到一个直接用libxml来解析h ...

  10. 日记整理---->2016-11-01

    这里我们整理一下项目的流程,一般来说做一个模块之前.会有需求文档.页面原型和接口文档. 一. js获取radio的值 页面的html代码: <ul class="list-group& ...