Golang中处理import自定义包出错的问题

文章讲述了Go语言的环境变量GOROOT和GOPATH的用途,以及在Go1.11后引入的模块管理方式GO111MODULE。当GO111MODULE开启时,go命令行会使用模块而非GOPATH。错误提示表明代码未在正确路径下,解决方法包括使用go.mod文件来管理依赖。

could not import ......

方式1:使用GOPATH和GOROOT

命令行中输入 go env 查看系统变量

GOROOT:就是Go的安装目录,(类似于java的JDK),里面有bin目录

GOPATH:是我们的工作空间,保存go项目代码和第三方依赖包

GOPATH可以设置多个,其中,第一个将会是默认的包目录,使用go get下载的包都会在第一个path中的src目录下,使用go install时,在哪个GOPATH中找到了这个包,就会在哪个GOPATH下的bin目录生成可执行文件

使用GOPATH时,Go会在以下为目录中搜索包:

GOROOT/src:Go标准库

GOPATH/src:应用自身代码和第三方依赖的代码

引入包时,路径从src的下一级文件地址开始写,编译器会自动从src下开始引入

import (
	"fmt"
	util "demo02/utils"
)

发生错误

PS D:\Study\VScode\Goworkspace\src\Learning\chapter06\demo02\main> go run main.go	
main.go:4:2: cannot find package "demo02/utils" in any of:        
D:\Program\lang\Golang\src\demo02\utils (from $GOROOT)        
C:\Users\Stafen\go\src\demo02\utils (from $GOPATH)

从Go1.11版本之后,已经不再推荐使用GOPATH来构建应用了,

Go使用GOMODULE来管理程序文件。

这里错误的原因也是我没有在系统设置的目录下书写和保存代码,导致文件根本找不到。


方式2:使用go.mod

首先指定系统变量GO111MODULE=on

命令行中执行:go env -w GO111MODULE=on

GO111MODULE有三个值:off, on和auto(默认值)

GO111MODULE=off,go命令行将不会支持module功能,寻找依赖包的方式将会沿用旧版本那种通过vendor目录或者GOPATH模式来查找。

GO111MODULE=on,go命令行会使用modules,而一点也不会去GOPATH目录下查找。

GO111MODULE=auto,默认值,go命令行将会根据当前目录来决定是否启用module功能。这种情况下可以分为两种情形:

        1)当前目录在GOPATH/src之外且该目录包含go.mod文件

        2)当前文件在包含go.mod文件的目录下面。

步骤

1.进入项目路径下执行 go mod init + 模块名 命令,在项目文件下创建一个go.mod文件

2.引入自定义包时,路径应从go.mod所在的路径下写起

Golang中,`bufio.Scanner` 可以用于高效地按行读取输入,不过并没有 `TextIn` 这个标准库中的功能,如果是想实现高效输入,主要依靠 `bufio.Scanner` 。以下是使用 `bufio.Scanner` 实现高效输入的示例: ```go package main import ( "bufio" "fmt" "os" ) func main() { // 创建一个新的 Scanner 来从标准输入读取数据 scanner := bufio.NewScanner(os.Stdin) // 循环读取输入的每一行 for scanner.Scan() { // 获取当前行的文本内容 line := scanner.Text() // 处理读取到的行,这里简单打印出来 fmt.Println("读取到的行内容: ", line) } // 检查扫描过程中是否有错误 if err := scanner.Err(); err != nil { fmt.Fprintln(os.Stderr, "读取输入时出错:", err) } } ``` 在上述代码中,`bufio.NewScanner(os.Stdin)` 创建了一个从标准输入读取数据的 `Scanner` 对象。`scanner.Scan()` 会不断尝试读取下一行,直到没有更多输入或者出现错误。`scanner.Text()` 用于获取当前读取到的行的文本内容。 如果需要读取较大的行,可能会遇到 `token too long` 错误,因为 `bufio.Scanner` 默认的缓冲区大小为64KB。可以通过自定义缓冲区大小来解决这个问题,示例如下: ```go package main import ( "bufio" "fmt" "os" ) func main() { // 创建一个新的 Reader 从标准输入读取数据 reader := bufio.NewReader(os.Stdin) // 创建一个 Scanner 并使用自定义的 Reader scanner := bufio.NewScanner(reader) // 设置 Scanner 的最大容量 const maxCapacity = 1024 * 1024 // 1MB buf := make([]byte, 0, maxCapacity) scanner.Buffer(buf, maxCapacity) // 循环读取输入的每一行 for scanner.Scan() { // 获取当前行的文本内容 line := scanner.Text() // 处理读取到的行,这里简单打印出来 fmt.Println("读取到的行内容: ", line) } // 检查扫描过程中是否有错误 if err := scanner.Err(); err != nil { fmt.Fprintln(os.Stderr, "读取输入时出错:", err) } } ``` 通过 `scanner.Buffer` 方法可以设置 `Scanner` 的缓冲区大小,避免 `token too long` 错误。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值