GOPATH는 Go 언어에서 사용되는 환경 변수로, Golang 프로젝트 코드가 저장되는 파일 경로인 프로젝트의 작업 디렉터리(작업 공간이라고도 함)를 제공하기 위해 절대 경로를 사용합니다. GOPATH 디렉토리는 일반적으로 다음과 같습니다. 1. 컴파일로 생성된 바이너리 파일을 저장하는 bin 2. XX_amd64, mod 및 sumdb 세 폴더를 포함하는 pkg 3. golang 프로젝트 코드가 저장되는 src.
이 튜토리얼의 운영 환경: Windows 7 시스템, GO 버전 1.18, Dell G3 컴퓨터.
GOPATH는 Go 언어에서 사용되는 환경 변수로, 프로젝트의 작업 디렉터리(작업 공간이라고도 함)를 제공합니다. Golang 프로젝트 코드가 저장되는 파일 경로, GOPATH는 대량의 Go 언어 소스 코드와 여러 패키지로 구성된 복잡한 프로젝트를 처리하는 데 적합합니다. 작업 디렉토리는 엔지니어링 개발을 위한 상대적 참조 디렉토리입니다. 예를 들어 회사에서 서버 코드 세트를 작성하려는 경우 워크스테이션에 포함된 데스크탑, 컴퓨터 및 의자가 작업 공간입니다.
작업 공간의 개념은 작업 디렉토리의 개념과 유사합니다. 작업 디렉터리 개념을 사용하지 않으면 여러 사람이 개발할 때 모두가 자신의 디렉터리 구조를 갖게 되며 구성 파일을 읽는 위치가 균일하지 않습니다.
2. GOPATH 사용GOPATH
目录一般为:
1、bin 存放编译生成的二进制文件。比如 执行命令 go get github.com/google/gops,bin目录会生成 gops 的二进制文件。
2、pkg 其中pkg下面以下三个文件夹。
- XX_amd64: 其中 XX 是目标操作系统,比如 mac 系统对应的是darwin_amd64, linux 系统对应的是 linux_amd64,存放的是.a结尾的文件。
- mod: 当开启go Modules 模式下,go get命令缓存下依赖包存放的位置
- sumdb: go get命令缓存下载的checksum数据存放的位
3、src 存放golang项目代码的位置
如下是一个完整的Go项目的开发目录:
my-go // my-go为GOPATH目录 -- bin -- myApp1 // 编译生成 -- myApp2 // 编译生成 -- myApp3 // 编译生成 -- pkg 依赖包编译后的*.a文件// -- src -- MyApp1 // 项目1 -- models -- controllers -- others -- main.go -- MyApp2 // 项目2 -- models -- controllers -- others -- main.go
在使用 GOPATH 模式下,我们需要将应用代码存放在固定的$GOPATH/src
目录下,且如果执行go get
使用第三方类库的时候会自动下载并安装到$GOPATH
1입니다. bin은 컴파일로 생성된 바이너리 파일을 저장합니다. 예를 들어 go get github.com/google/gops 명령을 실행하면 bin 디렉터리에 gops의 바이너리 파일이 생성됩니다.
프로젝트의 Golang 코드는 타사 Golang 파일과 혼합되어 있습니다.sumdb: go get 명령 캐시에서 다운로드한 체크섬 데이터가 저장되는 위치
고정된- 3. src 저장소 golang 프로젝트코드 위치
- 다음은 전체 Go 프로젝트의 개발 디렉터리입니다: rrreee
- Three. 문제 발생
GOPATH 사용 모드에서는$GOPATH/src
디렉터리에 애플리케이션 코드를 저장해야 하며,go get 타사 라이브러리를 사용하면 자동으로 다운로드되어 <code>$GOPATH
디렉터리에 설치됩니다.
각 프로젝트에 동일한 종속성이 필요한 경우 다양한 GoPath 소스에 다수의 중복된 타사 종속성 패키지가 다운로드되며 이는 공간도 차지합니다. . 디스크 공간이 크다
GOPATH의 단점디렉토리를 지정해야 하며,
이므로 일관된 타사 버전 번호를 동기화할 수 없습니다. Go 애플리케이션을 실행할 때 다른 사람들이 귀하가 의존할 것으로 예상하는 타사 라이브러리와 동일한 버전을 사용할 것이라는 보장은 없습니다.
🎜🎜우리는 프로젝트마다 다른 GoPath를 설정했습니다. 장점은 매우 분명합니다. 🎜🎜🎜 프로젝트마다 다른 GoPath가 있으므로 여러 Golang 처리가 가능합니다. 프로젝트 구조. 모든 프로젝트를 동일한 GoPath src 패키지에 넣으면 프로젝트 구조가 매우 혼란스럽고 관리하기 어려워집니다. 🎜🎜🎜그러나 타사 패키지에 의존해야 하는 경우 프로젝트마다 다른 GoPath를 설정하는 것의 단점도 매우 분명합니다. 🎜🎜🎜🎜🎜타사 종속 패키지가 자체 Golang 패키지와 혼합되면 프로젝트 파일 관리로 인해 특정 문제가 발생하게 됩니다. 🎜🎜🎜🎜 다양한 GoPath는 종속성을 다운로드해야 하므로 디스크에 중복된 종속성이 많아 디스크 공간을 많이 차지하게 됩니다. 🎜🎜🎜🎜🎜🎜그래서 중복 종속성 문제를 해결하기 위해 GoPath 디렉터리를 설정하고, 서로 다른 GoPath 디렉터리를 설정하고, Golang 프로젝트 구조가 혼란스러운 문제를 해결하는 것은 그 자체로 논란의 여지가 있는 문제입니다. 🎜🎜🎜이 모든 문제를 해결하기 위해 Golang은 마침내 GoModule이라는 개념을 도입했습니다.
【관련 추천: Go 비디오 튜토리얼, 프로그래밍 교육】
위 내용은 바둑 언어 GOPATH란 무엇인가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!