Go 语言基础(一)【基本用法】

前言

        最近心情格外不舒畅,不仅仅是对前途的迷茫,这种迷茫倒是我自己的问题还好,关键它是我们这种普通吗喽抗衡不了的。

        那就换个脑子,学点新东西吧,比如 Go?

1、Go 语言入门

        介绍就没必要多说了,Go 语言的作者是 B语言、C语言 和 Unix 支付联合开发的,所以可以预见这门语言不会差!而且事实也确实是这样。不得不感慨外国那群搞技术的人是真牛啊。

1.1、Go 环境安装

Go 语言官网 Go下载 - Go语言中文网 - Golang中文社区 下载安装包

安装后使用 go version 进行安装的验证

创建 Go 的工作目录并设置为系统环境变量 GOPATH,创建下面三个目录:

用户变量 GOPATH  默认会有一个工作目录,所以需要覆盖掉:

 检查安装成功:

1.2、Hello World

Go 语言的执行必须在 main 包下 :

package mainimport "fmt"func main() {fmt.Print("Hello World")
}

注意:这个包可以是不存在的,也就是它可以不是一个目录! 

运行结果: 

注意:必须在 GOROOT 环境下去执行 

当然,我们也可以去 go 文件所在的文件夹去打开,然后通过 go run 来执行该文件:

注意:必须要把要执行的 go 文放在 main 包下!

如果在运行过程中,出现了下面的报错:

需要关闭 go 环境变量中的 GO111MODULE :

  • GO111MODULE 是一个环境变量,它用于控制Go语言的包管理方式。

在Go 1.11版本之前,Go语言使用 GOPATH 模式来管理项目和依赖包,所有的代码和依赖都需要存放在$GOPATH目录下。随着Go 1.11版本的发布,引入了一种新的包管理方式,即模块(module)系统,这个系统允许开发者在不依赖于GOPATH的情况下管理和构建项目。

具体来说,GO111MODULE 环境变量可以设置以下三个值:

  • on:开启模块支持,此时Go命令行会完全使用模块机制来管理依赖,而不会去GOPATH目录下查找。
  • off:关闭模块支持,go命令行将不会支持module功能,寻找依赖包的方式将会沿用旧版本那种通过vendor目录或者GOPATH模式来查找。
  • auto(默认值):自动模式,go命令行将会根据当前目录来决定是否启用module功能。如果当前目录在GOPATH/src之外且该目录包含go.mod文件,或者当前文件在包含go.mod文件的目录下面,则会开启模块支持。

1.3、注释

Go 语言的注释和 Java 几乎一样

1.4、变量

Go 语言是一种静态类型编译型语言。

  • Go语言使用静态类型系统,这意味着变量的类型在编译时就已确定,有助于在编译阶段捕获错误,提高代码的安全性。
  • 同时,Go语言是编译型语言,源代码在执行前需要被编译成机器码。

1.4.1、变量的定义 

var name type

 同时定义多个变量

var (name string    // 默认为空age int    // 默认为 0)

注意:可以不给变量赋初始值,它会有默认值。

  • 此外,布尔值默认为 false,切片、函数、指针变量的默认值为 nil。

1.4.2、变量的标准初始化

// 使用 var 可以省去类型
var addr = "beijing"// 初始化多个变量
var (name string = "zs"age int = 18)
// 初始化单个变量
var addr string = "beijing"

1.4.3、端变量的初始化(自动推导)

省去 var,可以使用 := 来进行变量类型的自动推导

    name := "zs"age := 18fmt.Println(name,age)// %T 代表变量的类型fmt.Printf("%T,%T",name, age)

运行结果:

注意:被 := 初始化过的变量不能再初始化了!

1.4.4、打印内存地址

可以使用 Pringf 的 %p 结合 &变量 来实现内存地址的打印(& 也叫取地址符),但是这种取地址的方法只适合与数值类型,因为数值类型存储的是数值,需要用取地址符来取得数值地址,而引用类型本身就是存储的就是地址,不需要再取:

    name := "zs"fmt.Println(name)fmt.Printf("name=%s,内存地址=%p\n",name,&name)name = "ls"fmt.Printf("name=%s,内存地址=%p",name,&name)

运行结果:

 可以看到,即使一个变量的值发生了变化,但是它的内存地址是不会变化的。

1.4.5、变量交换

在别的语言中,变量的交换通常需要借助一个中间变量来实现:

    var tmp inttmp = aa = bb = tmp

但是 Go 语言提供了一个特别简洁的语法:

    var a,b int = 100,200println("a =",a,"b =",b)a,b = b,aprintln("a =",a,"b =",b)

注意这里使用了 println 输出的,看起来简单了很多,但是它是标准错误输出! 

1.4.6、匿名变量

        匿名变量就是一个下划线,它可以用于变量的声明或赋值,但是任何赋给这个标识符的值都将被抛弃

        所以这个匿名变量一般用于我们不需要这个值的时候(一般是返回值)。

package mainfunc test()(int,int)  {return 100,200
}func main() {a,_ := test()println(a)
}

        这里,我们不需要第二个返回值,但是接受返回值的时候又不能不写,所以直接使用匿名变量抛弃掉。

        匿名变量不占用内存,不会分配内存。匿名变量和匿名之间也不会因为多次初始化而无法使用。

1.4.7、变量的作用域

        Go 语言中同样是分类局部变量和全局变量,在 Go 语言中,如果全局变量名和局部变量名相同,调用时会使用就近原则:

// 全局变量
var name string = "hive"
func main() {// 局部变量name := "s"println(name)
}

        这里我们的局部变量 name 并不是在重新初始化(在 Go 语言中一个变量只能被初始化一次,除了匿名变量),而是一个全新的变量。

1.5、常量

1.5.1、普通常量

        常量就是在程序运行时,不能被修改的值。在 Go 语言中,常量只能是布尔型、数值型和字符串类型。

    const URL string = "www.csdn.com" // 显示定义 const USERNAME = "lyh" // 隐式定义const a,b,c = 1,2,3 // 同时定义多个常量 

注意:在 Go 语言中,常量全局变量不使用不会报错,但是变量定义了必须使用。

1.5.2、iota

        iota 是一个特殊的常量,可以认为是一个可以被编译器修改的常量。iota 是 go 语言的常量计数器。

        iota 在 const 关键字处显示会被重置为 0 ,const 中每新增一行就会 +1 。

package mainimport "fmt"func main() {const (a = iota	// 0b = iota 	// 1c = iota	// 2)fmt.Println(a,b,c)const (d = iota	// 0e			// 1f			// 2g = "hello"	// iota依然会自增h			// 默认和上面的值是一样的 helloi = iota	// 5)fmt.Println(d,e,f,g,h,i)
}

运行结果:

1.6、基本数据类型

1.6.1、布尔型

    var b1 bool // 默认 falsefmt.Printf("%T,%t",b1,b1)

注意%T 是输出变量类型,%t 是代表布尔类型的值

运行结果:

1.6.2、数值类型

整数类型

        整数分为有符号无符号两种类型,其中无符号包括(uint8、uint16、uint32、uint64),有符号包括(int8、int16、int32、int64)等。(无符号指的就是没有负数,有些场景下确实好用)

    var ss  = 100fmt.Printf("%T",ss) // int

注意:而 Go 语言默认的整型就是 int 型。

  • 此外,Go 语言中的 byte 默认就是 uint8

  • 从源码中可以看到,Go 语言中 int 并不等同于 int32, unit 也不等同于 unit32 。
浮点数

        浮点数同样根据位数分为 float32float64 。

    var ss  = 3.14fmt.Printf("%T",ss) // float64

注意: Go 语言的浮点数默认为 float64。

1.6.3、字符串类型

Go 语言没有字符类型,如果要输出字符类型,需要把它用 string() 方法从 转为 

    var sex = '男' // 默认为 int32 类型fmt.Printf("%T\n",sex)fmt.Println(string(sex))

运行结果:

  • int32 也就是指字符的 ASCII 码的值

1.6.4、数据类型转换

上面我们已经试过用 string() 来把 int32 类型的数据转为 string 类型了。

    a := 3.5b := int(a) // 3fmt.Println(b)
  • int() 默认是截取整数部分

1.7、运算符

Go 语言中的算数运算符、关系运算符、逻辑运算符等和Java基本一致,这里只介绍其他运算符:

1.7.1、其他运算符

主要有两个:

  • &:返回变量存储地址,配合 %p 使用
  • :指针变量,指向一个变量的内存地址
    var a int = 7var ptr *int = &a // 指针指向内存地址fmt.Printf("%T,%d,%p\n",a,a,&a)fmt.Printf("%p",ptr)

1.8、输入输出

下面适应 fmt.Scanln 进行输入测试: 

    var x intvar y intfmt.Println("请输入两个数...")fmt.Scanln(&x, &y)fmt.Println(x,y)

或者可以替换使用 fmtScanf 函数: 

fmt.Scanf("%d %d",&x,&y)

2、Go 语言基础

2.1、流程控制

无论是什么语言,流程控制都只有三种:顺序、选择(if、switch、select)、循环(for)。

2.1.1、if 语句

和 Java 相比,只是没有括号,仅此而已: 

    var x intfmt.Scanf("%d",&x)if x >= 60 {if x >= 90 {fmt.Println("成绩优秀")}else {fmt.Println("成绩及格")}}else {fmt.Println("成绩不及格")}

2.1.2、switch 语句

同样和 Java 差不多,不多介绍: 

	var x intfmt.Scanf("%d",&x)switch x {case 60:fmt.Println("C")case 80:fmt.Println("B")case 90:fmt.Println("A")default:fmt.Println("Other")}
forthrough 穿透

        switch 默认匹配成功后就不会去执行其他 case,如果我们需要无条件执行下面一条其他 case ,需要使用 fallthrough :

    var x intfmt.Scanf("%d",&x)switch x {case 60:fmt.Println("C")fallthroughcase 80:fmt.Println("B")case 90:fmt.Println("A")default:fmt.Println("Other")}

测试:输入 60

可以看到,fallthrough 只能穿透下面一个 case 。

2.1.3、for 循环

    var x intfmt.Scanf("%d",&x)// 打印 1~xfor i:=1;i<x;i++{fmt.Println(i)}

对于 for 的三个参数,我们也可以选择省略:

    count := 5for ;count>0;count--{fmt.Println(count)}

如果参数全部省略,则相当于Java 中的 while 循环(但是 Go 语言并没有提供 while 循环): 

for{// 无限循环
}

for 循环中的 break 和 continue 的用法和 Java 中是一样的。

遍历字符串
    var str = "flink"for i:=0;i<len(str);i++{fmt.Print(string(str[i])+" ")}
  • 需要注意 Go 语言中没有字符类型,必须转为 string ,否则输出 ASCII 码。

2.2、函数

2.2.1、函数的声明

func 函数名 ( 参数... ) [返回值 返回值类型]{函数体[return 返回]
}

求和函数: 

func main() {fmt.Println(sum(1,1)) // 2
}func sum(x int,y int)(res int){return x+y
}

至于函数中的形参、实参太 low 了,这里就不练习了。 

2.2.2、可变参数

和 Java 基本一样,就相当于传了一个 int 数组: 

func main() {fmt.Println(sum(1,1,1,1,1))    // 5
}func sum(num ... int)(res int){sum := 0for i:=0;i<len(num);i++{sum+=num[i]}return sum
}

2.2.3、值传递

        上面我们已经给函数传递过一些类型的值了,除了基本的数值类型,我们还可以传递数组类型(参数必须指定数组大小):

func main() {// 定义一个数组arr := [4]int{1,2,3,4}fmt.Println(sum(arr)) // 10
}// 如果参数是数组需要指定数组大小
func sum(arr [4]int)(res int){sum := 0for i:=0;i<len(arr);i++{sum+=arr[i]}return sum
}

        可以看到,使用数组作为函数参数非常受限制,这是因为Go语言在设计上注重的是安全性、清晰性和简洁性。虽然有时这可能会牺牲一定的灵活性,但它通过提供其他机制(如切片)来补充这一点,同时保持语言的一致性和易用性。

此外,还有一些类型的值比如 struct 之后再学。 

2.2.4、引用传递

Go 语言中引用类型的数据:slice、map、chan ...

func main() {// 切片是一个可扩容的数组s1 := []int{1,2,3,4}update(s1)fmt.Println(s1) // [-1 2 3 4]
}
func update(arr []int) {arr[0] = -1
}

        可以看到,如果参数是值类型(包括数组和结构体!),就像在 Java 中的形参为值类型一样,进入函数的参数会开辟自己的栈空间,所以我们事实上操作的是形参而不是实参!

        这里我们的参数类型是应用类型 slice,它虽然看起来像数组,但是它是一个引用类型,对于 Go 语言中的引用类型,它就像我们 Java 中的对象,所以当我们修改它的属性值的时候,修改的就是实参的值。

        总之,值传递时传递的是数据的拷贝,而引用传递时传递的是引用地址。

2.2.5、递归

递归就简单了,这里玩一个斐波那契数列:

func main() {for i:=1;i<10;i++ {fmt.Print(feb(i)," ")}
}
func feb(num int)(res int) {if num==1 || num==2 {return 1}else {return feb(num-1)+feb(num-2)}
}

运行结果:

 2.2.6、defer 延迟

被 defer 修饰的代码总是放到最后执行,它采用的是后进先出(栈)模式:

func main() {f("1")f("2")defer f("3")f("4")
}
func f(s string)  {fmt.Println(s)
}

运行结果:

 

因为 defer 的这个特性,我们可以用它去关闭资源。

2.3、函数高级

2.3.1、函数的本质

函数的本质就是一个引用类型,只不过它的类型为 func():

func main() {fmt.Printf("%T",f)
}
func f(s string)  {fmt.Println(s)
}

运行结果:

        所以,我们可以想到,当函数不加括号的时候函数就是一个类型,所以我们是否可以定义一个函数类型的变量?

func main() {fmt.Printf("%T\n",f)var f2 func(s string) = ff2("hello")// 打印函数的地址fmt.Println(f)fmt.Println(f2)
}
func f(s string)  {fmt.Println(s)
}

运行结果:

        可以看到,函数 f 被赋值给了一个为函数类型的变量 f2,而且这个 f2 已经具备了 f 的功能。而且我们可以看到,f 和 f2 的地址是相同的,这更加说明函数就是一个引用类型,我们给 f2 赋值的过程其实就是将 f 的地址传递给 f2。

2.3.2、匿名函数

Go 语言是支持函数式编程的:

  • 将匿名函数作为另一个函数的参数,回调函数
  • 将匿名函数作为另外一个函数的返回值,形成闭包
package mainimport ("fmt"
)func main() {f1()f2:=f1f2()// 匿名函数f3:=func(){fmt.Println("函数 f3")}f3()// 进一步简化func(){fmt.Println("函数 f4")}()// 带参数的匿名函数func(name string){fmt.Println("hello " + name)}("tom")// 带返回值的匿名函数sum:=func(a,b int) int{return a+b}(1,1)fmt.Println(sum)
}
func f1()  {fmt.Println("函数 f1")
}

2.3.3、回调函数

把一个函数作为另一个函数的参数:

比如:f2(f1())

其中,f2 就叫做高阶函数,f1 就叫做回调函数

func main(){res2 := f2(1,1,f1)fmt.Println(res2) // 2}
// 高阶函数
func f2(a,b int,f1 func(int,int) int) int {return f1(a,b)
}
// 回调函数
func f1(a,b int) int {return a+b
}

        这是一个非常高级的特性, 之后我们可以对同一个对象(高阶函数的参数)进行不同的业务操作,就可以通过给高阶函数传递不同的回调函数来执行不同的业务。

2.3.4、闭包

        如果一个函数包含层函数,内层函数可以操作外层函数的局部变量(当外层函数销毁,但是内存函数没有销毁,那么这个局部变量依旧存在),并且外层函数的返回值就是这个内层函数。而内层函数和外层函数的局部变量就称为闭包结构。

        在闭包结构中,局部变量的生命周期会发生改变,正常的局部变量的生命周期会随着函数创建而创建,随着函数的销毁而销毁。但是闭包结构中的外层函数的局部变量并不会随着外层函数的结束而销毁,因为内层函数还在继续使用。

package mainimport "fmt"func main() {r1 := increament()v1 := r1()fmt.Println("r1 => ",v1)v2 := r1()fmt.Println("r1 => ",v2)r2 := increament()fmt.Println("r2 => ",r2())fmt.Println("r2 => ",r2())fmt.Println("r1 => ",r1())
}
func increament() func() int {// 局部变量i := 0// 内层函数num := func() int{ // num 是 func() int 类型i++return i}return num
}

运行结果:

        在上面,当我们把 increament 函数赋值给 r1 的时候,相当于给了 r1 它的引用地址,所以 r1 可以直接执行。但是当我们把 increament 函数赋值给 r2 的时候,按道理给的是同一个引用地址(普通函数赋值给一个函数类型变量的时候一定是同一个地址),但事实上,它会给 r1 一个新的地址值:

package mainimport "fmt"func main() {r:=ffmt.Printf("r地址=%p,f地址=%p\n",r,f)r1 := increament()fmt.Printf("r1地址=%p,increament地址=%p\n",r1,increament)v1 := r1()fmt.Println("r1 => ",v1)v2 := r1()fmt.Println("r1 => ",v2)r2 := increament()fmt.Printf("r2地址=%p,increament地址=%p\n",r2,increament)fmt.Println("r2 => ",r2())fmt.Println("r2 => ",r2())fmt.Println("r1 => ",r1())
}
func increament() func() int {// 局部变量i := 0// 内层函数num := func() int{ // num 是 func() int 类型fmt.Printf("i 的地址=%p ",&i)i++return i}return num
}
func f(){fmt.Println("f")
}

运行结果:

        可以看到,首先,变量 r 和普通函数 f 的引用地址是完全一样的。

        而 r1 和 r2 同样都是直接通过 increament 直接赋值的,但是它们和 increament 的引用地址并不相同。此外,尽管 r1 和  r2 引用地址相同,但是它俩的局部变量 i 的地址并不相同!尽管 r1 和 r2 的引用地址相同,按道理它俩操作的是一个对象(内存地址),但是事实上这个对象的局部变量地址并不相同。

总结

        可以感觉到,Go 语言确实是一门简洁但是又严格的语言,它不像 Python 那种弱语言类型说来就来一个变量,什么类型都不知道。而且 Go 语言中的变量不使用就会报错、可以把不需要的值传给匿名变量抛弃掉,而且不占内存,所以也很高效。

        此外,Go 同样支持函数式编程,虽然不如 Scala 的支持度高,但是性能比 Scala 是要更加高效的。

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

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

相关文章

求矩阵对角线元素之和(C语言)

一、N-S流程图&#xff1b; 二、运行结果&#xff1b; 三、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h>int main() {//初始化变量值&#xff1b;int i 0;int j 0;int sum 0;int a[3][3] { 0 };//获取数组a的值&#xff1b;printf(&qu…

『大模型笔记』Code Example: Function Calling with ChatGPT

Code Example: Function Calling with ChatGPT 文章目录 一. Code Example: Function Calling with ChatGPT二. 参考文献一. Code Example: Function Calling with ChatGPT from openai import OpenAI from dotenv import load_dotenv import json# --------------------------…

标准汽车试验铁地板的技术要求

在现代科技化发展的工作中&#xff0c;试验平台被广泛使用。铸铁试验平台&#xff08;试验铁地板&#xff09;又叫试验工作平台&#xff0c;听名字大家也不难想象出来这是一款带有箱式体的台面&#xff0c;这是一种有长方形或者圆形又或者正方形的试验工作台。 铸铁试验平台&a…

调用WinPE给现有的Windows做一个备份

前言 前段时间有小伙伴问我&#xff1a;如何让给电脑备份系统。 小白直接告诉他&#xff1a;为啥要备份系统呢&#xff1f;直接给电脑创建一个还原点就好了。 Windows还原点创建教程&#xff08;点我跳转&#xff09; 没想到小伙伴的格局比小白大得多&#xff0c;他说&…

2024年第二十一届 五一杯 (C题)大学生数学建模挑战赛 | 多目标优化问题,深度学习分析 | 数学建模完整代码解析

DeepVisionary 每日深度学习前沿科技推送&顶会论文&数学建模与科技信息前沿资讯分享&#xff0c;与你一起了解前沿科技知识&#xff01; 本次DeepVisionary带来的是五一杯的详细解读&#xff1a; 完整内容可以在文章末尾全文免费领取&阅读&#xff01; 首先&…

编码方式导致的csv文件错误

写入csv文件时&#xff0c;假如出现了csv文件是乱码的情况&#xff0c;那么说明编码方式有问题&#xff0c;需要修改一下编码方式为utf-8-sig。 把编码方式修改一下为encodingutf-8-sig &#xff0c;再次运行就不会是乱码了&#xff0c;可见再读写csv文件时&#xff0c;假如使用…

【报错处理】ib_write_bw执行遇到Found Incompatibility issue with GID types.原因与解决办法

文章目录 拓扑现象根因解决办法解决后效果 拓扑 #mermaid-svg-zheSkw17IeCpjnVA {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-zheSkw17IeCpjnVA .error-icon{fill:#552222;}#mermaid-svg-zheSkw17IeCpjnVA .error…

Python语言零基础入门——模块

目录 一、模块的导入与使用 1.模块的导入 2.模块的使用 二、包的使用 1.包 2.包的使用 三、常见的标准库 1.random的运用举例 2.random小游戏 &#xff08;1&#xff09;石头剪刀布 &#xff08;2&#xff09;猜大小 3.re 4.time库的使用 5.turtle库的使用 6.so…

手把手实现一个简约酷美美的版权声明模块

1. 导语 版权声明在很多网站都有用到&#xff0c;出场率还是很高的。所以今天就实现一个属于自己分风格的版权声明模块&#xff0c;技术上采用原生的前端三剑客: HTMLCSSJavaScript(可能会用到) 比如CSDN的版权声明是这样的 2. 需求分析 先看看成品吧&#xff0c;这篇文字结…

Access to image at ... from origin ... has been blocked

Access to image at ‘http://127.0.0.1:3000/api/getImg?url/uploads/file/20240421/file-1713715007811-logo.png’ from origin ‘http://ggbol.gnway.cc’ has been blocked by CORS policy: The request client is not a secure context and the resource is in more-pri…

【C++】---模板进阶

【C】---模板进阶 一、模版参数1、类型参数2、非类型参数 二、模板的特化1、函数模板的特化2、类模板特化&#xff08;1&#xff09;全特化&#xff08;2&#xff09;偏特化 三、模板分离编译1、模板支持分离编译吗&#xff1f;2、为什么模板不支持分离编译&#xff1f;3、如何…

google search API 获取

登录谷歌云启动服务 首先登录谷歌云Google Cloud: https://console.cloud.google.com/&#xff0c;登录后创建一个项目。 选择创建的项目&#xff0c;进入API库。搜索Google Search。 选择custom Search API并启用。 此外&#xff0c;有个非常具有类似的API-- Google Search …

3D建模在游戏行业的演变和影响

多年来&#xff0c;游戏行业经历了显着的转变&#xff0c;这主要是由技术进步推动的。 深刻影响现代游戏的关键创新之一是 3D 建模领域。 从像素化精灵时代到我们今天探索的错综复杂的游戏世界&#xff0c;3D 建模已成为游戏开发不可或缺的基石。 本文讨论 3D 建模在游戏行业中…

PyVista 3D数据可视化 Python 库 一行代码实现裁剪 含源码

简介&#xff1a; Pyvista是一个用于科学可视化和分析的Python库,使3D数据可视化变得更加简单和易用&#xff1b; 只增加一行代码就可以实现裁剪&#xff1b; 1.效果&#xff1a; 2.代码如下&#xff1a; 加载模型数据&#xff1a; 代码实现&#xff1a; import pyvista a…

查找算法之二分查找

一、算法介绍 二分查找&#xff0c;也称为折半查找&#xff0c;是一种在有序数组中查找特定元素的高效算法。对于包含 n 个元素的有序数组&#xff0c;二分查找的步骤如下&#xff1a; 确定搜索范围&#xff1a;首先&#xff0c;将要查找的元素与数组中间的元素进行比较。如果…

引领农业新质生产力,鸿道(Intewell®)操作系统助力农业机器人创新发展

4月27日至29日&#xff0c;2024耒耜国际会议在江苏大学召开。科东软件作为特邀嘉宾出席此次盛会&#xff0c;并为江苏大学-科东软件“农业机器人操作系统”联合实验室揭牌。 校企联合实验室揭牌 在开幕式上&#xff0c;江苏大学、科东软件、上交碳中和动力研究院、遨博智能研究…

查看笔记本电池容量/健康状态

1. 打开命令行提示符 快捷键“win R”后输入“cmd” 2. 在命令提示符中输入命令 “powercfg /batteryreport" 并回车 3. 查看文件 最后就可以看到笔记本的电池使用报告了

高效率的做事方法?

高效率的做事方法可以帮助我们更好地管理时间和资源&#xff0c;以下是一些建议&#xff1a; 1.明确目标和计划&#xff1a; 在开始任何任务之前&#xff0c;先明确你的目标是什么。 制定一个详细的计划&#xff0c;包括步骤、时间表和预期结果。 将任务分解成小块&#xff0…

第11章 数据库技术(第一部分)

一、数据库技术术语 &#xff08;一&#xff09;术语 1、数据 数据描述事物的符号描述一个对象所用的标识&#xff0c;可以文字、图形、图像、语言等等 2、信息 现实世界对事物状态变化的反馈。可感知、可存储、可加工、可再生。数据是信息的表现形式和载体&#xff0c;信…

python实现的基于单向循环链表插入排序

相比于定义一个循环双向链表来实现插入排序来说&#xff0c;下面的实现采用一个单向循环链表来实现&#xff0c;并且不需要定义一个单向循环链表类&#xff0c;而是把一个list&#xff08;数组/顺序表&#xff09;当成单向循环链表来用&#xff0c;list的元素是一个包含两个元素…