Go语言基础知识学习(一)
Go基本数据类型
bool
bool型值可以为true
或者false
,例子:
var b bool = true
数值型
类型 | 表示 | 范围 |
---|---|---|
int8 | 有符号8位整型 | -128 ~ 127 |
int16 | 有符号16位整型 | -32768 ~ 32767 |
int32 | 有符号32位整型 | -2147783648 ~ 2147483647 |
int64 | 有符号64位整型 | ··· |
uint8 | 无符号8位整型 | 0 ~ 255 |
uint16 | 无符号16位整型 | 0 ~ 65535 |
uint32 | 无符号32位整型 | 0 ~ 4294967295 |
uint64 | 无符号64位整型 | ··· |
浮点型
类型 | 表示 |
---|---|
float32 | 32位浮点数 |
float64 | 64位浮点数 |
其他
类型 | 表示 |
---|---|
byte | uint8 |
rune | int32 |
数据类型的转换
简单的转换操作
package mainimport ("fmt""strconv"
)// 类型转换
func main() {var a int8 = 12var b = uint8(a)var f float32 = 3.14var c = int32(f)fmt.Println(b, c)var f64 = float64(a)fmt.Println(f64)type IT int //类型要求很严格var d IT = 13fmt.Println(d)//字符串转数字var istr = "12a"//字符串转数字的方法,返回转换的值和errormint, err := strconv.Atoi(istr)if err != nil {fmt.Println("convert error!")} else {fmt.Println(mint)}var myi = 32//数字转字符串mstr := strconv.Itoa(myi)fmt.Println(mstr)//字符串转为float32, 转换为boolfl, err2 := strconv.ParseFloat("3.1415926", 64)if err2 != nil {return}fmt.Println(fl)//字符串转为整数parseInt, err3 := strconv.ParseInt("-42", 10, 64)if err3 != nil {return}fmt.Println(parseInt)//字符串转为boolparseBool, parseBoolErr := strconv.ParseBool("true")if parseBoolErr != nil {return}fmt.Println(parseBool)//基本类型转为字符串boolStr := strconv.FormatBool(true)fmt.Println(boolStr)//float转为字符串floatStr := strconv.FormatFloat(3.1415926, 'f', -1, 64)fmt.Println(floatStr)fmt.Println(strconv.FormatInt(42, 16))
}
运算符和表达式
package mainimport "fmt"func main() {// 运算符 + - * / % ++ --var a, b = 1, 2fmt.Println(a + b) //3var astr, bstr = "hello", "zed"fmt.Println(astr + bstr) //hellozed//取余fmt.Println(3 % 2) //1a++fmt.Println(a) //2//逻辑运算符var abool, bbool = true, falsefmt.Println(abool && bbool) //falsefmt.Println(abool || bbool) //truefmt.Println(!abool) //false//位运算符var A = 60var B = 13fmt.Println(A & B) // 12
}
字符串
格式化输出
package mainimport ("fmt""strconv""strings"
)func main() {//转义符courseName := "go\"体系课\""fmt.Println(courseName)//格式化输出username := "bobby"out := "hello" + username //简单组装输出fmt.Println(out)age := 18address := "北京"fmt.Println("用户名: " + username + "," + "年龄: " + strconv.Itoa(age) + ",地址: " + address)fmt.Printf("用户名: %s, 年龄: %d, 地址: %s", username, age, address) //非常常用,性能不好userMsg := fmt.Sprintf("用户名: %s, 年龄: %d, 地址: %s", username, age, address)fmt.Println(userMsg)//通过string的builder进行字符串拼接,高性能var builder strings.Builderbuilder.WriteString("用户名: ")builder.WriteString(username)builder.WriteString(", 年龄: ")builder.WriteString(strconv.Itoa(age))builder.WriteString(", 地址: ")builder.WriteString(address)re := builder.String()fmt.Println(re)
}
字符串的比较
package mainimport "fmt"func main() {//字符串的比较a := "hello"b := "hello"fmt.Println(a == b) // true//字符串的大小比较c := "bello"fmt.Println(a > c) //true,比较asic码的大小
}
字符串的操作方法
package mainimport ("fmt""strings"
)func main() {//字符串的比较a := "hello"b := "hello"fmt.Println(a == b) // true//字符串的大小比较c := "bello"fmt.Println(a > c) //true,比较asic码的大小//是否包含某字符串name := "goland-工程师"isContains := strings.Contains(name, "goland")fmt.Println(isContains)//查询字串出现的次数fmt.Println(strings.Count(name, "o")) //1//分割字符串fmt.Println(strings.Split(name, "-")) //[goland 工程师]//字符串是否包含前缀 是否包含后缀fmt.Println(strings.HasPrefix(name, "g")) //truefmt.Println(strings.HasSuffix(name, "g")) //false//查询字串出现的位置fmt.Println(strings.Index(name, "师")) //14 字节出现的位置//字串替换fmt.Println(strings.Replace(name, "goland", "java", 1))//大小写转换fmt.Println(strings.ToLower(name))fmt.Println(strings.ToUpper(name)) // GOLAND//去掉特殊字符串fmt.Println(strings.Trim("hello go ", " ")) // hello go, 去掉的是左右的所有被指定的字符串}
条件判断与for循环
条件判断
package mainimport "fmt"/* if bool表达式 {逻辑
}
*/func main() {//条件判断age := 22country := "中国"if age < 18 && country == "中国" {fmt.Println("未成年人")} else if age == 18 {fmt.Println("刚好是成年人")} else {fmt.Println("成年人")}}
for循环
package mainimport "fmt"func main() {/*for循环for init; condition; post {逻辑}*/for i := 0; i < 3; i++ {fmt.Println(i)}//打印九九乘法表for i := 1; i <= 9; i++ {for j := 1; j <= i; j++ {fmt.Printf("%d * %d = %d ", i, j, i*j)}fmt.Println()}//for range,主要是对字符串、数组、切片、map、channel的遍历/**for index, value := range 遍历的数据 {}1. 如果遍历的是字符串的话,key为字符串的索引,value字符串对应的缩影的字符的值的拷贝,如果不鞋key,返回的是索引2. 数组: key为数组的索引,value为索引对应的值的拷贝3. 切片: key为切片的索引,value为索引对应的值的拷贝4. map: key为map的key, value为key对应的值的拷贝5. channel: 无key, value为channel接收的数据*/name := "hello, go"for index, value := range name {//fmt.Println(index, value)fmt.Printf("%d %c\r\n", index, value)}//不想打印index,可以使用匿名变量fmt.Println("----------------------------")for _, value := range name {fmt.Printf("%c\r\n", value)}fmt.Println("----------------------------")for index := range name {fmt.Printf("%c\r\n", name[index])}
}
goto
package mainimport "fmt"/*
*
goto语句可以让我的代码跳到指定的代码块中运行
很少用
*/
func main() {for i := 0; i < 5; i++ {for j := 0; j < 4; j++ {if j == 2 {goto over}fmt.Println(i, j)}}over:fmt.Println("over")}
switch
package mainimport "fmt"func main() {/*switch val {case val1:...case val2:...default:...}*///中文的星期几,输出对应的英文day := "周五"switch day {case "周一":fmt.Println("Mongday")case "周五":fmt.Println("Friday")case "周三":fmt.Println("Wednesday")default:fmt.Println("Saturday")}score := 95switch {case score < 60:fmt.Println("E")case score >= 60 && score < 70:fmt.Println("D")case score >= 70 && score < 80:fmt.Println("C")case score >= 80 && score < 90:fmt.Println("b")case score >= 90 && score <= 100:fmt.Println("A")}switch score {case 60, 70, 80:fmt.Println("牛")default:fmt.Println("牛牛")}
}
Go语言的容器
数组、切片(slice)、map、list
Go–数组
package mainimport "fmt"func main() {/*go语言提供了哪些集合类型的数据结构1、数组2、切片(slice)3、map4、list*/// 数组 定义: var name [count]intvar courses1 [3]string //courses1类型: 只有三个元素的数组类型var courses2 [4]string //courses2类型: 只有四个元素的数组类型fmt.Printf("%T\r\n", courses1)fmt.Printf("%T\r\n", courses2)courses1[0] = "go"courses1[1] = "grpc"courses1[2] = "gin"fmt.Println(courses1)//对数组进行遍历,indexfor _, value := range courses1 {fmt.Println(value)}
}
Go–Slice切片
package mainimport "fmt"func main() {//go折中var courses []stringfmt.Printf("%T\r\n", courses)courses = append(courses, "Java", "Python", "Golang")fmt.Println(courses)//访问切片的元素 访问一个,根据下标访问 or 访问多个fmt.Println(courses[2])//访问多个coursesSlice := []string{"Java", "Go", "mysql", "Kafka", "Redis", "ElasticSearch"}/*courseSlice[start:end] 左闭右开区间,1、如果只有start,没有end,表示从start开始到结尾的所有数据2、如果没有start,只有end,表示从0到end之间的所有的数据3、没有start没有end就是复制了一份*/fmt.Println(coursesSlice[1:3])fmt.Println(coursesSlice[0:])fmt.Println(coursesSlice[:3])fmt.Println(coursesSlice[:])//切片数据的添加coursesSlice2 := []string{"go", "grpc"}//若想合并两个切片的数据coursesSlice3 := []string{"python", "kafka"}for _, val := range coursesSlice3 {coursesSlice2 = append(coursesSlice2, val)}coursesSlice2 = append(coursesSlice2, coursesSlice3...)coursesSlice2 = append(coursesSlice2, "gin", "mysql", "es")fmt.Println(coursesSlice2)//如何删除slice中的元素,利用append函数重新生成slicecoursesSlice4 := []string{"go", "Java", "Python", "MySQL"}newSlice := append(coursesSlice4[:2], coursesSlice4[3:]...)fmt.Println(newSlice)//复制slicecoursesSlice4Copy := coursesSlice4coursesSlice4Copy2 := coursesSlice4[:]fmt.Println(coursesSlice4Copy)fmt.Println(coursesSlice4Copy2)var newCoursesSliceCopy = make([]string, len(coursesSlice4))copy(newCoursesSliceCopy, coursesSlice4)fmt.Println(newCoursesSliceCopy)fmt.Println("--------直接赋值和使用copy函数的区别--------")coursesSlice4[0] = "golang"fmt.Println(coursesSlice4Copy[0])fmt.Println(newCoursesSliceCopy[0])
}
切片在函数参数传递时是值传递还是引用传递
package mainimport ("fmt""strconv"
)func printSlice(data []string) {data[0] = "java"for i := 0; i < 10; i++ {data = append(data, strconv.Itoa(i))}
}func main() {/*go的slice在函数参数传递的时候是值传递还是引用传递?答案是值传递,但是效果呈现的是引用的效果(不完全是)这个代码呈现的结果是,如果是对当前slice进行值的修改,发现改成功了,但是想加数据却加不了,现象是改数据看起来是引用传递了,加数据反而是值传递的效果*/courses := []string{"go", "grpc", "gin"}printSlice(courses)fmt.Println(courses)
}
Go容器–map
package mainimport "fmt"func main() {/*map是一个key(索引)和value(值)的无序集合查询方便O(1)*/var coursesMap = map[string]string{"go": "golang工程师","grpc": "grpc入门","gin": "gin深入理解",}fmt.Println(coursesMap["grpc"])//放值coursesMap["mysql"] = "mysql原理"//var nullMap map[string]string //nil, map类型如果想设置值,必须要初始化//nullMap["mysql"] = "mysql原理"//fmt.Println(nullMap)//fmt.Println(coursesMap)var nullMap2 = map[string]string{}nullMap2["mysql"] = "mysql原理"fmt.Println(nullMap2)//使用make函数初始化,make是内置函数,主要用于初始化slice map channelvar nullMap3 = make(map[string]string, 3)nullMap3["mysql"] = "mysql原理"fmt.Println(nullMap3)/*map必须初始化采用使用, 初始化的方法1. map[string]string{}2. make(map[string]string, 3 )3. 但是slice可以不初始化*/var slirceTest []stringif slirceTest == nil {fmt.Println("slirceTest is nil")}slirceTest = append(slirceTest, "a")/**map的两种赋值方法:1. 初始化的赋值:var coursesMap = map[string]string{"go": "golang工程师","grpc": "grpc入门","gin": "gin深入理解",}2. 直接手动赋值:coursesMap["mysql"] = "mysql原理"*///遍历mapfmt.Println("-------------map的遍历---------------")for key, value := range coursesMap {fmt.Println(key, value)}fmt.Println("-------------map的遍历,只打印key---------------")for key := range coursesMap {fmt.Println(key, coursesMap[key])}//map是无序的,并且不保证每次打印是相同的数据fmt.Println("-------------map寻找key不存在的数据---------------")d := coursesMap["java"]fmt.Println(d)if _, ok := coursesMap["java"]; !ok {fmt.Println("not in")} else {fmt.Println("in")}//删除一个元素delete(coursesMap, "grpc")fmt.Println(coursesMap)delete(coursesMap, "rpc") //删除不存在的元素也不会报错//重要提示, map不是线程安全的
}
Go容器 – list(链表)
package mainimport ("container/list""fmt"
)func main() {var mylist = list.List{}mylist.PushBack("go")mylist.PushBack("grpc")mylist.PushBack("gin")fmt.Println(mylist)//遍历打印值,从头遍历for i := mylist.Front(); i != nil; i = i.Next() {fmt.Println(i.Value)}fmt.Println("----------反向遍历----------")//反向遍历for i := mylist.Back(); i != nil; i = i.Prev() {fmt.Println(i.Value)}fmt.Println("----------初始化list的方法----------")newList := list.New()newList.PushFront("mysql")for i := newList.Front(); i != nil; i = i.Next() {fmt.Println(i.Value)}//插入指定元素之前或者之后fmt.Println("----------插入指定元素之前或者之后----------")i := newList.Front()for ; i != nil; i = i.Next() {if i.Value.(string) == "mysql" {break}}newList.InsertBefore("oracle", i)for i := newList.Front(); i != nil; i = i.Next() {fmt.Println(i.Value)}//list删除fmt.Println("----------newList删除----------")newList.Remove(i)for i := newList.Front(); i != nil; i = i.Next() {fmt.Println(i.Value)}
}
相关文章:

Go语言基础知识学习(一)
Go基本数据类型 bool bool型值可以为true或者false,例子: var b bool true数值型 类型表示范围int8有符号8位整型-128 ~ 127int16有符号16位整型-32768 ~ 32767int32有符号32位整型-2147783648 ~ 2147483647int64有符号64位整型uint8无符号8位整型0 ~ 255uint16…...

Vue 3项目的目录结构
使用vite创建完VUE项目后,使用VS Code编辑器打开项目目录,可以看到一个默认生成的项目目录结构 下图是目录结构: 详细介绍.vscode:存放VS Code编辑器的相关配置。 node_modules:存放项目的各种依赖和安装的插件。…...

RPG项目01_技能释放
基于“RPG项目01_新输入输出”, 修改脚本文件夹中的SkillBase脚本: using System; using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.Events; //回复技能,魔法技能,物理技能…...

Leetcode—209.长度最小的子数组【中等】
2023每日刷题(五十六) Leetcode—209.长度最小的子数组 实现代码 class Solution { public:int minSubArrayLen(int target, vector<int>& nums) {int left 0, right 0;int ans nums.size() 1, s 0;for(; right < nums.size(); righ…...

Nacos源码解读12——Nacos中长连接的实现
短连接 VS 长连接 什么是短连接 客户端和服务器每进行一次HTTP操作,就建立一次连接,任务结束就中断连接。 长连接 客户端和服务器之间用于传输HTTP数据的TCP连接不会关闭,客户端再次访问这个服务器时,会继续使用这一条已经建立…...

k8s 安装部署
一,准备3台机器,安装docker,kubelet、kubeadm、kubectl firewall-cmd --state 使用下面命令改hostname的值:(改为k8s-master01)另外两台改为相应的名字。 172.188.32.43 hostnamectl set-hostname k8s-master01 172.188.32.4…...
TCP/IP五层(或四层)模型,IP和TCP到底在哪层?
文章目录 前言一、应用层二.传输层三.网络层:四.数据链路层五.物理层:六.OSI七层模型:1.物理层(Physical Layer):2.数据链路层(Data Link Layer):3.网络层(Ne…...

STM32串口接收不定长数据(空闲中断+DMA)
玩转 STM32 单片机,肯定离不开串口。串口使用一个称为串行通信协议的协议来管理数据传输,该协议在数据传输期间控制数据流,包括数据位数、波特率、校验位和停止位等。由于串口简单易用,在各种产品交互中都有广泛应用。 但在使用串…...
LeetCode56. Merge Intervals
文章目录 一、题目二、题解 一、题目 Given an array of intervals where intervals[i] [starti, endi], merge all overlapping intervals, and return an array of the non-overlapping intervals that cover all the intervals in the input. Example 1: Input: interva…...
【华为OD题库-083】玩牌高手-Java
题目 给定一个长度为n的整型数组,表示一个选手在n轮内可选择的牌面分数。选手基于规则选牌,请计算所有轮结束后其可以获得的最高总分数。 选择规则如下: 1.在每轮里选手可以选择获取该轮牌面,则其总分数加上该轮牌面分数,为其新的…...

ARM day3
题目:实现3盏灯的流水 代码: .text .global _start _start: 设置RCC寄存器使能 LDR R0,0X50000A28 LDR R1,[R0] ORR R1,R1,#(0X1<<4) ORR R1,R1,#(0X1<<5) STR R1,[R0]设置PE10管脚为输出模式 LDR R0,0X50006000 LDR R1,[R0] BIC R1,R1,…...

[足式机器人]Part2 Dr. CAN学习笔记-自动控制原理Ch1-2稳定性分析Stability
本文仅供学习使用 本文参考: B站:DR_CAN Dr. CAN学习笔记-自动控制原理Ch1-2稳定性分析Stability 0. 序言1. 稳定的分类2. 稳定的对象3. 稳定的系统4. 系统稳定性的讨论5. 补充内容——Transfer Function(传递函数) - nonzero Initial Condition(非零初始…...

Android Audio实战——音频链路分析(二十五)
在 Android 系统的开发过程当中,音频异常问题通常有如下几类:无声、调节不了声音、爆音、声音卡顿和声音效果异常(忽大忽小,低音缺失等)等。尤其声音效果这部分问题通常从日志上信息量较少,相对难定位根因。想要分析此类问题,便需要对声音传输链路有一定的了解,能够在链…...
PHP基础 - 常量字符串
常量 在PHP中,常量是一个简单值的标识符,定义后默认是全局变量,可以在整个运行的脚本的任何地方使用。常量由英文字母、下划线和数字组成,但数字不能作为首字母出现。 PHP中定义常量的方式是使用define()函数,其语法如下: bool define( string $name, mixed $value [,…...

Linux查看命令的绝对路径
linux查看命令的绝对路径 在Linux中,可以使用以下命令来查看命令的绝对路径: 1、which 命令名 例如,要查看chronyc命令的绝对路径,可以运行: which chronyc 2、whereis 命令名 例如,要查看chronyc命令…...

Docker build 无法解析域名
### 报错 Docker build 无法解析域名 报错:ERROR [ 2/12] RUN curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo 解决Docker build无法解析域名 # 追加到 etc/docker/daemon.json,注意JSON的格式 {"dn…...

退稿论文重复率太高会怎么样【保姆教程】
大家好,今天来聊聊退稿论文重复率太高会怎么样,希望能给大家提供一点参考。 以下是针对论文重复率高的情况,提供一些修改建议和技巧: 退稿论文重复率太高会怎么样 在学术出版领域,论文的重复率是衡量其原创性和学术诚…...
Flask 最佳实践(一)
Flask是一个轻量级而强大的Python Web框架,它的简洁性和灵活性使其成为许多开发者的首选。然而,为了确保项目的可维护性和可扩展性,我们需要遵循一些最佳实践。本文将探讨Flask中一些关键的最佳实践。 1. 项目结构 构建一个清晰的项目结构是…...

直流电和交流电
直流电(Direct Current,简称DC)和交流电(Alternating Current,简称AC)是电流的两种基本形式。 1. 直流电 直流电是指电流方向始终保持不变的电流。在直流电中,电子只能沿着一个方向移动。直流电…...

『亚马逊云科技产品测评』活动征文|基于亚马逊EC2云服务器安装Prometheus数据可视化监控
授权声明:本篇文章授权活动官方亚马逊云科技文章转发、改写权,包括不限于在 Developer Centre, 知乎,自媒体平台,第三方开发者媒体等亚马逊云科技官方渠道 亚马逊EC2云服务器(Elastic Compute Cloud)是亚马…...
ubuntu搭建nfs服务centos挂载访问
在Ubuntu上设置NFS服务器 在Ubuntu上,你可以使用apt包管理器来安装NFS服务器。打开终端并运行: sudo apt update sudo apt install nfs-kernel-server创建共享目录 创建一个目录用于共享,例如/shared: sudo mkdir /shared sud…...

练习(含atoi的模拟实现,自定义类型等练习)
一、结构体大小的计算及位段 (结构体大小计算及位段 详解请看:自定义类型:结构体进阶-CSDN博客) 1.在32位系统环境,编译选项为4字节对齐,那么sizeof(A)和sizeof(B)是多少? #pragma pack(4)st…...
TRS收益互换:跨境资本流动的金融创新工具与系统化解决方案
一、TRS收益互换的本质与业务逻辑 (一)概念解析 TRS(Total Return Swap)收益互换是一种金融衍生工具,指交易双方约定在未来一定期限内,基于特定资产或指数的表现进行现金流交换的协议。其核心特征包括&am…...

多种风格导航菜单 HTML 实现(附源码)
下面我将为您展示 6 种不同风格的导航菜单实现,每种都包含完整 HTML、CSS 和 JavaScript 代码。 1. 简约水平导航栏 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport&qu…...

用docker来安装部署freeswitch记录
今天刚才测试一个callcenter的项目,所以尝试安装freeswitch 1、使用轩辕镜像 - 中国开发者首选的专业 Docker 镜像加速服务平台 编辑下面/etc/docker/daemon.json文件为 {"registry-mirrors": ["https://docker.xuanyuan.me"] }同时可以进入轩…...

GC1808高性能24位立体声音频ADC芯片解析
1. 芯片概述 GC1808是一款24位立体声音频模数转换器(ADC),支持8kHz~96kHz采样率,集成Δ-Σ调制器、数字抗混叠滤波器和高通滤波器,适用于高保真音频采集场景。 2. 核心特性 高精度:24位分辨率,…...

基于SpringBoot在线拍卖系统的设计和实现
摘 要 随着社会的发展,社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。 在线拍卖系统,主要的模块包括管理员;首页、个人中心、用户管理、商品类型管理、拍卖商品管理、历史竞拍管理、竞拍订单…...

深入浅出深度学习基础:从感知机到全连接神经网络的核心原理与应用
文章目录 前言一、感知机 (Perceptron)1.1 基础介绍1.1.1 感知机是什么?1.1.2 感知机的工作原理 1.2 感知机的简单应用:基本逻辑门1.2.1 逻辑与 (Logic AND)1.2.2 逻辑或 (Logic OR)1.2.3 逻辑与非 (Logic NAND) 1.3 感知机的实现1.3.1 简单实现 (基于阈…...
深度剖析 DeepSeek 开源模型部署与应用:策略、权衡与未来走向
在人工智能技术呈指数级发展的当下,大模型已然成为推动各行业变革的核心驱动力。DeepSeek 开源模型以其卓越的性能和灵活的开源特性,吸引了众多企业与开发者的目光。如何高效且合理地部署与运用 DeepSeek 模型,成为释放其巨大潜力的关键所在&…...

【无标题】湖北理元理律师事务所:债务优化中的生活保障与法律平衡之道
文/法律实务观察组 在债务重组领域,专业机构的核心价值不仅在于减轻债务数字,更在于帮助债务人在履行义务的同时维持基本生活尊严。湖北理元理律师事务所的服务实践表明,合法债务优化需同步实现三重平衡: 法律刚性(债…...