go modules——HelloWorld示例
go modules——HelloWorld示例
go modules 存在的意义是方便代码的共享(虽然这会使自己开发过程中有一些小小的麻烦)
开发第一步,创建一个github仓库,然后克隆到本地
首先创建一个github仓库
github.com/<username>/hello,这里我的仓库地址是:github.com/fudute/hello。然后在本地拉取远程仓库:
git clone https://github.com/fudute/hello.git
cd hello
创建一个module
go mod init github.com/fudute/hello
注意这里的后缀要和github的网址一致
这会在当前目录下创建一个go.mod文件,表示这是一个module。
然后创建一个文件hello.go:
package hello // Hello return "Hello World"
func Hello() string {
return "Hello World!"
}
和测试文件hello_test.go
func TestHello(t *testing.T) {
tests := []struct {
name string
want string
}{
{name: "test", want: "Hello world!"},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := Hello(); got != tt.want {
t.Errorf("Hello() = %v, want %v", got, tt.want)
}
})
}
}
现在进行测试:
> go test
PASS
ok example.com/hello 0.002s
说明功能没有问题,这时候就可以准备提交了。但是在提交之前,还存在一个版本问题
module的版本问题
版本的命名方式为
vMAJOR.MINOR.PATCH,有下面这些规则:- 当API发生向后不兼容的修改时,例如删除某个API函数,这时候需要修改MAJOR版本号
- 当API发生向后兼容的修改是,例如添加API函数,这时候需要修改MINOR版本号
- 当API没有发生修改,只是做了bug修复或者优化,这时候需要修改PATCH就可以
- v0版本是不稳定版本,这个阶段可能发生各种修改,是开发时的版本。如果觉得开发的已经足够完善,那么就可以提高到v1版本,表示这是一个相对稳定的版本。
将module push到github上
先提交当前目录下的文件:
git add *
git commit -m "my first module"
需要先给module添加一个版本标记,指定版本为 v0.1.0
git tag v0.1.0
然后push到github上
git push origin v0.1.0
创建另一个项目,使用之前的module
接下来在本地创建一个main module
mkdir main
cd main
go mod init main
创建文件main.go
package main import (
"fmt" "github.com/fudute/hello"
) func main() {
fmt.Println(hello.Hello())
}在这里导入了之前创建的module,路径是
github.com/fudute/hello,然后直接运行:> go run .
go: extracting github.com/fudute/hello v0.1.0
Hello World!
可以看到,golang会自动从github上拉取module,然后成功编译运行。
自动下载的module可以在
$GOPATH/pkg/mod目录下看到。
go modules——HelloWorld示例的更多相关文章
- torm入门(三)HelloWorld示例
一.配置开发环境 storm有两种操作模式: 本地模式和远程模式.使用本地模式的时候,你可以在你的本地机器上开发测试你的topology, 一切都在你的本地机器上模拟出来; 用远程模式的时候你提交的t ...
- Spring Boot 2.x 快速入门(下)HelloWorld示例详解
上篇 Spring Boot 2.x 快速入门(上)HelloWorld示例 进行了Sprint Boot的快速入门,以实际的示例代码来练手,总比光看书要强很多嘛,最好的就是边看.边写.边记.边展示. ...
- Storm入门(三)HelloWorld示例
一.配置开发环境 storm有两种操作模式: 本地模式和远程模式.使用本地模式的时候,你可以在你的本地机器上开发测试你的topology, 一切都在你的本地机器上模拟出来; 用远程模式的时候你提交的t ...
- TensorFlow入门,基本介绍,基本概念,计算图,pip安装,helloworld示例,实现简单的神经网络
TensorFlow入门,基本介绍,基本概念,计算图,pip安装,helloworld示例,实现简单的神经网络
- Activiti Workflow HelloWorld 示例与测试环境搭建
作者:Rock 出处:http://www.ecmkit.com/zh-hans/2012/03/21/activiti-workflow-hell Activiti Workflow HelloWo ...
- IDEA+Maven+Spring MVC HelloWorld示例
用Maven创建Web项目 选择webapp模板 创建成功后点Enable Auto-Import idea给我们创建出来的结构是这样的,这还不标准,需要自己修改. 在main文件夹下创建java文件 ...
- Spring Boot 2.x 快速入门(上)HelloWorld示例
本文重点 最近决定重新实践下Spring Boot的知识体系,因为在项目中遇到的总是根据业务需求走的知识点,并不能覆盖Spring Boot完整的知识体系,甚至没有一个完整的实践去实践某个知识点.最好 ...
- CC2650LaunchPad 运行contiki hello-world示例程序
最近做毕设,开始接触contiki. 下载并运行Instant Contiki 3.0 这是官方制作的虚拟机镜像,直接用vmware等工具就可以运行. 从这里下载. 下载并解压后,用vmware运行. ...
- Node.js实战(二)之HelloWorld示例
经过前面的Node.js实战(一)之概述 想必你应该对Node.js的概念.应用场景.优缺点等有个大致的了解,同时你本地Windows或者Linux上已经准备好了Node.js环境. 下面我们来进入每 ...
随机推荐
- Memcached与Redis对比及其优劣分析
国外讨论 本文主要总结缓存Redis和Memcached的区别,总结之前先参考外国知乎上的一篇问答:<Is memcached a dinosaur in comparison to Redis ...
- 阿里云 Redis 开发规范
阿里云Redis开发规范-阿里云开发者社区 https://developer.aliyun.com/article/531067 https://mp.weixin.qq.com/s/UWE1Kx6 ...
- (002)每日SQL学习:删除名称重复的数据
create table A ( id VARCHAR2(36), name VARCHAR2(100), sl VARCHAR2(36) ); insert all into a (id,name) ...
- 逃逸分析与栈、堆分配分析 escape_analysis
小结: 1.当形参为 interface 类型时,在编译阶段编译器无法确定其具体的类型.因此会产生逃逸,最终分配到堆上. 2.The construction of a value doesn't d ...
- list里放map list 放list
Map<String,Integer> hashMap = new HashMap<String, Integer>(); Map<String,Integer> ...
- is == id ,编码
一. id 查询内存地址. # name = 'alex' # print(id(name)) # name1 = 'alex' # name2 = 'alex' # print(name1 == n ...
- AutoMapper源码解析
研究AutoMapper源码前,我们先来看一下AutoMapper的作用 官网解释:AutoMapper是一个简单的小程序库,旨在解决看似复杂的问题-摆脱将一个对象映射到另一个对象的代码 解释 首先一 ...
- codeblocks下载安装及快捷键
100MB的下载链接:自带mingw http://pan.baidu.com/s/1o6BgFP4 13.12版本 gcc 4.7.1的 这是windows版本的 linux下编译安装:参考: ...
- linux学习之---在linux服务器上跑一段Java代码
经常在windows上进行开发,有时候,需要在Linux环境上跑一些程序测下代码,要怎么办才好嘞? 假设你对Java常用命令和linux常用命令已经基本熟悉,就可以直接按照以下步骤来啦,默认linux ...
- 使用Observer实现HBase到Elasticsearch的数据同步
最近在公司做统一日志收集处理平台,技术选型肯定要选择elasticsearch,因为可以快速检索系统日志,日志问题排查及功业务链调用可以被快速检索,公司各个应用的日志有些字段比如说content是不需 ...