当前位置: 首页 > news >正文

10、go工程化与标准库

目录

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

一、用go mod管理工程

  • 初始化项目go mod init $module_name,$module_name和目录名可以不一样。上述命令会生成go.mod文件
module maingo 1.19require 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())      //秒 -> 时间戳 1677915658fmt.Println(now.UnixMilli()) //毫秒 -> 时间戳 1677915658844fmt.Println(now.UnixMicro()) //微秒 -> 时间戳 1677915658844888fmt.Println(now.UnixNano())  //纳秒 -> 时间戳 1677915658844888900fmt.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 intfmt.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.Durationfmt.Println(useTime1.Seconds())     //0.000523fmt.Println(useTime1.Nanoseconds()) //523000fmt.Println("----------------------")//时间差计算方式2:end := time.Now()useTime2 := end.Sub(begin)          //计算时间差,返回类型是time.Durationfmt.Println(useTime2.Seconds())     //0.000523fmt.Println(useTime2.Nanoseconds()) //523000fmt.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:19fmt.Println(begin.Format(TIME_FMT1)) //2023-03-04fmt.Println(begin.Format(TIME_FMT2)) //20230304
}
  • 文本转时间
func time_parse() {//不建议直接使用Parseif t, err := time.Parse(TIME_FMT1, "2022-02-18"); err == nil {fmt.Println(t.Year())  //2022fmt.Println(t.Month()) //Februaryfmt.Println(t.Day())   //18}//建议使用ParseInLocationloc, _ := time.LoadLocation("Asia/Shanghai")if t, err := time.ParseInLocation(TIME_FMT1, "2022-02-18", loc); err == nil {fmt.Println(t.Year())  //2022fmt.Println(t.Month()) //Februaryfmt.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.Cfmt.Println(time.Now().Unix())}
}

2 - 数学计算

  • 数学常量
func main() {fmt.Println(math.E)                 //自然对数的底,2.718281828459045fmt.Println(math.Pi)                //圆周率,3.141592653589793fmt.Println(math.MaxInt)            //9223372036854775807fmt.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()) //NaNrect := math_nan()if math.IsNaN(rect) {fmt.Println("出错了")}
}
  • **常用函数 **
func main() {//常用函数fmt.Println(math.Ceil(1.1))     //向上取整,2fmt.Println(math.Floor(1.9))    //向下取整,1。 math.Floor(-1.9)=-2fmt.Println(math.Trunc(1.9))    //取整数部分,1fmt.Println(math.Modf(2.5))     //返回整数部分和小数部分,2  0.5fmt.Println(math.Abs(-2.6))     //绝对值,2.6fmt.Println(math.Max(4, 8))     //取二者的较大者,8fmt.Println(math.Min(4, 8))     //取二者的较小者,4fmt.Println(math.Mod(6.5, 3.5)) //x-Trunc(x/y)*y结果的正负号和x相同,3fmt.Println(math.Sqrt(9))       //开平方,3fmt.Println(math.Cbrt(9))       //开三次方,2.08008//对数和指数fmt.Println(math.Log(5))     //默认底数为自然对数math.E,1.60943fmt.Println(math.Log1p(4))   //等价于Log(1+p),确保结果为正数,1.60943fmt.Println(math.Log10(100)) //以10为底数,取对数,2fmt.Println(math.Log2(8))    //以2为底数,取对数,3fmt.Println(math.Pow(3, 2))  //x^y,9fmt.Println(math.Pow10(2))   //10^x,100fmt.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) { //随机打乱一个给定的slicearr[i], arr[j] = arr[j], arr[i]})fmt.Println(arr)
}
  • 自定义rand
func math_rand() {//创建一个Randsource := 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()) //必须重置一下Seedrander2 := 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 stringfmt.Scan(&s1)var s2 stringfmt.Scan(&s2)fmt.Printf("you input %s %s", s1, s2)var i intfmt.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.Builderfor {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 intfor {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.modinfo, _ := file.Stat()fmt.Println(info.IsDir())   //falsefmt.Println(info.ModTime()) //2023-03-02 15:30:15.2281889 +0800 CSTfmt.Println(info.Mode())    //-rw-rw-rw-fmt.Println(info.Size())    //57fmt.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()
}

相关文章:

10、go工程化与标准库

目录一、用go mod管理工程二、包引入规则三、init调用链四、可见性五、标准库1 - 时间函数2 - 数学计算3 - I/O操作4 - 编码一、用go mod管理工程 初始化项目&#xff1a;go mod init $module_name&#xff0c;$module_name和目录名可以不一样。上述命令会生成go.mod文件 mod…...

【Selenium自动化测试】鼠标与键盘操作

在 WebDriver 中&#xff0c;与鼠标操作相关的方法都封装在ActionChains 类中&#xff0c;与键盘操作相关的方法都封装在Keys类中。下面介绍下这两个类中的常用方法。 鼠标操作 ActionChains类鼠标操作常用方法&#xff1a; context_click()&#xff1a;右击double_click()&…...

自定义javax.validation校验枚举类

枚举类单一情况 package com.archermind.cloud.phone.dto.portal.external.validation.validator;import com.archermind.cloud.phone.dto.portal.external.validation.constraints.EnumValidation; import lombok.extern.slf4j.Slf4j;import javax.validation.ConstraintVali…...

[Java·算法·中等]LeetCode39. 组合总和

每天一题&#xff0c;防止痴呆题目示例分析思路1题解1分析思路2题解2&#x1f449;️ 力扣原文 题目 给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target &#xff0c;找出 candidates 中可以使数字和为目标数 target 的 所有 不同组合 &#xff0c;并以列表形…...

【Linux】vi和vim编辑器

目录主题主题 三种常见模式&#xff1a; 正常模式 以vim 打开一个档案就直接进入一般模式了(这是默认的模式)。在这个模式中&#xff0c;你可以使用[上下左右]按键来移动光标&#xff0c;你可以使用『删除字符』或『删除整行』来处理档案内容&#xff0c;也可以使用「复制、…...

BIO,NIO,AIO

IO模型 用什么样的通道进行数据传输和接收&#xff0c;java支持3种io网络编程模式 BIO NIO AIO BIO 同步阻塞 一个客户端连接对应一个处理线程 BIO示例代码&#xff08;客户端和服务端&#xff09; package com.tuling.bio;import java.io.IOException; import java.net.So…...

代码随想录刷题-数组-有序数组的平方

文章目录有序数组的平方习题暴力排序双指针有序数组的平方 本节对应代码随想录中&#xff1a;代码随想录&#xff0c;讲解视频&#xff1a;有序数组的平方_哔哩哔哩_bilibili 习题 题目链接&#xff1a;977. 有序数组的平方 - 力扣&#xff08;LeetCode&#xff09; 给你一…...

【玩转c++】stack和queue的介绍和模拟实现

本期主题&#xff1a;list的讲解和模拟实现博客主页&#xff1a; 小峰同学分享小编的在Linux中学习到的知识和遇到的问题小编的能力有限&#xff0c;出现错误希望大家不吝赐stack的介绍和使用1.1.stack的介绍1. stack是一种容器适配器&#xff0c;专门用在具有后进先出操作的上…...

Linux order(文件、磁盘、网络、系统管理、备份压缩)

1. Linux 文件命令 -rwxrwxrwx chmod&#xff1a;change mode&#xff0c;用于&#xff08;文件所有者或 root &#xff09;变更用户(u:owner g:group o:other a:all)的权限 chmod [OPTION]… MODE[,MODE]… FILE… OPTION -R&#xff1a;递归修改more option&#xff1a;chmod…...

最详细的CentOS7安装Mysql数据库服务

1.查看是否安装mysql: rpm -qa | grep mysql如果有查出来东西&#xff0c;使用命令删除&#xff1a; rpm -e xxx2.检查是否有mysql用户组和mysql用户,没有就添加有就忽略&#xff1a; groups mysql 添加用户组和用户 groupadd mysql && useradd -r -g mysql mysql&a…...

【IoT】项目管理:如何做好端到端的项目管理?

今天主要来谈谈项目管理这个话题。 首先来看一个我在网络上看到的一个关于项目管理的案例或者是段子。 将项目管理的作用及意义非常直观地展示了出来。 有一个植树搞绿化的企业&#xff0c;在公司内部设置有五个部门&#xff0c;分别是&#xff1a; 运输部门&#xff1b;挖坑部…...

渲染十万条数据就把你难住了?不存在的!

虚拟列表的使用场景如果我想要在网页中放大量的列表项&#xff0c;纯渲染的话&#xff0c;对于浏览器性能将会是个极大的挑战&#xff0c;会造成滚动卡顿&#xff0c;整体体验非常不好&#xff0c;主要有以下问题&#xff1a;页面等待时间极长&#xff0c;用户体验差CPU计算能力…...

编程学习的心路历程和困惑回顾

回首入行9年的经历&#xff0c;从大一开始学习C语言和数据结构&#xff0c;老师一直是在用IDE演示程序的编写和运行&#xff0c;我们也就一直在跟黑乎乎的命令行窗口打交道。 后来在一些课程的实验环节&#xff0c;接触到了一些别人编写好的工程代码&#xff0c;知道了Makefile…...

请介绍类加载过程,什么是双亲委派模型?

第23讲 | 请介绍类加载过程&#xff0c;什么是双亲委派模型&#xff1f; Java 通过引入字节码和 JVM 机制&#xff0c;提供了强大的跨平台能力&#xff0c;理解 Java 的类加载机制是深入 Java 开发的必要条件&#xff0c;也是个面试考察热点。 今天我要问你的问题是&#xff0…...

Navisworks编辑材质和Revit快速切换材质问题

一、如何在Navisworks2016中编辑材质 初次使用NW2016-2017时发现&#xff0c;原来用于创建编辑材质的小地球不见了&#xff0c;如图1所示&#xff0c;在各大技术群里求助没有回应&#xff0c;度娘搜索也总是摇头。 经过仔细排查可能出现的地方&#xff0c;终于找到了可以编辑材…...

Object对象键值的输出循序到底如何排列的?

1.日常摸鱼看八股 今天又是复习八股文的一天&#xff0c;发现还是彻底懂得原理才好和面试官吹牛批呀。 接着来看看我chat大宝贝的回答&#xff1a; 在现代浏览器中&#xff0c;Object 对象的键值输出循序是比较稳定的&#xff0c;通常是按照如下顺序输出&#xff1a; 所有的数…...

气泡式水位计的安装方法详解

气泡水位计的安装实际上就是气管的安装&#xff0c;气管的安装是否正确将直接影响到仪器测量数据的结果&#xff0c;气泡水位计它由活塞泵产生的压缩空气流经测量管和气泡室&#xff0c;进入被测的水体中&#xff0c;测量管中的静压力与气泡室上的水位高度成正比。那么接下来就…...

求“二维随机变量的期望E(X)与方差D(X)”例题(一)

离散型 设随机变量(X,Y)的联合分布律为 X\Y0100.10.210.30.4 (1)求E(X) 先求x的边缘分布律&#xff0c;表格里x0的概率为0.10.2&#xff0c;于是我们可得 X01P0.30.7直接求E(X)即可&#xff0c;得到结果 (2)求E(XY) 直接x与y相乘就行。 记得别乘多了&#xff0c;别的算了又…...

MySQL 搞定行转列,列转行

行转列方法总结1、使用case…when…then2、使用SUM(IF()) 生成列3、使用SUM(IF()) 生成列 WITH ROLLUP 生成汇总行4、使用SUM(IF()) 生成列 UNION 生成汇总行,并利用 IFNULL将汇总行标题显示为 Total5、使用SUM(IF()) 生成列&#xff0c;直接生成汇总结果&#xff0c;不再利用…...

正点原子裸机开发之C语言点灯程序

一. 简介 本文针对 IMX6ULL 的裸机开发的&#xff08;即不带Linux操作系统的开发&#xff09;。 主要分两部分的工作&#xff1a; 1. 配置 C语言运行环境 2. C 语言编写及运行 二. 配置C语言运行环境 配置 C 语言运行环境的工作分 三部分。如下&#xff1a; 1. 设置…...

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…...

React 第五十五节 Router 中 useAsyncError的使用详解

前言 useAsyncError 是 React Router v6.4 引入的一个钩子&#xff0c;用于处理异步操作&#xff08;如数据加载&#xff09;中的错误。下面我将详细解释其用途并提供代码示例。 一、useAsyncError 用途 处理异步错误&#xff1a;捕获在 loader 或 action 中发生的异步错误替…...

超短脉冲激光自聚焦效应

前言与目录 强激光引起自聚焦效应机理 超短脉冲激光在脆性材料内部加工时引起的自聚焦效应&#xff0c;这是一种非线性光学现象&#xff0c;主要涉及光学克尔效应和材料的非线性光学特性。 自聚焦效应可以产生局部的强光场&#xff0c;对材料产生非线性响应&#xff0c;可能…...

RocketMQ延迟消息机制

两种延迟消息 RocketMQ中提供了两种延迟消息机制 指定固定的延迟级别 通过在Message中设定一个MessageDelayLevel参数&#xff0c;对应18个预设的延迟级别指定时间点的延迟级别 通过在Message中设定一个DeliverTimeMS指定一个Long类型表示的具体时间点。到了时间点后&#xf…...

盘古信息PCB行业解决方案:以全域场景重构,激活智造新未来

一、破局&#xff1a;PCB行业的时代之问 在数字经济蓬勃发展的浪潮中&#xff0c;PCB&#xff08;印制电路板&#xff09;作为 “电子产品之母”&#xff0c;其重要性愈发凸显。随着 5G、人工智能等新兴技术的加速渗透&#xff0c;PCB行业面临着前所未有的挑战与机遇。产品迭代…...

CentOS下的分布式内存计算Spark环境部署

一、Spark 核心架构与应用场景 1.1 分布式计算引擎的核心优势 Spark 是基于内存的分布式计算框架&#xff0c;相比 MapReduce 具有以下核心优势&#xff1a; 内存计算&#xff1a;数据可常驻内存&#xff0c;迭代计算性能提升 10-100 倍&#xff08;文档段落&#xff1a;3-79…...

工程地质软件市场:发展现状、趋势与策略建议

一、引言 在工程建设领域&#xff0c;准确把握地质条件是确保项目顺利推进和安全运营的关键。工程地质软件作为处理、分析、模拟和展示工程地质数据的重要工具&#xff0c;正发挥着日益重要的作用。它凭借强大的数据处理能力、三维建模功能、空间分析工具和可视化展示手段&…...

论文浅尝 | 基于判别指令微调生成式大语言模型的知识图谱补全方法(ISWC2024)

笔记整理&#xff1a;刘治强&#xff0c;浙江大学硕士生&#xff0c;研究方向为知识图谱表示学习&#xff0c;大语言模型 论文链接&#xff1a;http://arxiv.org/abs/2407.16127 发表会议&#xff1a;ISWC 2024 1. 动机 传统的知识图谱补全&#xff08;KGC&#xff09;模型通过…...

根据万维钢·精英日课6的内容,使用AI(2025)可以参考以下方法:

根据万维钢精英日课6的内容&#xff0c;使用AI&#xff08;2025&#xff09;可以参考以下方法&#xff1a; 四个洞见 模型已经比人聪明&#xff1a;以ChatGPT o3为代表的AI非常强大&#xff0c;能运用高级理论解释道理、引用最新学术论文&#xff0c;生成对顶尖科学家都有用的…...

全志A40i android7.1 调试信息打印串口由uart0改为uart3

一&#xff0c;概述 1. 目的 将调试信息打印串口由uart0改为uart3。 2. 版本信息 Uboot版本&#xff1a;2014.07&#xff1b; Kernel版本&#xff1a;Linux-3.10&#xff1b; 二&#xff0c;Uboot 1. sys_config.fex改动 使能uart3(TX:PH00 RX:PH01)&#xff0c;并让boo…...