1.环境搭建

news2024/11/28 22:42:01

1.Windows

系统GolangVisual Studio Code
Microsoft Windows (x86-64)go1.20.1.windows-amd64.msihttps://code.visualstudio.com/Download
Microsoft Windows (x86-i386)go1.20.1.windows-386.msihttps://code.visualstudio.com/Download
Microsoft Windows (ARM64)go1.20.1.windows-arm64.msihttps://code.visualstudio.com/Download

1.1.Golang

1.1.1.安装

  • 双击打开下载的安装包, 点击Next
    在这里插入图片描述
  • 接受许可协议, 点击Next
    在这里插入图片描述
  • 选择安装目录, 点击Next
    在这里插入图片描述
  • 进行安装, 点击Install
    在这里插入图片描述
    在这里插入图片描述
  • 安装完成, 点击Finish
    在这里插入图片描述

1.1.2.配置

  • 打开终端,进行配置

键盘按下: Win + R,输入cmd,点击确定,唤起终端

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

  • 创建工作目录

pushd d:进入指定目录D盘
pushd D:\ProgramData\Workspace\Go进入到指定目录

pushd d:
mkdir D:\ProgramData\Workspace\Go
pushd D:\ProgramData\Workspace\Go
mkdir bin pkg src
dir

在这里插入图片描述

  • 配置环境变量
变量名变量值说明
GOROOTD:\Program Files\GoGo安装位置
GOPATHD:\ProgramData\Workspace\GoGo工作目录,含有:1. src:项目源代码;2. pkg:依赖库;3. bin:可执行文件
GOBIND:\ProgramData\Workspace\Go\binGo编译运行可执行文件目录
GO111MODULEongo mod管理:on/auto/off
GOPROXYhttps://goproxy.io代理(特别是GO111MODULE配置为on或者auto后尤其重要)
Path ;%GOROOT%\bin;%GOPATH%\bin;%GOBIN%;%GOPROXY%可执行文件目录,追加到Path环境变量后

进入Windows的文件资源管理器,选择此电脑,鼠标右键单击,选择属性

在这里插入图片描述

进入系统>系统信息页面,点击 高级系统设置

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

进入 系统属性> 高级 页面,点击 环境变量

在这里插入图片描述

删除用户变量中有关Go的变量信息,用户变量中的Path变量内容可以双击打开进行编辑,确保用户变量中没有任何关于Go的信息

  • 新建系统变量GOROOT
    在这里插入图片描述

GOROOT必须是安装时候选择的Go的安装目录

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

  • 新建系统变量GOPATH
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 新建系统变量GOBIN
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 新建系统变量GO111MODULE
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 新建系统变量GOPROXY
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 追加新建的系统变量到Path后面
    在这里插入图片描述
    在这里插入图片描述

新建 %GOROOT%\bin

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

新建 %GOPATH%\bin

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

新建 %GOBIN%

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

新建 %GOPROXY%

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

点击确定

在这里插入图片描述

  • 环境变量 配置确定
    在这里插入图片描述

  • 系统属性> 高级配置 确定
    在这里插入图片描述

1.1.3.测试

  • 打开终端,进行配置

键盘按下: Win + R,输入cmd,点击确定,唤起终端

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

  • 查看环境
go env

在这里插入图片描述

  • 查看版本
go version

在这里插入图片描述

1.2.Visual Studio Code

1.2.1.安装

  • 双击打开下载的安装包
    在这里插入图片描述
    在这里插入图片描述

  • 接受许可协议,点击下一步
    在这里插入图片描述

  • 选择安装位置,点击下一步
    在这里插入图片描述

  • 点击下一步
    在这里插入图片描述

  • 选择附加任务,点击下一步
    在这里插入图片描述

  • 点击安装
    在这里插入图片描述
    在这里插入图片描述

  • 点击完成
    在这里插入图片描述
    在这里插入图片描述

1.2.2.插件

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

  • SSH

在这里插入图片描述

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

  • 终端设置 GO111MODULE和 GOPROXY 环境变量

go env -w GO111MODULE=on
go env -w GOPROXY=https://goproxy.io

在这里插入图片描述

  • 安装插件工具
Go:Install/Update Tools

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

  • koroFileHeader
    在这里插入图片描述

1.2.3.配置

  • 打开命令面板
    在这里插入图片描述

  • 打开用户设置JSON

Open User Settings JSON

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

  • 编辑用户配置JSON文件并保存
{
    // 当编辑器失去焦点时,自动保存具有更改的编辑器
    "files.autoSave": "onFocusChange",
    // 头部注释
    "fileheader.customMade": {
        // Author字段是文件的创建者 可以在specialOptions中更改特殊属性
        // 公司项目和个人项目可以配置不同的用户名与邮箱 搜索: gitconfig includeIf  比如: https://ayase.moe/2021/03/09/customized-git-config/
        // 自动提取当前git config中的: 用户名、邮箱
        "Author": "git config user.name && git config user.email", // 同时获取用户名与邮箱
        // "Author": "git config user.name", // 仅获取用户名
        // "Author": "git config user.email", // 仅获取邮箱
        // "Author": "OBKoro1", // 写死的固定值 不从git config中获取
        "Date": "Do not edit", // 文件创建时间(不变)
        // LastEditors、LastEditTime、FilePath将会自动更新 如果觉得时间更新的太频繁可以使用throttleTime(默认为1分钟)配置更改更新时间。
        "LastEditors": "git config user.name && git config user.email", // 文件最后编辑者 与Author字段一致
        // 由于编辑文件就会变更最后编辑时间,多人协作中合并的时候会导致merge
        // 可以将时间颗粒度改为周、或者月,这样冲突就减少很多。搜索变更时间格式: dateFormat
        "LastEditTime": "Do not edit", // 文件最后编辑时间
        // 输出相对路径,类似: /文件夹名称/src/index.js
        "FilePath": "Do not edit", // 文件在项目中的相对路径 自动更新
        // 插件会自动将光标移动到Description选项中 方便输入 Description字段可以在specialOptions更改
        "Description": "", // 介绍文件的作用、文件的入参、出参。
        // custom_string_obkoro1~custom_string_obkoro100都可以输出自定义信息
        // 可以设置多条自定义信息 设置个性签名、留下QQ、微信联系方式、输入空行等
        "custom_string_obkoro1": "",
        // 版权声明 保留文件所有权利 自动替换年份 获取git配置的用户名和邮箱
        // 版权声明获取git配置, 与Author字段一致: ${git_name} ${git_email} ${git_name_email}
        "custom_string_obkoro1_copyright": "Copyright (c) ${now_year} by ${git_name_email}, All Rights Reserved. "
        // "custom_string_obkoro1_copyright": "Copyright (c) ${now_year} by 写死的公司名/用户名, All Rights Reserved. "
    },
    // 函数注释
    "fileheader.cursorMode": {
        "description": "", // 函数注释生成之后,光标移动到这里
        "param": "", // param 开启函数参数自动提取 需要将光标放在函数行或者函数上方的空白行
        "return": "",
    },
    // 插件配置项
    "fileheader.configObj": {
        "autoAdd": true, // 检测文件没有头部注释,自动添加文件头部注释
        "autoAddLine": 100, // 文件超过多少行数 不再自动添加头部注释
        "autoAlready": true, // 只添加插件支持的语言以及用户通过`language`选项自定义的注释
        "supportAutoLanguage": [], // 设置之后,在数组内的文件才支持自动添加
        // 自动添加头部注释黑名单
        "prohibitAutoAdd": [
            "json"
        ],
        "prohibitItemAutoAdd": [
            "项目的全称禁止项目自动添加头部注释, 使用快捷键自行添加"
        ],
        "folderBlacklist": [
            "node_modules"
        ], // 文件夹或文件名禁止自动添加头部注释
        "wideSame": false, // 头部注释等宽设置
        "wideNum": 13, // 头部注释字段长度 默认为13
        "functionWideNum": 0, // 函数注释等宽设置 设为0 即为关闭
        // 头部注释第几行插入
        "headInsertLine": {
            "php": 2 // php文件 插入到第二行
        },
        "beforeAnnotation": {}, // 头部注释之前插入内容
        "afterAnnotation": {}, // 头部注释之后插入内容
        "specialOptions": {}, // 特殊字段自定义 比如: Author、LastEditTime、LastEditors、FilePath、Description、Date等
        "switch": {
            "newlineAddAnnotation": true // 默认遇到换行符(\r\n \n \r)添加注释符号
        },
        "moveCursor": true, // 自动移动光标到Description所在行
        "dateFormat": "YYYY-MM-DD HH:mm:ss",
        "atSymbol": [
            "@",
            "@"
        ], // 更改所有文件的自定义注释中的@符号
        "atSymbolObj": {}, //  更改单独语言/文件的@
        "colon": [
            ": ",
            ": "
        ], // 更改所有文件的注释冒号
        "colonObj": {}, //  更改单独语言/文件的冒号
        "filePathColon": "路径分隔符替换", // 默认值: mac: / window是: \
        "showErrorMessage": false, // 是否显示插件错误通知 用于debugger
        "writeLog": false, // 错误日志生成
        "CheckFileChange": false, // 单个文件保存时进行diff检查
        "createHeader": false, // 新建文件自动添加头部注释
        "useWorker": false, // 是否使用工作区设置
        "designAddHead": false, // 添加注释图案时添加头部注释
        "headDesignName": "random", // 图案注释使用哪个图案 
        "headDesign": false, // 是否使用图案注释替换头部注释
        // 自定义配置是否在函数内生成注释 不同文件类型和语言类型
        "cursorModeInternalAll": {}, // 默认为false 在函数外生成函数注释
        "openFunctionParamsCheck": true, // 开启关闭自动提取添加函数参数
        "functionParamsShape": [
            "{",
            "}"
        ], // 函数参数外形自定义 
        // "functionParamsShape": "no type" 函数参数不需要类型
        "functionBlankSpaceAll": {}, // 函数注释空格缩进 默认为空对象 默认值为0 不缩进
        "functionTypeSymbol": "*", // 参数没有类型时的默认值
        "typeParamOrder": "type param", // 参数类型 和 参数的位置自定义
        "NoMatchParams": "no show param", // 没匹配到函数参数,是否显示@param与@return这两行 默认不显示param
        "functionParamAddStr": "", // 在 type param 后面增加字符串 可能是冒号,方便输入参数描述
        // 自定义语言注释,自定义取消 head、end 部分
        // 不设置自定义配置language无效 默认都有head、end
        "customHasHeadEnd": {}, // "cancel head and function" | "cancel head" | "cancel function" 
        "throttleTime": 60000, // 对同一个文件 需要过1分钟再次修改文件并保存才会更新注释
        // 自定义语言注释符号,覆盖插件的注释格式
        "language": {
            // js后缀文件
            "js": {
                "head": "/$$",
                "middle": " $ @",
                "end": " $/",
                // 函数自定义注释符号:如果有此配置 会默认使用
                "functionSymbol": {
                    "head": "/******* ", // 统一增加几个*号
                    "middle": " * @",
                    "end": " */"
                },
                "functionParams": "typescript" // 函数注释使用ts语言的解析逻辑
            },
            // 一次匹配多种文件后缀文件 不用重复设置
            "h/hpp/cpp": {
                "head": "/*** ", // 统一增加几个*号
                "middle": " * @",
                "end": " */"
            },
            // 针对有特殊要求的文件如:test.blade.php
            "blade.php": {
                "head": "<!--",
                "middle": " * @",
                "end": "-->",
            }
        },
        // 默认注释  没有匹配到注释符号的时候使用。
        "annotationStr": {
            "head": "/*",
            "middle": " * @",
            "end": " */",
            "use": false
        },
    },
    // Golang 配置
    "go.toolsManagement.autoUpdate": true,
    "go.autocompleteUnimportedPackages": true,
    "go.gotoSymbol.includeImports": true,
    "go.gocodePackageLookupMode": "go",
    "go.docsTool": "godoc",
    // Golang test 测试执行一次,避免缓存多次效果相同
    "go.testFlags": [
        "-v",
        "-count=1"
    ]
}

1.2.4.测试

  • 打开终端,新建项目
pushd D:\ProgramData\Workspace\Go\src
mkdir test
pushd D:\ProgramData\Workspace\Go\src\test
go mod init

在这里插入图片描述

  • 打开项目文件夹

环境变量%GOPATH%对应的/src/test文件夹

在这里插入图片描述

  • 创建main.go
package main

import "fmt"

func main() {
	fmt.Println("hello")
}
  • 打开终端,运行测试
go run main.go

在这里插入图片描述

2.macOS

系统GolangVisual Studio Code
Apple macOS (x86-64)go1.20.1.darwin-amd64.pkghttps://code.visualstudio.com/Download
Apple macOS (ARM64)go1.20.1.darwin-arm64.pkghttps://code.visualstudio.com/Download

2.1.Golang

2.1.1.安装

  • 双击打开下载的安装包, 点击继续
    在这里插入图片描述

  • 点击安装
    在这里插入图片描述

  • 授权安装
    在这里插入图片描述
    在这里插入图片描述

  • 安装完成,点击关闭即可
    在这里插入图片描述

2.1.2.配置

打开终端,进行配置

  • 创建工作目录
cd ~
mkdir -p ~/Workspace/Go/{bin,pkg,src}
  • 配置环境变量
cd ~
touch .zshenv
cat >> .zshenv<<EOF
export GOROOT=/usr/local/go
export GOPATH=~/Workspace/Go
export GOBIN=~/Workspace/Go/bin
export GO111MODULE="on"
export GOPROXY=https://goproxy.io
export PATH=$PATH:$GOROOT/bin:$GOPATH:$GOBIN:$GOPROXY
EOF
source .zshenv

2.1.3.测试

  • 查看环境
go env

在这里插入图片描述

  • 查看版本
go version

在这里插入图片描述

2.2.Visual Studio Code

2.2.1.安装

  • 双击解压压缩包
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

将应用程序文件移动(拖拽)到 应用程序目录下

在这里插入图片描述

  • 在启动台可以看到安装的程序
    在这里插入图片描述

  • 打开应用程序, 点击打开
    在这里插入图片描述
    在这里插入图片描述

2.2.2.插件

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

  • SSH
    在这里插入图片描述

  • Go
    在这里插入图片描述

  • 终端设置 GO111MODULEGOPROXY 环境变量

go env -w GO111MODULE=on
go env -w GOPROXY=https://goproxy.io

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

  • 安装插件工具
Go:Install/Update Tools

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

  • koroFileHeader
    在这里插入图片描述

2.2.3.配置

  • 打开命令面板
    在这里插入图片描述

  • 打开用户设置JSON

Open User Settings JSON

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

  • 编辑用户配置JSON文件并保存
{
    // 当编辑器失去焦点时,自动保存具有更改的编辑器
    "files.autoSave": "onFocusChange",
    // 头部注释
    "fileheader.customMade": {
        // Author字段是文件的创建者 可以在specialOptions中更改特殊属性
        // 公司项目和个人项目可以配置不同的用户名与邮箱 搜索: gitconfig includeIf  比如: https://ayase.moe/2021/03/09/customized-git-config/
        // 自动提取当前git config中的: 用户名、邮箱
        "Author": "git config user.name && git config user.email", // 同时获取用户名与邮箱
        // "Author": "git config user.name", // 仅获取用户名
        // "Author": "git config user.email", // 仅获取邮箱
        // "Author": "OBKoro1", // 写死的固定值 不从git config中获取
        "Date": "Do not edit", // 文件创建时间(不变)
        // LastEditors、LastEditTime、FilePath将会自动更新 如果觉得时间更新的太频繁可以使用throttleTime(默认为1分钟)配置更改更新时间。
        "LastEditors": "git config user.name && git config user.email", // 文件最后编辑者 与Author字段一致
        // 由于编辑文件就会变更最后编辑时间,多人协作中合并的时候会导致merge
        // 可以将时间颗粒度改为周、或者月,这样冲突就减少很多。搜索变更时间格式: dateFormat
        "LastEditTime": "Do not edit", // 文件最后编辑时间
        // 输出相对路径,类似: /文件夹名称/src/index.js
        "FilePath": "Do not edit", // 文件在项目中的相对路径 自动更新
        // 插件会自动将光标移动到Description选项中 方便输入 Description字段可以在specialOptions更改
        "Description": "", // 介绍文件的作用、文件的入参、出参。
        // custom_string_obkoro1~custom_string_obkoro100都可以输出自定义信息
        // 可以设置多条自定义信息 设置个性签名、留下QQ、微信联系方式、输入空行等
        "custom_string_obkoro1": "",
        // 版权声明 保留文件所有权利 自动替换年份 获取git配置的用户名和邮箱
        // 版权声明获取git配置, 与Author字段一致: ${git_name} ${git_email} ${git_name_email}
        "custom_string_obkoro1_copyright": "Copyright (c) ${now_year} by ${git_name_email}, All Rights Reserved. "
        // "custom_string_obkoro1_copyright": "Copyright (c) ${now_year} by 写死的公司名/用户名, All Rights Reserved. "
    },
    // 函数注释
    "fileheader.cursorMode": {
        "description": "", // 函数注释生成之后,光标移动到这里
        "param": "", // param 开启函数参数自动提取 需要将光标放在函数行或者函数上方的空白行
        "return": "",
    },
    // 插件配置项
    "fileheader.configObj": {
        "autoAdd": true, // 检测文件没有头部注释,自动添加文件头部注释
        "autoAddLine": 100, // 文件超过多少行数 不再自动添加头部注释
        "autoAlready": true, // 只添加插件支持的语言以及用户通过`language`选项自定义的注释
        "supportAutoLanguage": [], // 设置之后,在数组内的文件才支持自动添加
        // 自动添加头部注释黑名单
        "prohibitAutoAdd": [
            "json"
        ],
        "prohibitItemAutoAdd": [
            "项目的全称禁止项目自动添加头部注释, 使用快捷键自行添加"
        ],
        "folderBlacklist": [
            "node_modules"
        ], // 文件夹或文件名禁止自动添加头部注释
        "wideSame": false, // 头部注释等宽设置
        "wideNum": 13, // 头部注释字段长度 默认为13
        "functionWideNum": 0, // 函数注释等宽设置 设为0 即为关闭
        // 头部注释第几行插入
        "headInsertLine": {
            "php": 2 // php文件 插入到第二行
        },
        "beforeAnnotation": {}, // 头部注释之前插入内容
        "afterAnnotation": {}, // 头部注释之后插入内容
        "specialOptions": {}, // 特殊字段自定义 比如: Author、LastEditTime、LastEditors、FilePath、Description、Date等
        "switch": {
            "newlineAddAnnotation": true // 默认遇到换行符(\r\n \n \r)添加注释符号
        },
        "moveCursor": true, // 自动移动光标到Description所在行
        "dateFormat": "YYYY-MM-DD HH:mm:ss",
        "atSymbol": [
            "@",
            "@"
        ], // 更改所有文件的自定义注释中的@符号
        "atSymbolObj": {}, //  更改单独语言/文件的@
        "colon": [
            ": ",
            ": "
        ], // 更改所有文件的注释冒号
        "colonObj": {}, //  更改单独语言/文件的冒号
        "filePathColon": "路径分隔符替换", // 默认值: mac: / window是: \
        "showErrorMessage": false, // 是否显示插件错误通知 用于debugger
        "writeLog": false, // 错误日志生成
        "CheckFileChange": false, // 单个文件保存时进行diff检查
        "createHeader": false, // 新建文件自动添加头部注释
        "useWorker": false, // 是否使用工作区设置
        "designAddHead": false, // 添加注释图案时添加头部注释
        "headDesignName": "random", // 图案注释使用哪个图案 
        "headDesign": false, // 是否使用图案注释替换头部注释
        // 自定义配置是否在函数内生成注释 不同文件类型和语言类型
        "cursorModeInternalAll": {}, // 默认为false 在函数外生成函数注释
        "openFunctionParamsCheck": true, // 开启关闭自动提取添加函数参数
        "functionParamsShape": [
            "{",
            "}"
        ], // 函数参数外形自定义 
        // "functionParamsShape": "no type" 函数参数不需要类型
        "functionBlankSpaceAll": {}, // 函数注释空格缩进 默认为空对象 默认值为0 不缩进
        "functionTypeSymbol": "*", // 参数没有类型时的默认值
        "typeParamOrder": "type param", // 参数类型 和 参数的位置自定义
        "NoMatchParams": "no show param", // 没匹配到函数参数,是否显示@param与@return这两行 默认不显示param
        "functionParamAddStr": "", // 在 type param 后面增加字符串 可能是冒号,方便输入参数描述
        // 自定义语言注释,自定义取消 head、end 部分
        // 不设置自定义配置language无效 默认都有head、end
        "customHasHeadEnd": {}, // "cancel head and function" | "cancel head" | "cancel function" 
        "throttleTime": 60000, // 对同一个文件 需要过1分钟再次修改文件并保存才会更新注释
        // 自定义语言注释符号,覆盖插件的注释格式
        "language": {
            // js后缀文件
            "js": {
                "head": "/$$",
                "middle": " $ @",
                "end": " $/",
                // 函数自定义注释符号:如果有此配置 会默认使用
                "functionSymbol": {
                    "head": "/******* ", // 统一增加几个*号
                    "middle": " * @",
                    "end": " */"
                },
                "functionParams": "typescript" // 函数注释使用ts语言的解析逻辑
            },
            // 一次匹配多种文件后缀文件 不用重复设置
            "h/hpp/cpp": {
                "head": "/*** ", // 统一增加几个*号
                "middle": " * @",
                "end": " */"
            },
            // 针对有特殊要求的文件如:test.blade.php
            "blade.php": {
                "head": "<!--",
                "middle": " * @",
                "end": "-->",
            }
        },
        // 默认注释  没有匹配到注释符号的时候使用。
        "annotationStr": {
            "head": "/*",
            "middle": " * @",
            "end": " */",
            "use": false
        },
    },
    // Golang 配置
    "go.toolsManagement.autoUpdate": true,
    "go.autocompleteUnimportedPackages": true,
    "go.gotoSymbol.includeImports": true,
    "go.gocodePackageLookupMode": "go",
    "go.docsTool": "godoc",
    // Golang test 测试执行一次,避免缓存多次效果相同
    "go.testFlags": [
        "-v",
        "-count=1"
    ]
}

2.2.4.测试

  • 打开终端,新建项目
mkdir -p $GOPATH/src/test && cd $_
go mod init

在这里插入图片描述

  • 打开项目文件夹

环境变量$GOPATH对应的/src/test文件夹

在这里插入图片描述

  • 创建main.go
package main

import "fmt"

func main() {
	fmt.Println("hello")
}
  • 打开终端,运行测试
go run main.go

在这里插入图片描述

3.Linux

系统GolangVisual Studio Code
Linux (x86-64)go1.20.1.linux-amd64.tar.gzhttps://code.visualstudio.com/Download
Linux (x86-i386)go1.20.1.linux-386.tar.gzhttps://code.visualstudio.com/Download
Linux (ARM64)go1.20.1.linux-arm64.tar.gzhttps://code.visualstudio.com/Download

3.1.Golang

3.1.1.安装

  • 安装安装必备工具
sudo yum -y install wget tar
  • 下载安装包
wget --no-check-certificate -c -O go1.20.1.linux-amd64.tar.gz https://go.dev/dl/go1.20.1.linux-amd64.tar.gz && ls -la |grep "go1.20.1.linux-amd64.tar.gz"
  • 解压到指定目录
sudo tar -zxf go1.20.1.linux-amd64.tar.gz -C /usr/local/ && ls /usr/local/ | grep go
  • 删除安装包
rm -rf go1.20.1.linux-amd64.tar.gz

3.1.2.配置

● 创建工作目录

mkdir -p ~/Workspace/Go/{bin,pkg,src} && ls -la ~/Workspace/Go/
  • 配置环境变量
sudo tee -a /etc/profile<<-'EOF'
export GOROOT=/usr/local/go
export GOPATH=~/Workspace/Go
export GOBIN=~/Workspace/Go/bin
export GO111MODULE="on"
export GOPROXY=https://goproxy.io
export PATH=$PATH:$GOROOT/bin:$GOPATH/bin:$GOBIN:$GOPROXY
EOF
source /etc/profile

3.1.3.测试

  • 查看环境
go env
  • 查看版本
go version

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/524184.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《疯狂Java讲义》读书笔记4

初始化块 是构造器的补充&#xff0c;在构造器之前执行。 是一段固定的代码&#xff0c;不接受任何参数。 构造器其实是一个假象&#xff0c;编译Java类后&#xff0c;初始化块会消失&#xff0c;当中的代码被还原到构造器中&#xff0c;且位于构造器前面。 静态初始化块 用…

springboot+vue家政服务管理平台(源码+文档)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的家政服务管理平台。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 &#x1f495;&#x1f495;作者&#xff1a;风…

R语言相关系数的可视化

R相关系数的可视化 文章目录 R相关系数的可视化[toc]1、序列自相关2、序列偏自相关3、简单相关4、相关图可视化5、不同方法6、其他一些修饰 1、序列自相关 自相关是指同一时间序列在不同时间 t t t上取值的相关程度&#xff0c;假设时间序列 { X t } t 1 T \{X_t\}_{t1}^{T} …

电子电气架构——车载以太网防火墙

我是穿拖鞋的汉子,魔都中坚持长期主义的工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 本文主要分享关于车用基础软件的内核和中间件核心技术—虚拟化的典型应用案例。 车辆内部的以太网网络是一个相对封闭的环境,没有因特网那么复杂。由于车辆…

[LeetCode周赛复盘] 第 345 场周赛20230514

[LeetCode周赛复盘] 第 345 场周赛20230514 一、本周周赛总结6430. 找出转圈游戏输家1. 题目描述2. 思路分析3. 代码实现 6431. 相邻值的按位异或1. 题目描述2. 思路分析3. 代码实现 6433. 矩阵中移动的最大次数1. 题目描述2. 思路分析3. 代码实现 6432. 统计完全连通分量的数…

多核与多处理器的区别

一、定义 多核&#xff1a;单块CPU上面能处理数据的芯片组的数量&#xff0c;比如&#xff0c;双核就是包括2个相对独立的CPU核心单元组&#xff0c;四核就包含4个相对独立的CPU核心单元组。 多处理器&#xff1a;主板上实际插入的cpu数量&#xff0c;一般有两个或者多个处理…

AutoSar之DaVinci开发环境

文章目录 前言一、AutoSar架构简介二、开发环境组成1.DaVinci Developer2.DaVinci Configurator3.SIP 总结 前言 作为初学者&#xff0c;接触AutoSar的开发&#xff0c;除了需要掌握基本的AutoSar架构知识外&#xff0c;还需要熟悉设计和配置AutoSar的工具链。接下来我会以Vec…

ChatGPT在小红书文案实践

今天聊一聊ChatGPT在小红书这个实际应用场景的案例。ChatGPT 以较低的门槛提高了使用者创作水平&#xff0c;有较高的下限&#xff0c;但如何创造更高质量的内容就要依靠使用者在领域的能力和AI使用技巧&#xff0c;作者无任何小红书推广和文案写作经验&#xff0c;文章内容来自…

【MySQL】C语言连接数据库

在使用数据库的时候&#xff0c;我们是操作客户端方的&#xff0c;向服务器请求数据。MySQL的端口号-3306 连接mysql需要头文件&#xff1a;#include<mysql/mysql.h> 基础连接步骤&#xff1a; 1.创建连接句柄 MYSQL mysql_con;//连接句柄 2.初始化连接句柄mysql_i…

LabVIEWCompactRIO 开发指南18 使用网络流发送消息和命令

LabVIEWCompactRIO 开发指南18 使用网络流发送消息和命令 默认情况下&#xff0c;网络流旨在最大化吞吐量&#xff0c;但可以轻松实现它们以最大化发送命令或消息的低延迟。 为本部分提供LabVIEW示例代码 命令发送器体系结构 命令发送器是CompactRIO控制器必须响应的任何命…

如何构建“Buy Me a Coffee”DeFi dApp

&#x1f978; 本教程来自官网&#xff1a;https://docs.alchemy.com/docs。对原文部分内容进行了修改。教程中所有实例经过本人实践&#xff0c;代码可见&#xff1a;https://github.com/ChuXiaoYi/web3Study 区块链技术令人惊叹&#xff0c;因为它使我们能够使用代码和软件编…

【Linux初阶】进程地址空间 | CUP与可执行程序的交互原理

&#x1f31f;hello&#xff0c;各位读者大大们你们好呀&#x1f31f; &#x1f36d;&#x1f36d;系列专栏&#xff1a;【Linux初阶】 ✒️✒️本篇内容&#xff1a;计算机空间初识&#xff08;子进程变量修改实验&#xff09;&#xff0c;感性理解进程虚拟地址空间&#xff0…

Web自动化测试工具大对决:细致比较Selenium、Protractor和Cypress

目录 前言&#xff1a; Selenium Protractor Cypress 结论 Web自动化测试步骤结构图&#xff1a; 前言&#xff1a; 随着Web应用程序的广泛使用&#xff0c;Web自动化测试工具的需求也越来越高。Web自动化测试工具可以模拟用户在Web浏览器中的行为&#xff0c;并且可以快…

NICE-SLAM学习

NICE-SLAM简介&#xff1a; 是浙大和ETH提出的一种神经隐式SLAM方法主要创新点在于解决了基于传统nerf的方案如imap无法应用在较大场景的问题。 关于该工程的前身和当前领域的主要研究现状见&#xff1a;&#xff08;知乎&#xff1a;秦通&#xff09;基于神经辐射场的&#…

接口自动化测试-Pytest核心固件Fixture详解以及应用实战

目录 前言&#xff1a; 一、Fixture概述 二、Fixture分类 在Pytest中&#xff0c;Fixture可以分为4类&#xff1a; 三、Fixture使用 下面结合实例说明如何使用Fixture。 3.1 session级别的Fixture 3.2 module级别的Fixture 3.3 function级别的Fixture 3.4 class级别的F…

2023.5.13前端设计

SpringbootVue架构设计&#xff08;一&#xff09; 项目中的文件来自B站视频&#xff08;程序员青戈&#xff09; https://www.bilibili.com/video/BV1U44y1W77D 前端设计 assets 文件夹通常用于存放静态资源文件&#xff0c;例如图像、CSS、字体等。components 文件夹通常用…

2023.5.14数据库设计

SpringbootVue架构设计&#xff08;二&#xff09; 项目中的文件来自B站视频&#xff08;程序员青戈&#xff09; https://www.bilibili.com/video/BV1U44y1W77D 数据库设计 1、article 在关系型数据库中&#xff0c;text类型和varchar类型都是用来存储字符串的数据类型。它…

【ShaderToy中图形效果转译到UnityShaderlab案例分享_Flame】

ShaderToy内的源码与效果图如下: float noise(vec3 p) //Thx to Las^Mercury {vec3 i = floor(p);vec4 a = dot(i

电动力学专题:电磁波传播时的色散效应

本文中假定波动方程的性质足够好&#xff0c;不要杠&#xff0c;杠你就输了 数学分析中的问题和XX 波动方程&#xff1a;\frac{\partial^2 u}{\partial t^2} - a^2 \frac{\partial^2 u}{\partial x^2} 0......(1) 波的色散 波动方程描写的是以恒定速度a传播的非衰减波。方程&…

【电厂用 交流三相电流继电器HJL-F93/AY 导轨安装 JOSEF约瑟供应 】

名称&#xff1a;交流三相电流继电器&#xff0c;品牌&#xff1a;JOSEF约瑟&#xff0c;型号&#xff1a;HJL-F93/AY&#xff0c;功率消耗&#xff1a;≤5W&#xff0c;触点容量&#xff1a;250V/5A&#xff0c;额定电压&#xff1a;58、100、110、220V 上海约瑟供应 交流三相…