IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> Go学习:生成文档和实例代码 -> 正文阅读

[Java知识库]Go学习:生成文档和实例代码

文档

package queue

type Queue []int

func (queue *Queue) Push(val int) {
	*queue = append(*queue, val)
}

func (queue *Queue) Pop() int {
	popVal := (*queue)[0]
	*queue = (*queue)[1:]
	return popVal
}

func (queue *Queue) IsEmpty() bool {
	return len(*queue) == 0
}

  • 对上面的代码生成文档进行查看;我们主要使用到的是godoc命令
  • go 1.13版本后移除了godoc相关的一些命令,因此需要手动安装
    • 第一步配置相关代理

      go env -w GO111MODULE=on
      go env -w GOPROXY="https://goproxy.io,direct"
      
    • 第二步命令行输入,安装godoc

      go get golang.org/x/tools/cmd/godoc
      

在这里插入图片描述
在这里插入图片描述

  • 使用命令生成文档;我们自己写的程序也会挂在这个文档上面
    在这里插入图片描述

  • 现在一行注释都没有写,所以现在是没有文档的

package queue

// 一个FIFO(先进先出)的队列
type Queue []int

// 向队列尾部添加元素
func (queue *Queue) Push(val int) {
	*queue = append(*queue, val)
}

// 弹出头部元素
func (queue *Queue) Pop() int {
	popVal := (*queue)[0]
	*queue = (*queue)[1:]
	return popVal
}

// 判断队列是否为空
func (queue *Queue) IsEmpty() bool {
	return len(*queue) == 0
}

  • 随便写一点注释;重新生成文档
    在这里插入图片描述
    在这里插入图片描述
  • 再go语言中,我们可以随意的写注释,不想java或者其他的语言,即使是注释也有自己比较复杂的语法

示例代码

package queue

import "fmt"

func ExampleQueue_Push() {
	queue := Queue{1}
	queue.Push(2)
	queue.Push(3)
	fmt.Println(queue.Pop())
	fmt.Println(queue.Pop())
	fmt.Println(queue.IsEmpty())
	fmt.Println(queue.Pop())
	fmt.Println(queue.IsEmpty())
}

在这里插入图片描述
我们执行代码的时候没有输出我们想要的结果,返回的却是testing: warning: no tests to run

package queue

import "fmt"

func ExampleQueue_Push() {
	queue := Queue{1}
	queue.Push(2)
	queue.Push(3)
	fmt.Println(queue.Pop())
	fmt.Println(queue.Pop())
	fmt.Println(queue.IsEmpty())
	fmt.Println(queue.Pop())
	fmt.Println(queue.IsEmpty())

	// OutPut:
	// 1
	// 2
	// false
	// 3
	// true
}

  • 使用OutPut:把结果都注释再代码下面;就可以正常输出了
    在这里插入图片描述
  • 故意写错一个答案试一下
package queue

import "fmt"

func ExampleQueue_Push() {
	queue := Queue{1}
	queue.Push(2)
	queue.Push(3)
	fmt.Println(queue.Pop())
	fmt.Println(queue.Pop())
	fmt.Println(queue.IsEmpty())
	fmt.Println(queue.Pop())
	fmt.Println(queue.IsEmpty())

	// OutPut:
	// 1
	// 2
	// fals
	// 3
	// true
}

在这里插入图片描述

go语言的示例代码,不仅可以执行;而且还会检查一下你的期望值是否跟结果一样;如果不一样会有反馈;示例代码也可以作为测试,但是不仅仅是测试;还可以作为用户的example

文档&示例代码

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 用注释写文档
  • 再测试中加入Example
  • 使用go doc/godoc来查看/生成文档
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-03-13 21:36:26  更:2022-03-13 21:36:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 9:07:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码