Golang项目目录结构组织

其实golang的工程管理还是挺简单的,完全使用目录结构还有package名来推导工程结构和构建顺序。

当然,首先要说的是环境变量$GOPATH,项目构建全靠它。这么说吧,想要构建一个项目,就要将这个项目添加到$GOPATH中,多个项目用";"分隔。

Golang项目目录下一般有三个子目录:

  • src存放源代码
  • pkg编译后生成的文件
  • bin编译后生成的可执行文件

我们重点要关注的其实就是src文件夹中的目录结构。

举个例子比啥都强,目录结构如下:

<proj>
   |--<src>
       |--<a>
           |--<a1>
               |--al.go
           |--<a2>
               |--a2.go
       |--<b>
           |--b1.go
           |--b2.go
       |--<c>
           |--c.go
   |--<pkg>
   |--<bin>

各文件代码:

a1.go

 package a1

 import "fmt"
 
 func PrintA1(){
    fmt.Println("a/a1")
 }

a2.go

package a2
 
import "fmt"
 
func PrintA2(){
   fmt.Println("a/a2")
}

b1.go

package b

 import "fmt"
 
 func printB1(){
    fmt.Println("b.b1")
 }

b2.go

 package b
 
 import "fmt"
 
 func PrintB(){

    printB1()
    fmt.Println("b.b2")
 }

注意b1.go b2.go中的包并且是相同的,也就是说同一个目录下面只允许一个包

c.go

 package main
 
 import(
    "a/a1"
    "a/a2"
    "b"
 )
 func main(){
    a1.PrintA1()
    a2.PrintA2()
    b.PrintB()
 }

将proj加入$GOPATH:

在windows下有个问题要注意,就是中文路径问题,如果proj路径有中文,那么在编译的时候可能出问题,我被这个问题折磨了半个多小时,左右挑不出错,就是不能编译。

 

go build a/a1
go install a/a1
go build a/a2
go install a/a2
go build b
go install b

go build c
go install c

执行相关命令。

可以看到pkg文件夹下生成了,a文件夹、b.a,a文件夹下有a1.a、a2.a

bin文件夹下有c.exe(当然,在执行go build c的位置也存在c.exe)

运行下c.exe

可以看出,分门别类,非常清楚。

其实b文件夹下的两个.go文件完全可以合并成一个的,没有任何影响。

package中的名称最好与目录名一样,这样在import的时候直接import目录名就好了。如果两者不一致,例如上面的b1.go、b2.go里面的package是package bbbbb,则在c.go里import的时候要import "b",然后下面的b.PrintB(),则需要改为bbbbb.PrintB()

go项目的目录结构我感觉说得挺明白的了。

本文来自:博客园

感谢作者:ghgyj

查看原文:Golang项目目录结构组织

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。