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. 实例教程Unity3D单例模式(二)自我包括法

    unity3d 里的单例模式自我包括法 有一次玩Trench Run game,我意识到我的场景类里存在很多的GameObject.所以,我开发了自我包括的单例.假设没找找到实例,就会创建它自己的Ga ...

  2. Eclipse+PyDev搭建Python开发环境(Windows篇)

    1.Python安装,并设置环境变量 2.python for eclipse插件安装 下载pydev 下载地址:http://www.pydev.org/download.html

  3. SPI接口功能描述

  4. 如何快速入门单片机C语言

    一.为什么要学单片机技术? 传统的电子产品升级改造成智能化的电子产品需要用到单片机技术.也就是说传统的电子产品如电视机.电子表.计算器.数码相机.手机.MP3.遥控器.洗衣机等产品智能化.微型化,需要 ...

  5. java基础---->多线程之Runnable(一)

    java线程的创建有两种方式,这里我们通过简单的实例来学习一下.一切都明明白白,但我们仍匆匆错过,因为你相信命运,因为我怀疑生活. java中多线程的创建 一.通过继承Thread类来创建多线程 pu ...

  6. JS-【同页面多次调用】轮播特效封装-json传多个参数

    看着传那么一长串的参数神烦,继续深化!——json传参: html: <div class="scrollBanner"> <ul class="ban ...

  7. [SQL] MSSQL update 语句中的关联

    将tableA 表中的所有title 用tableB中的titlename 更新掉,如果tableB中存在对应的关系 update tableA as a set a.title = (select ...

  8. R的替换sub和gsub

    sub(pattern, replacement, x, ignore.case = FALSE, perl = FALSE, fixed = FALSE, useBytes = FALSE) gsu ...

  9. 学习c++的50条忠告(转自C++百度贴吧)

    1.把C++当成一门新的语言学习(和C没啥关系!真的.): 2.看<Thinking In C++>,不要看<C++变成死相>: 3.看<The C++ Programm ...

  10. VMware Fusion 5虚拟机怎样与MAC共享文件

    刚刚在Macbook Pro中安装了VMware Fusion 5虚拟机,虚拟机里装了Windows7,在虚拟机的设置里也设置了共享MAC的几个文件夹,以便与MAC交换文件,但是在Windows7里怎 ...