10、go工程化与标准库

news2025/1/11 5:44:20

目录

  • 一、用go mod管理工程
  • 二、包引入规则
  • 三、init调用链
  • 四、可见性
  • 五、标准库
    • 1 - 时间函数
    • 2 - 数学计算
    • 3 - I/O操作
    • 4 - 编码

一、用go mod管理工程

  • 初始化项目go mod init $module_name,$module_name和目录名可以不一样。上述命令会生成go.mod文件
module main

go 1.19

require gonum.org/v1/gonum v0.12.0

  • 包查找规则:Go依次从当前项目、GOROOT、GOPATH下寻找依赖包
    • 从当前go文件所在的目录逐级向上查找go.mod文件(假设go.mod位于目录mode_path下),里面定义了module_name,则引入包的路径为"module_name/包相对于mode_path的路径"
    • go标准库提供的包在GOROOT/src下
    • 第三方依赖包在GOPATH/pkg/mod下
  • 包管理命令
    • 从go1.7开始,go get只负责下载第三方依赖包,并把它加到go.mod文件里,由go install负责安装二进制文件
      • go get github.com/mailru/easyjson会在GOPATH/pkg/mod目录下生成github.com/mailru/easyjson目录
      • go install github.com/mailru/easyjson/easyjson会在GOPATH/bin下生成easyjson二进制可执行文件
    • go mod tidy通过扫描当前项目中的所有代码来添加未被记录的依赖至go.mod文件或从go.mod文件中删除不再被使用的依赖

二、包引入规则

  • 包的声明
    • go文件的第一行声明 package xxx
    • 在包声明的上面可写关于包的注释,包注释也可以专门写在doc.go里
    • 包名跟目录名可以不同
    • 同一个目录下,所有go文件的包名必须一致
  • **包的引用 **
    • 可以直接使用同目录下其他go文件里的变量、函数、结构体
    • 跨目录使用则需要变量前加入包名,并且引入包所在的目录
      • imoprt "go-course/package":go-course是model名,package是目录名
      • mypackage.Add():mypackage是包名,它对应的目录是package
    • 在import块里可以引用父目录,也可以引用子目录
    • 引用关系不能构成一个环
    • 在import的目录前面可以给包起一个别名
      • imoprt asd "go-course/package"
      • asd.Add()

三、init调用链

  • init函数
    • main函数是go程序的唯一入口,所以main函数只能存在一个;main函数必须位于main包中
    • 在main函数执行之前会先执行init()函数
    • 在一个目录,甚至一个go文件里,init()可以重复定义
    • 引入其他包时,相应包里的init()函数也会在main()函数之前被调用
  • 包引用而不用import _ "net/http/pprof"
    • 在目录前加一个_,代码里却没有显式地使用这个包里的函数或变量,实际上是想执行这个包里的init()函数

四、可见性

  • 可见性
    • 以小写字母开头命名的函数、变量、结构体只能在本包内访问
    • 以大写字母开头命名的函数、变量、结构体在其他包中也可以访问
    • 如果结构体名字以大写字母开头,而其成员变量、成员方法以小写字母开头,则这样的成员只能在本包内访问
  • internal包
    • Go中命名为internal的package,可以被平级目录和上一级目录所访问,更上层的目录不能访问
    • c目录(internal的上一级目录)及其子孙目录之间可以任意import,但a目录和b目录不能import internal及其下属的所有目录

在这里插入图片描述

五、标准库

1 - 时间函数

  • 时间属性
func time_pro() {
	now := time.Now()
	fmt.Println(now.Unix())      //秒 -> 时间戳 1677915658
	fmt.Println(now.UnixMilli()) //毫秒 -> 时间戳 1677915658844
	fmt.Println(now.UnixMicro()) //微秒 -> 时间戳 1677915658844888
	fmt.Println(now.UnixNano())  //纳秒 -> 时间戳 1677915658844888900

	fmt.Println(now.Weekday().String())
	fmt.Println(now.Hour())
	fmt.Println(now.Minute())
	fmt.Println(now.Second())
	fmt.Println(now.Month())
	fmt.Println(int(now.Month())) //3 -> type Month int
	fmt.Println(now.Year())
	fmt.Println(now.YearDay()) //当前年的第几天
	fmt.Println(now.Day())     //当前月的第几天
	fmt.Println(now.Date())    //2023 March 4

}
  • 时间运算
func time_calc() {
	begin := time.Now()

	for i := 1; i < 10000; i++ {
		fmt.Printf("")
	}
	fmt.Println("use some time")

	//时间差计算方式1:
	useTime1 := time.Since(begin)       //计算时间差,返回类型是time.Duration
	fmt.Println(useTime1.Seconds())     //0.000523
	fmt.Println(useTime1.Nanoseconds()) //523000
	fmt.Println("----------------------")

	//时间差计算方式2:
	end := time.Now()
	useTime2 := end.Sub(begin)          //计算时间差,返回类型是time.Duration
	fmt.Println(useTime2.Seconds())     //0.000523
	fmt.Println(useTime2.Nanoseconds()) //523000
	fmt.Println("----------------------")

	//获取相对时间
	dua := time.Duration(8 * time.Hour)
	end_dua := begin.Add(dua)
	fmt.Println(end_dua) //2023-03-04 23:53:38.4740063 +0800 CST m=+28800.002135201
}
  • 时间格式化
const (
	TIME_FMT  = "2006-01-02 15:04:05"
	TIME_FMT1 = "2006-01-02"
	TIME_FMT2 = "20060102"
)

func time_fmt() {
	begin := time.Now()
	fmt.Println(begin) //2023-03-04 16:01:19.7069136 +0800 CST m=+0.003180001
	//格式化必须使用 "2006-01-02 15:04:05" 此格式
	fmt.Println(begin.Format(TIME_FMT))  //2023-03-04 16:01:19
	fmt.Println(begin.Format(TIME_FMT1)) //2023-03-04
	fmt.Println(begin.Format(TIME_FMT2)) //20230304
}
  • 文本转时间
func time_parse() {
	//不建议直接使用Parse
	if t, err := time.Parse(TIME_FMT1, "2022-02-18"); err == nil {
		fmt.Println(t.Year())  //2022
		fmt.Println(t.Month()) //February
		fmt.Println(t.Day())   //18
	}

	//建议使用ParseInLocation
	loc, _ := time.LoadLocation("Asia/Shanghai")
	if t, err := time.ParseInLocation(TIME_FMT1, "2022-02-18", loc); err == nil {
		fmt.Println(t.Year())  //2022
		fmt.Println(t.Month()) //February
		fmt.Println(t.Day())   //18
	}
}
  • 周期执行time.NewTicker
func main() {
	tk := time.NewTicker(1 * time.Second)
	defer tk.Stop()
	for i := 0; i < 10; i++ {
		<-tk.C //阻塞1秒钟
		fmt.Printf("第[%d]次执行,[%d]\n", i, time.Now().Unix())
	}
	tk.Stop()
}
  • 定时执行time.NewTimer<-time.After
func main() {
	// tm := time.NewTimer(time.Duration(3 * time.Second))
	// type Duration int64 -> 可以不需要time.Duration,Nanosecond也是Duration类型
	// const (
	// 	Nanosecond  Duration = 1
	// 	Microsecond          = 1000 * Nanosecond
	// 	Millisecond          = 1000 * Microsecond
	// 	Second               = 1000 * Millisecond
	// 	Minute               = 60 * Second
	// 	Hour                 = 60 * Minute
	// )
	tm := time.NewTimer(3 * time.Second)
	defer tm.Stop()
	<-tm.C //阻塞3秒钟
	fmt.Println(time.Now().Unix())

	//或者用
	<-time.After(3 * time.Second) //阻塞3秒钟
	fmt.Println(time.Now().Unix())
}
  • 重复使用timerReset
func main() {
	tm := time.NewTimer(3 * time.Second)
	defer tm.Stop()
	<-tm.C //阻塞3秒钟
	fmt.Println(time.Now().Unix())

	for i := 0; i < 6; i++ {
		tm.Reset(1 * time.Second)//使用Reset可以多次使用Timer
		<-tm.C
		fmt.Println(time.Now().Unix())
	}
}

2 - 数学计算

  • 数学常量
func main() {
	fmt.Println(math.E)                 //自然对数的底,2.718281828459045
	fmt.Println(math.Pi)                //圆周率,3.141592653589793
	fmt.Println(math.MaxInt)            //9223372036854775807
	fmt.Println(uint64(math.MaxUint64)) //18446744073709551615
}
  • math.NaN()
func math_nan() float64 {
	if f, err := strconv.ParseFloat("12.56X8", 64); err == nil {
		return f
	} else {
		return math.NaN()
	}
}

func main() {
	fmt.Println(math.NaN()) //NaN
	rect := math_nan()
	if math.IsNaN(rect) {
		fmt.Println("出错了")
	}
}
  • **常用函数 **
func main() {
	//常用函数
	fmt.Println(math.Ceil(1.1))     //向上取整,2
	fmt.Println(math.Floor(1.9))    //向下取整,1。 math.Floor(-1.9)=-2
	fmt.Println(math.Trunc(1.9))    //取整数部分,1
	fmt.Println(math.Modf(2.5))     //返回整数部分和小数部分,2  0.5
	fmt.Println(math.Abs(-2.6))     //绝对值,2.6
	fmt.Println(math.Max(4, 8))     //取二者的较大者,8
	fmt.Println(math.Min(4, 8))     //取二者的较小者,4
	fmt.Println(math.Mod(6.5, 3.5)) //x-Trunc(x/y)*y结果的正负号和x相同,3
	fmt.Println(math.Sqrt(9))       //开平方,3
	fmt.Println(math.Cbrt(9))       //开三次方,2.08008

	//对数和指数
	fmt.Println(math.Log(5))     //默认底数为自然对数math.E,1.60943
	fmt.Println(math.Log1p(4))   //等价于Log(1+p),确保结果为正数,1.60943
	fmt.Println(math.Log10(100)) //以10为底数,取对数,2
	fmt.Println(math.Log2(8))    //以2为底数,取对数,3
	fmt.Println(math.Pow(3, 2))  //x^y,9
	fmt.Println(math.Pow10(2))   //10^x,100
	fmt.Println(math.Exp(2))     //e^x,7.389

	//三角函数

	fmt.Println(math.Sin(1))
	fmt.Println(math.Cos(1))
	fmt.Println(math.Tan(1))
	fmt.Println(math.Tanh(1))
}
  • 随机数生成
func math_rand() {
	rand.Seed(time.Now().UnixMilli()) //如果对两次运行没有一致性要求,可以不设seed随机种子
	fmt.Println(rand.Int())           //随机生成一个整数
	fmt.Println(rand.Float32())       //随机生成一个浮点数
	fmt.Println(rand.Intn(100))       //100以内的随机整数,[0,100)
	fmt.Println(rand.Perm(100))       //把[0,100)上的整数随机打乱

	arr := []int{1, 2, 3, 4, 5, 6, 7, 8, 9}
	rand.Shuffle(len(arr), func(i, j int) { //随机打乱一个给定的slice
		arr[i], arr[j] = arr[j], arr[i]
	})
	fmt.Println(arr)
}
  • 自定义rand
func math_rand() {
	//创建一个Rand
	source := rand.NewSource(time.Now().UnixMicro()) //seed相同的情况下,随机数生成器产生的数列是相同的
	rander := rand.New(source)
	for i := 0; i < 10; i++ {
		fmt.Printf("%d ", rander.Intn(100))
	}
	fmt.Println()
	source.Seed(time.Now().UnixMicro()) //必须重置一下Seed
	rander2 := rand.New(source)
	for i := 0; i < 10; i++ {
		fmt.Printf("%d ", rander2.Intn(100))
	}
}

3 - I/O操作

  • 格式化输出
输出格式输出内容
%t单词 true 或 false
%b表示为二进制
%d表示为十进制
%e(=%.6e)有 6 位小数部分的科学计数法,如 -1234.456e+78
%f(=%.6f)有 6 位小数部分,如 123.456123
%g根据实际情况采用 %e 或 %f 格式(获得更简洁、准确的输出)
%s直接输出字符串或者字节数组
%v值的默认格式表示
%+v类似 %v,但输出结构体时会添加字段名
%#v值的 Go 语法表示
值的类型的 Go 语法表示
  • 标准输入
func std_io() {
	fmt.Println("please input two string")
	var s1 string
	fmt.Scan(&s1)
	var s2 string
	fmt.Scan(&s2)
	fmt.Printf("you input %s %s", s1, s2)
	var i int
	fmt.Scan(&i)
	fmt.Printf("input int is %d", i)
}
  • 读写文件:一般使用read_file2来读文件
func read_file1() {
	if file, err := os.Open("go.mod"); err != nil {
		fmt.Println(err)
	} else {
		defer file.Close()
		var buffer strings.Builder
		for {
			bs := make([]byte, 1024)
			if n, err := file.Read(bs); err != nil {
				fmt.Println(err)
				if err == io.EOF { //读到文件末尾
					break
				}
			} else {
				fmt.Printf("从文件中读出了%d个字节\n", n)
				buffer.WriteString(string(bs))
			}
		}
		fmt.Println(buffer.String())
	}
}
func read_file2() {
	if file, err := os.Open("go.mod"); err != nil {
		fmt.Println(err)
	} else {
		defer file.Close()
		reader := bufio.NewReader(file) //使用bufio效率更高
		var i int
		for {
			if line, err := reader.ReadString('\n'); err != nil {
				fmt.Println(err)
				if err == io.EOF {
					break
				}
			} else {
				fmt.Printf("第%d行\n", i)
				fmt.Print(line)
				// fmt.Println(strings.Trim(line, "\n"))
				i++
			}
		}
	}
}
  • 写文件
func write_file1() {
	if file, err := os.OpenFile("lala.txt", os.O_CREATE|os.O_TRUNC|os.O_WRONLY, 0666); err != nil {
		fmt.Println(err)
	} else {
		defer file.Close()
		file.Write([]byte("hello\n"))
	}
}

func write_file2() {
	if file, err := os.OpenFile("lala.txt", os.O_CREATE|os.O_APPEND|os.O_WRONLY, 0666); err != nil {
		fmt.Println(err)
	} else {
		defer file.Close()
		writer := bufio.NewWriter(file) //使用bufio效率更高
		writer.WriteString("hello")     //只是把内容写到内存缓冲区
		writer.WriteString("\n")
		writer.Flush() //强行将缓冲区内容刷新到磁盘中
	}
}
  • **创建文件/目录 **:
    • os.Create(name string)//创建文件
    • os.Mkdir(name string, perm fs.FileMode)//创建目录
    • os.MkdirAll(path string, perm fs.FileMode)//增强版Mkdir,沿途的目录不存在时会一并创建
    • os.Rename(oldpath string, newpath string)//给文件或目录重命名,还可以实现move的功能
    • os.Remove(name string)//删除文件或目录,目录不为空时才能删除成功
    • os.RemoveAll(path string)//增强版Remove,所有子目录会递归删除
func main() {
	os.Remove("lala.txt")
	os.MkdirAll("p1/p2", 0666)
	os.Create("p1/p2/lala.txt")
	os.RemoveAll("p1")
	os.Create("old.txt")
	os.Rename("old.txt", "new.txt")
}
  • 获取文件属性
func main() {
	file, _ := os.Open("go.mod")
	fmt.Println(file.Name()) //go.mod
	info, _ := file.Stat()
	fmt.Println(info.IsDir())   //false
	fmt.Println(info.ModTime()) //2023-03-02 15:30:15.2281889 +0800 CST
	fmt.Println(info.Mode())    //-rw-rw-rw-
	fmt.Println(info.Size())    //57
	fmt.Println(info.Name())    //go.mod
}
  • 遍历目录
func walk_dir(path string) error {
	if fileInfos, err := ioutil.ReadDir(path); err != nil {
		return err
	} else {
		for _, fileInfo := range fileInfos {
			fmt.Println(fileInfo.Name())
			if fileInfo.IsDir() {
				// if err := walk_dir(path + "/" + fileInfo.Name()); err != nil {
				//更通用的写法,根据不同的操作系统来拼接目录
				if err := walk_dir(filepath.Join(path, fileInfo.Name())); err != nil {
					return err
				}
			}
		}
	}
	return nil
}

func main() {
	walk_dir("D:/Program Files")
}
  • log日志
func logger() {
	if file, err := os.OpenFile("mage.log", os.O_CREATE|os.O_APPEND|os.O_WRONLY, 0666); err != nil {
		fmt.Println(err)
	} else {
		defer file.Close()
		logWriter := log.New(file, "[BIZ_NAME]", log.Ldate|log.Lmicroseconds)
		logWriter.Println("hello")
		logWriter.Println("jack")
		logWriter.Println("tom")
	}
}

在这里插入图片描述

  • 系统命令
func sys_call() {
	cmd_path, err := exec.LookPath("netstat")
	if err != nil {
		fmt.Println("os不支持 netstat命令")
	} else {
		fmt.Println(cmd_path)
		cmd := exec.Command("netstat", "-s")
		output, err := cmd.Output()
		if err != nil {
			fmt.Println(err)
		} else {
			fmt.Print(string(output))
		}
	}

	//不需要接收执行返回
	cmd := exec.Command("calc")
	if err := cmd.Run(); err != nil {
		fmt.Println(err)
	}
}

4 - 编码

  • compress:compress包下实现了zlib、bzip、gip、lzw等压缩算法
func compress() {
	fin, _ := os.Open("go.mod")
	fout, _ := os.OpenFile("go.mod.zlib", os.O_CREATE|os.O_TRUNC|os.O_WRONLY, 0666)
	writer := zlib.NewWriter(fout)
	defer fin.Close()
	defer fout.Close()
	for {
		bs := make([]byte, 10)
		n, err := fin.Read(bs)
		if err != nil {
			if err == io.EOF {
				break
			} else {
				fmt.Println(err)
			}
		} else {
			writer.Write(bs[:n])
		}
	}
	writer.Flush()

	//读压缩文件
	fin, _ = os.Open("go.mod.zlib")
	reader, _ := zlib.NewReader(fin)
	io.Copy(os.Stdout, reader)
	reader.Close()
	fin.Close()
}
  • json:json是go标准库里自带的序列化工具,使用了反射,效率比较低
func test_json() {
	user := User{"jack", 18}
	if bs, err := json.Marshal(user); err != nil {
		fmt.Println(err)
	} else {
		fmt.Println(string(bs)) //{"Name":"jack","Age":18}
	}
}
  • easyjson
    • easyjson只针对预先定义好的json结构体对输入的json字符串进行纯字符串的截取,并将对应的json字段赋值给结构体
    • easyjson -all xxx.go 生成go文件中定义的结构体对应的解析
    • xxx.go所在的package不能是main

在这里插入图片描述

func test_easyjson() {
	user := stru.User{Name: "jack", Age: 18}
	if bs, err := easyjson.Marshal(user); err != nil {
		fmt.Println(err)
	} else {
		fmt.Println(string(bs)) //{"Name":"jack","Age":18}
	}
}
  • base64
    • base64经常在http环境下用来传输较长的信息
    • 任意byte数组都可以采用base64编码转为字符串,并且可以反解回byte数组
    • 编码和解码的方法是公开、确定的, base64不属于加密算法
func test_base64() {
	fin, _ := os.Open("C:/Users/nd/Desktop/Gopher.jpeg")
	bs := make([]byte, 1<<20)
	n, _ := fin.Read(bs)
	str := base64.StdEncoding.EncodeToString(bs[:n])
	fmt.Println(str)

	bbb, _ := base64.StdEncoding.DecodeString(str)
	fout, _ := os.OpenFile("pic.png", os.O_CREATE|os.O_TRUNC|os.O_WRONLY, 0666)
	fout.Write(bbb)
	fout.Close()
}

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

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

相关文章

除了「加机器」,其实你的微服务还能这样优化

生产实践中&#xff0c;如果遇到业务流量变高导致服务负载升高甚至报警&#xff0c;我们的第一反应往往是「加机器」。 俗话说&#xff0c;能用钱解决的问题都不是问题。 俗话又说&#xff0c;充钱你就能变得更强。 但是&#xff0c;作为一个有理想有抱负的架构师&#xff0c;…

前端——7.图像标签和路径

这篇文章&#xff0c;我们来讲解一下图像标签 目录 1.图像标签 1.1介绍 1.2实际展示 1.3图像标签的属性 1.3.1 alt属性 1.3.2 title属性 1.3.3 width / height 属性 1.3.4 border属性 1.4注意事项 2.文件夹 2.1目录文件夹和根目录 2.2 VSCode打开目录文件夹 3.路…

决策树学习报告

报告 一、基本概念 决策树的定义&#xff1a;首先&#xff0c;决策树是一种有监督的分类算法——即给定X&#xff0c;Y值&#xff0c;构建X&#xff0c;Y的映射关系。不同于线性回归等是多项式&#xff0c;决策树是一种树形的结构&#xff0c;一般由根节点、父节点、子节点、…

MyBatis-Plus的入门学习

MyBatis-Plus入门学习简介特性快速开始MyBatis-Plus的注解详解Tableld主键生成策略1、数据库自动增长 AUTO2、UUID3、Redis生成id4、MP主键自动生成TableNameTableField自动填充测试方法&#xff1a;update乐观锁select查所有根据id查多个id批量查询简单条件查询&#xff08;通…

MySQL性能优化

MySQL性能调优 存储数据类型优化 尽量避免使用 NULL尽量使用可以的最小数据类型。但也要确保没有低估需要存储的范围整型比字符串操作代价更低使用 MySQL 内建的数据类型&#xff08;比如date、time、datetime&#xff09;&#xff0c;比用字符串更快 基本数据类型 数字 整数…

中国巨头在NLP领域的大模型布局

什么是大模型&#xff1f; 大规模模型&#xff08;large-scale model&#xff09;是近年来人工智能领域的一个热点话题&#xff0c;因为它们可以对自然语言处理&#xff08;NLP&#xff09;和其他任务进行更准确和深入的处理。由于大模型需要庞大的计算资源和数据支持&#xf…

论文投稿指南——中文核心期刊推荐(国家财政)

【前言】 &#x1f680; 想发论文怎么办&#xff1f;手把手教你论文如何投稿&#xff01;那么&#xff0c;首先要搞懂投稿目标——论文期刊 &#x1f384; 在期刊论文的分布中&#xff0c;存在一种普遍现象&#xff1a;即对于某一特定的学科或专业来说&#xff0c;少数期刊所含…

SpringSecurity第二讲

目录 二、SpringSecurity02 2.1 JWT概述 2.1.1 JWT介绍 2.1.2 跨域认证问题 2.2 JWT的原理 2.3 JWT的数据结构 2.3.1 Header 2.3.2 Payload 2.3.3 Signature 2.4 JWT的使用方式 2.5 JWT的使用 2.5.1 引入JWT依赖 2.5.2 编写JWT工具类 2.6 编写前后端不分离的项目…

【C语言】每日刷题 —— 牛客语法篇(3)

前言 大家好&#xff0c;继续更新专栏c_牛客&#xff0c;不出意外的话每天更新十道题&#xff0c;难度也是从易到难&#xff0c;自己复习的同时也希望能帮助到大家&#xff0c;题目答案会根据我所学到的知识提供最优解。 &#x1f3e1;个人主页&#xff1a;悲伤的猪大肠9的博客…

sd卡格式化后数据恢复怎么操作

有时候我们需要清空SD卡数据文件&#xff0c;有时候则是因为需要修复SD卡所以需要格式化&#xff0c;但是却被提示无法格式化SD卡。这种情况往往是由于平时SD卡使用时的一些不良习惯或是SD卡中病毒&#xff0c;病毒在运行SD卡中的软件所造成的。那么sd卡格式化后数据恢复怎么操…

[数据结构]栈的深入学习-java实现

CSDN的各位uu们你们好,今天千泽带来了栈的深入学习,我们会简单的用代码实现一下栈, 接下来让我们一起进入栈的神奇小世界吧!0.速览文章一、栈的定义1. 栈的概念2. 栈的图解二、栈的模拟实现三.栈的经典使用场景-逆波兰表达式总结一、栈的定义 1. 栈的概念 栈&#xff1a;一种…

国密SM4分组密码算法

前言密码&#xff0c;是指使用特定变换对数据等信息进行加密保护或安全认证的物项&#xff08;承载算法、密钥、密文的介质&#xff09;和技术&#xff0c;主要用于加密和安全认证&#xff08;身份识别、完整性、抗抵赖性&#xff09;。密码按照保密等级&#xff0c;又分为核密…

06 电力电子仿真 MATLAB/Simulink

文章目录01 单相半波整流电路02 单相全波整流电路&#xff08;子系统封装模块&#xff09;03 三相桥式整流电路&#xff08;三相模块与示波器使用&#xff09;04 相控与斩控交交调压&#xff08;THD计算&#xff09;05 Buck电路&#xff08;PWM实现与闭环反馈&#xff09;06 单…

【STL】Vector剖析及模拟实现

✍作者&#xff1a;阿润菜菜 &#x1f4d6;专栏&#xff1a;C vector的常用接口 首先贴上&#xff1a;vector的文档介绍,以备查阅使用。 vector的基本框架&#xff1a; vector的成员变量分别是空间首部分的_start指针和最后一个元素的下一个位置的_finish指针&#xff0c;以…

Tomcat安装及启动

日升时奋斗&#xff0c;日落时自省 目录 1、Tomcat下载 2、JDK安装及配置环境 3、Tomcat配置环境 4、启动Tomcat 5、部署演示 1、Tomcat下载 直接入主题&#xff0c;下载Tomcat 首先就是别下错了&#xff0c;直接找官方如何看是不是广告&#xff0c;或者造假 搜索Tomc…

【强度混合和波段自适应细节融合:PAN-Sharpening】

Intensity mixture and band-adaptive detail fusion for pansharpening &#xff08;用于全色锐化的强度混合和波段自适应细节融合&#xff09; 全色锐化的目的是通过高分辨率单通道全色&#xff08;PAN&#xff09;图像锐化低分辨率多光谱&#xff08;MS&#xff09;图像&a…

ChatGPT、人工智能、人类和一些酒桌闲聊

© 2023 Conmajia Initiated 10th March, 2023 昨天跟某化学家喝酒&#xff0c;期间提到了 ChatGPT。他的评价是&#xff1a;这鬼东西大量输出毫无意义、错漏百出甚至是虚假的信息&#xff0c;“in a confident accent”。例如某次 GPT 针对“描述某某记者”这一问题&#…

C++的入门

C的关键字 C总计63个关键字&#xff0c;C语言32个关键字 命名空间 我们C的就是建立在C语言之上&#xff0c;但是是高于C语言的&#xff0c;将C语言的不足都弥补上了&#xff0c;而命名空间就是为了弥补C语言的不足。 看一下这个例子。在C语言中会报错 #include<stdio.h>…

【C++】C++11——左右值|右值引用|移动语义|完美转发

文章目录一、左值与右值1.概念2.引用3.注意二、右值引用的意义1.左值引用意义2.右值引用和移动语义3.容器新增三、万能引用四、完美转发一、左值与右值 1.概念 左值是什么&#xff1f;右值是什么&#xff1f; 左值是一个表示数据的表达式&#xff08;如变量名或解引用的指针&…

学校学生心理测评系统

青少年在线心理测评系统 这款系统&#xff0c;是和北大合作开发&#xff0c;并真实用于线上测评场景&#xff0c;该项目有完整后台&#xff0c;以及学生管理等模块。 我们欢迎以下形式合作&#xff1a; 单纯研究项目。合作对该测评平台进行升级。单纯使用。 请联系我们 silv…