100天精通Golang(基础入门篇)——第15天:深入解析Go语言中函数的应用:从基础到进阶,助您精通函数编程!(进阶)

在这里插入图片描述

🌷 博主 libin9iOak带您 Go to Golang Language.✨
🦄 个人主页——libin9iOak的博客🎐
🐳 《面试题大全》 文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺
🌊 《IDEA开发秘籍》学会IDEA常用操作,工作效率翻倍~💐
🪁 希望本文能够给您带来一定的帮助🌸文章粗浅,敬请批评指正!🐥

100天精通Golang(基础入门篇)

  • 100天精通Golang(基础入门篇)——第15天:深入解析Go语言中函数的应用(进阶)
  • 摘要:
  • 引言
  • 100天精通Golang(基础入门篇)——第15天:深入解析Go语言中的函数
    • 第一节:函数基础
      • 1.1 什么是函数
      • 1.2 函数的声明和定义
      • 1.3 函数的调用和返回值
    • 第二节:函数参数
      • 2.1 参数的基本使用
      • 2.2 可变参数函数
      • 2.3 值传递和引用传递
    • 第三节:多返回值和空白标识符
      • 3.1 函数的多返回值
      • 3.2 使用空白标识符处理不需要的返回值
    • 第四节:函数的作用域和变量
      • 4.1 局部变量和作用域
      • 4.2 全局变量和包级函数
    • 第五节:匿名函数和闭包
      • 5.1 匿名函数的定义和使用
      • 5.2 闭包的概念和实现
    • 第六节:延迟执行(defer)
      • 6.1 延迟执行的概念和用途
      • 6.2 使用defer延迟函数的执行
      • 6.3 defer和参数的注意事项
    • 第七节:错误处理
      • 7.1 错误处理的基本原则
      • 7.2 使用error类型返回和处理错误
      • 7.3 错误处理的最佳实践和常见模式
    • 第八节:函数的高级特性
      • 8.1 递归函数
      • 8.2 函数作为参数和返回值
    • 第八节:函数类型和方法
      • 8.3 函数类型和方法
        • 8.3.1 函数类型的定义和使用
        • 8.3.2 方法的定义和使用
    • 第九节:Go语言函数与Java函数的区别
      • 9.1 函数的声明和调用方式
      • 9.2 参数传递方式的差异
      • 9.3 错误处理机制的不同
  • 代码案例总结:
    • 今日学习总结:
  • 结语

100天精通Golang(基础入门篇)——第15天:深入解析Go语言中函数的应用(进阶)

摘要:

本篇文章是《100天精通Golang(基础入门篇)》系列的第15天,我们将继续深入解析Go语言中函数的应用。通过对函数的基础知识、参数传递、多返回值、作用域、匿名函数、闭包、延迟执行、错误处理、函数的高级特性以及Go语言函数与Java函数的区别进行探讨,我们将更全面地理解和应用函数的相关知识点。

在这篇博客中,我们将深入探讨Go语言中函数的基本概念。函数作为Go语言的重要组成部分,具有封装、重用和模块化的特性,为我们编写高效、可维护和可测试的代码提供了便利。我们将从函数的定义、声明和调用开始,逐步深入到参数传递、返回值、作用域、匿名函数、闭包、延迟执行、错误处理、递归函数、函数作为参数和返回值、函数类型和方法等方面的内容。

在本篇博客中,您将学习到以下内容:

  • 函数的基本概念和定义方法
  • 函数的调用和返回值处理
  • 函数参数的基本使用和可变参数函数的特性
  • 值传递和引用传递的区别
  • 函数的多返回值和空白标识符的应用
  • 函数的作用域和变量的可见性
  • 匿名函数的定义和使用场景
  • 闭包的概念和实现方式
  • 延迟执行的概念和使用方法
  • 错误处理的基本原则和使用error类型返回错误
  • 递归函数的概念和应用场景
  • 函数作为参数和返回值的灵活应用
  • 函数类型和方法的定义和使用

引言

函数作为编程中重要的构建块,是开发过程中必不可少的一部分。在前面的学习中,我们已经掌握了函数的基本概念和使用方法。在本篇文章中,我们将进一步深入学习函数的应用,并探索一些进阶的概念和技巧。通过学习这些内容,我们将更加灵活地使用函数,提高代码的可读性和可维护性。

通过阅读本篇博客,您将深入了解Go语言函数的基本概念和特性,掌握函数的使用技巧和常见模式。同时,您还将对函数在Go语言中与其他语言的区别和优势有更清晰的认识。让我们开始这段精彩的学习之旅,深入解析Go语言中函数的基本概念!

100天精通Golang(基础入门篇)——第15天:深入解析Go语言中的函数

第一节:函数基础

1.1 什么是函数

函数是Go语言中用来封装可重用代码的基本单位。函数可以接受输入参数并返回输出结果,使代码更加模块化、可维护和可测试。

1.2 函数的声明和定义

函数的声明和定义包括函数名、参数列表和返回值类型的使用。示例代码如下:

func add(a, b int) int {return a + b
}

1.3 函数的调用和返回值

函数的调用可以传递参数并处理返回值。示例代码如下:

result := add(3, 4)
fmt.Println(result) // 输出:7

第二节:函数参数

2.1 参数的基本使用

函数参数用于接受外部传递的数据。示例代码如下:

func greet(name string) {fmt.Println("Hello, " + name + "!")
}greet("Alice") // 输出:Hello, Alice!

2.2 可变参数函数

可变参数函数允许传递可变数量的参数。示例代码如下:

func sum(nums ...int) int {total := 0for _, num := range nums {total += num}return total
}result := sum(1, 2, 3, 4, 5)
fmt.Println(result) // 输出:15

2.3 值传递和引用传递

函数参数可以通过值传递或引用传递进行传递。示例代码如下:

func updateName(name string) {name = "Bob"
}func updateAge(age *int) {*age = 30
}name := "Alice"
updateName(name)
fmt.Println(name) // 输出:Aliceage := 25
updateAge(&age)
fmt.Println(age) // 输出:30

第三节:多返回值和空白标识符

3.1 函数的多返回值

函数可以返回多个值,示例代码如下:

func divmod(a, b int) (int, int) {return a / b, a % b
}quotient, remainder := divmod(10, 3)
fmt.Println(quotient, remainder) // 输出:3 1

3.2 使用空白标识符处理不需要的返回值

使用空白标识符可以处理不需要的函数返回值。示例代码如下:

func getName() (string, string) {return "John", "Doe"
}first, _ := getName()
fmt.Println(first) // 输出:John

第四节:函数的作用域和变量

4.1 局部变量和作用域

局部变量的作用域限定在函数内部。示例代码如下:

func calculateSum(a, b int) int {sum := a + breturn sum
}result := calculateSum(3, 4)
fmt.Println(result) // 输出:7

4.2 全局变量和包级函数

全局变量在整个包中可见。示例代码如下:

var counter intfunc increment() {counter++
}func main() {increment()increment()fmt.Println(counter) // 输出:2
}

第五节:匿名函数和闭包

5.1 匿名函数的定义和使用

匿名函数是一种没有名称的函数,可以直接在代码中定义和使用。通过匿名函数,我们可以将其作为值进行传递、赋值给变量或作为其他函数的参数和返回值。匿名函数通常用于简化代码,尤其是在需要定义一些较小的功能代码块时。

下面是匿名函数的定义和使用示例代码:

greet := func(name string) {fmt.Println("Hello, " + name + "!")
}greet("Alice") // 输出:Hello, Alice!

在上述示例中,我们定义了一个匿名函数 greet,它接受一个参数 name,并打印出相应的问候语。然后我们通过将参数 "Alice" 传递给 greet 函数,调用并输出结果为 Hello, Alice!

5.2 闭包的概念和实现

闭包是由函数和其相关的引用环境组合而成的实体。闭包中的函数可以访问和操作其创建时的上下文环境中的变量,即使在其创建的上下文环境不存在或已经销毁时仍然有效。

下面是闭包的概念和实现示例代码:

func incrementGenerator() func() int {count := 0return func() int {count++return count}
}increment := incrementGenerator()
fmt.Println(increment()) // 输出:1
fmt.Println(increment()) // 输出:2

在上述示例中,我们定义了一个名为 incrementGenerator 的函数,它返回一个内部函数。内部函数是一个闭包,它可以访问 incrementGenerator 函数中定义的局部变量 count。每次调用内部函数时,count 的值都会增加,并返回增加后的值。

main 函数中,我们调用 incrementGenerator 函数,并将返回的内部函数赋值给变量 increment。通过调用 increment 函数,我们可以实现一个简单的计数器功能。每次调用 increment 函数,计数器的值就会增加,并打印出结果。

闭包的优点是可以保持状态和封装数据,使得代码更加简洁和灵活。它常用于需要记忆状态或延迟执行的场景,如计数器、事件处理等。然而,使用闭包时需要注意内存管理和潜在的副作用,避免引发意外的结果或资源泄漏。

第六节:延迟执行(defer)

延迟执行(defer)是一种在函数执行结束前延迟执行某个语句或函数调用的机制。延迟执行语句或函数调用的操作会被添加到一个栈中,并在函数返回之前按照后进先出(LIFO)的顺序执行。

延迟执行通常用于在函数执行结束后执行一些清理操作,例如关闭文件句柄、释放资源、解锁互斥锁等。它能够确保这些操作在函数返回之前被执行,即使函数发生错误或提前返回。

延迟执行通过 defer 关键字实现。在使用 defer 关键字时,需要在要延迟执行的语句或函数调用前添加 defer 关键字。当函数执行到 defer 语句时,该语句不会立即执行,而是被添加到延迟栈中。当函数执行完毕即将返回时,延迟栈中的操作会按照后进先出的顺序执行。

下面是一个延迟执行的示例代码:

func doSomething() {fmt.Println("Doing something...")defer fmt.Println("Cleanup") // 在函数返回前执行// 其他操作...fmt.Println("Function end")
}func main() {doSomething()
}

在上述示例中,我们定义了一个 doSomething 函数,在函数中添加了一个延迟执行的语句 defer fmt.Println("Cleanup")。当函数执行到该语句时,它并不会立即执行,而是被添加到延迟栈中。然后函数会继续执行其他操作,最后在函数即将返回时,延迟栈中的操作会被执行。这样就确保了清理操作在函数返回前被执行。

在运行示例代码时,输出结果如下:

Doing something...
Function end
Cleanup

可以看到,延迟执行的语句 "Cleanup" 在函数返回之前被执行。

延迟执行在处理资源管理和错误处理时非常有用,它能够简化代码并确保必要的清理操作不会被遗漏。同时,需要注意延迟执行的特性,确保在延迟执行的代码中不会出现对外部变量的修改或操作。

6.1 延迟执行的概念和用途

延迟执行是指在函数返回之前执行某个语句或函数。示例代码如下:

func cleanup() {fmt.Println("Performing cleanup...")
}func main() {defer cleanup()fmt.Println("Executing main function...")```go// 输出:Executing main function...// 输出:Performing cleanup...
}

6.2 使用defer延迟函数的执行

通过defer关键字可以延迟函数的执行。示例代码如下:

func main() {defer fmt.Println("World")fmt.Println("Hello")
}
    // 输出:Hello// 输出:World
}

6.3 defer和参数的注意事项

使用defer时需要注意参数的值在defer语句执行时被计算并保存。示例代码如下:

func main() {name := "Alice"defer fmt.Println("Hello, " + name + "!")name = "Bob"
}

go
// 输出:Hello, Alice!

第七节:错误处理

7.1 错误处理的基本原则

错误处理是编写健壮代码的重要组成部分。在开发过程中,我们经常会遇到各种可能发生的错误情况,如文件读写错误、网络连接问题、数据格式错误等。良好的错误处理机制可以帮助我们及时发现和处理这些错误,提高程序的健壮性和可靠性。

在错误处理中,有一些基本原则值得我们遵循:

  1. 错误检查:在关键的代码逻辑中进行错误检查是必要的。我们应该通过返回错误值来指示操作是否成功,而不是简单地忽略错误。例如,当打开文件时,我们应该检查是否发生了错误并及时进行处理。

  2. 错误处理:在发生错误时,我们应该有明确的错误处理策略。根据实际情况,可以选择记录错误日志、返回错误信息给调用方、降级处理或终止程序运行等。这取决于具体的业务需求和程序设计。

  3. 错误传递:在函数调用链中,应该将错误传递给调用者,而不是在每个函数中处理错误。这样可以保持代码的清晰和简洁,并且有助于更好地追踪和调试错误。

  4. 错误类型:在Go语言中,我们可以使用error类型来表示错误。这是一个内置接口类型,通常用于表示操作是否成功以及错误的具体信息。我们可以自定义实现该接口来提供更具体的错误信息。

良好的错误处理机制能够帮助我们更好地理解和调试代码,减少潜在的错误和异常情况对程序的影响。在编写代码时,请始终考虑错误处理,并遵循上述基本原则来编写健壮的代码。

7.2 使用error类型返回和处理错误

Go语言中使用error类型来表示错误,并提供了处理错误的机制。示例代码如下:

func divide(a, b float64) (float64, error) {if b == 0 {return 0, fmt.Errorf("division by zero")}return a / b, nil
}result, err := divide(10, 0)
if err != nil {fmt.Println("Error:", err)
} else {fmt.Println("Result:", result)
}
// 输出:Error: division by zero

7.3 错误处理的最佳实践和常见模式

在错误处理过程中,有一些最佳实践和常见模式可以帮助我们更好地处理错误,提高代码的可读性和可维护性。

  1. 错误传递:在函数调用链中,应该将错误传递给调用者,而不是在每个函数中处理错误。这样可以保持代码的简洁和清晰,并且能够更好地追踪和调试错误。调用者可以根据实际需求选择合适的错误处理方式,如记录日志、返回错误信息给上层调用者等。

  2. 错误包装:有时候,我们需要对错误进行包装,以提供更多的上下文信息或错误链。通过使用errors包中的Wrap函数,我们可以将原始错误包装为一个新的错误,并提供额外的上下文信息。这样做可以在错误处理过程中保留原始错误的信息,并提供更清晰的错误链。

    func ReadFile(filename string) ([]byte, error) {data, err := ioutil.ReadFile(filename)if err != nil {return nil, fmt.Errorf("read file: %w", err)}return data, nil
    }
    

    在调用该函数时,我们可以使用errors包中的Unwrap函数来获取原始的错误,并进行逐层处理。

  3. 错误日志记录:在错误处理过程中,及时记录错误日志是一个好习惯。我们可以使用Go语言的日志库,如log包或第三方日志库,来记录错误信息。将错误日志记录到适当的位置,可以帮助我们快速定位和解决问题。

    func ProcessData(data []byte) error {// 处理数据...if err != nil {log.Printf("error processing data: %v", err)return err}return nil
    }
    

    在代码中添加适当的日志记录,可以帮助我们跟踪错误发生的位置和原因,便于排查和修复问题。

  4. 错误类型断言:有时候,我们需要判断错误类型以执行特定的处理逻辑。使用类型断言可以帮助我们检查错误是否属于特定类型,从而执行相应的处理代码。

    func ProcessData(data []byte) error {// 处理数据...if err != nil {if _, ok := err.(*MyCustomError); ok {// 执行特定的处理逻辑...}return err}return nil
    }
    

    在错误处理过程中,根据实际情况使用类型断言可以使代码更灵活和可扩展。

通过遵循以上最佳实践和常见模式,我们可以更好地处理错误,提高代码的可读性和可维护性。在编写代码时,请始终考虑错误处理并选择适当的模式,以保证代码的健壮性和稳定性。

第八节:函数的高级特性

8.1 递归函数

递归函数是指调用自身的函数。我们将学习递归函数的概念和使用方法,并通过示例代码展示递归的应用场景。

8.2 函数作为参数和返回值

在Go语言中,函数也可以作为参数传递给其他函数,或作为函数的返回值。示例代码如下:

func calculate(a, b int, operation func(int, int) int) int {return operation(a, b)
}func add(a, b int) int {return a + b
}result := calculate(3, 4, add)
fmt.Println(result) // 输出:7

通过本篇博客的学习,您将对Go语言中的函数有更深入的了解,掌握函数的基础知识和高级特性。在后续学习中,您将能够更加灵活地使用函数,并能够区分Go语言函数与Java函数的区别和特点。

第八节:函数类型和方法

8.3 函数类型和方法

在Go语言中,函数也可以作为一种类型进行定义和使用。函数类型可以像普通变量一样被赋值、传递给其他函数和作为函数的返回值。同时,Go语言还支持为特定类型定义方法,使得这些方法可以直接在类型上调用。

8.3.1 函数类型的定义和使用

我们可以使用type关键字定义一个函数类型,示例代码如下:

type MathFunc func(int, int) intfunc add(a, b int) int {return a + b
}func subtract(a, b int) int {return a - b
}func calculate(a, b int, operation MathFunc) int {return operation(a, b)
}result1 := calculate(3, 4, add)
result2 := calculate(5, 2, subtract)fmt.Println(result1) // 输出:7
fmt.Println(result2) // 输出:3

在上述示例中,我们定义了一个名为MathFunc的函数类型,它接受两个int类型的参数并返回一个int类型的结果。然后,我们定义了两个与MathFunc类型兼容的函数addsubtract。最后,我们使用calculate函数来执行不同的操作,根据传入的函数参数进行计算。

8.3.2 方法的定义和使用

在Go语言中,我们可以为特定的类型定义方法。方法是与类型关联的函数,可以在类型的实例上直接调用。

示例代码如下:

type Rectangle struct {width, height float64
}func (r Rectangle) Area() float64 {return r.width * r.height
}func main() {rect := Rectangle{width: 3, height: 4}fmt.Println(rect.Area()) // 输出:12
}

在上述示例中,我们定义了一个Rectangle类型,它有一个方法Area用于计算矩形的面积。在Area方法的定义中,我们使用了接收者(r Rectangle)来指定该方法与Rectangle类型关联。通过在main函数中创建一个Rectangle类型的实例并调用Area方法,我们可以计算矩形的面积。

第九节:Go语言函数与Java函数的区别

9.1 函数的声明和调用方式

Go语言函数的声明和调用方式与Java有一些差异。在Go语言中,函数声明的语法是func 函数名(参数列表) 返回值类型,而Java中的函数声明是返回值类型 函数名(参数列表)。此外,Go语言函数的命名规范遵循驼峰式命名约定,而Java中的函数命名规范是小驼峰式

示例代码如下:

func add(a, b int) int {return a + b
}result := add(3, 4)
fmt.Println(result) // 输出:7

9.2 参数传递方式的差异

在Go语言中,函数的参数传递方式可以是值传递或引用传递,而Java中函数的参数传递方式是值传递。这意味着在Go语言中,如果传递的是可修改的数据类型(如切片、映射和指针等),函数内部对参数的修改会影响到外部的数据。

示例代码如下:

func updateName(name *string) {*name = "Bob"
}name := "Alice"
updateName(&name)
fmt.Println(name) // 输出:Bob

9.3 错误处理机制的不同

Go语言和Java在错误处理机制上有一些不同。在Java中,异常处理是一种常见的错误处理方式,而Go语言使用error类型来表示错误,并鼓励使用函数返回错误值来处理错误。

示例代码如下:

func divide(a, b float64) (float64, error) {if b == 0 {return 0, errors.New("division by zero")}return a / b, nil
}result, err := divide(10, 0)
if err != nil {fmt.Println("Error:", err)
} else {fmt.Println("Result:", result)
}

在上述示例中,我们定义了一个divide函数用于进行除法运算,并返回商和错误。如果除数为0,则返回一个表示错误的error类型值。在调用该函数时,我们使用err变量来接收返回的错误值,如果不为空,则表示出现了错误。

通过以上的内容,我们了解了函数类型和方法的概念,并且比较了Go语言函数与Java函数在声明和调用方式、参数传递方式以及错误处理机制方面的不同之处。这将帮助我们更好地理解Go语言的函数特性和与其他语言的区别。

代码案例总结:


package mainimport ("errors""fmt"
)// 1.1 什么是函数
func greet(name string) {fmt.Println("Hello, " + name + "!")
}// 1.2 函数的声明和定义
func add(a, b int) int {return a + b
}// 1.3 函数的调用和返回值
func calculateSum(a, b int) int {sum := add(a, b)return sum
}// 2.1 参数的基本使用
func multiply(a, b int) {fmt.Println(a * b)
}// 2.2 可变参数函数
func sum(nums ...int) int {total := 0for _, num := range nums {total += num}return total
}// 2.3 值传递和引用传递
func updateName(name *string) {*name = "Bob"
}// 3.1 函数的多返回值
func divide(a, b float64) (float64, error) {if b == 0 {return 0, errors.New("division by zero")}return a / b, nil
}// 3.2 使用空白标识符处理不需要的返回值
func getName() (string, string) {return "John", "Doe"
}// 4.1 局部变量和作用域
func calculateArea(length, width float64) float64 {area := length * widthreturn area
}// 4.2 全局变量和包级函数
var counter intfunc increment() {counter++
}// 5.1 匿名函数的定义和使用
func anonymousFunction() {func() {fmt.Println("This is an anonymous function")}()
}// 5.2 闭包的概念和实现
func closure() func() int {count := 0return func() int {count++return count}
}// 6.1 延迟执行的概念和用途
func cleanup() {fmt.Println("Performing cleanup...")
}// 6.2 使用defer延迟函数的执行
func main() {defer cleanup()fmt.Println("Executing main function...")// 6.3 defer和参数的注意事项name := "Alice"defer func(name string) {fmt.Println("Deferred execution:", name)}(name)name = "Bob"// 7.1 错误处理的基本原则result, err := divide(10, 2)if err != nil {fmt.Println("Error:", err)} else {fmt.Println("Result:", result)}// 7.2 使用error类型返回和处理错误firstName, _ := getName()fmt.Println("First name:", firstName)// 8.1 递归函数fmt.Println("Factorial of 5:", factorial(5))// 8.2 函数作为参数和返回值result1 := calculate(3, 4, add)fmt.Println("Result1:", result1)// 8.3 函数类型和方法rect := Rectangle{width: 3, height: 4}fmt.Println("Rectangle area:", rect.Area())// 9.1 函数的声明和调用方式fmt.Println("Sum of 3 and 4:", add(3, 4))// 9.2 参数传递方式的差异name := "Alice"updateName(&name)fmt.Println("Updated name:", name)// 9.3 错误处理机制的不同result2, err := divide(10, 0)if err != nil {fmt.Println("Error:", err)} else {fmt.Println("Result:", result2)}
}// 8.1 递归函数
func factorial(n int) int {if n == 0 {return 1}return n * factorial(n-1)
}// 8.2 函数作为参数和返回值
func calculate(a, b int, operation func(int, int) int) int {return operation(a, b)
}// 8.3 函数类型和方法
type MathFunc func(int, int) intfunc add(a, b int) int {return a + b
}type Rectangle struct {width, height float64
}func (r Rectangle) Area() float64 {return r.width * r.height
}func main() {// 8.3 函数类型和方法var mathFunc MathFuncmathFunc = addresult := mathFunc(3, 4)fmt.Println("Result:", result)// 8.3 函数类型和方法rect := Rectangle{width: 3, height: 4}fmt.Println("Rectangle area:", rect.Area())
}

以上代码综合了前八节中的所有知识点,涵盖了函数的基础、参数传递、返回值、作用域、匿名函数、闭包、延迟执行、错误处理、递归函数、函数作为参数和返回值、函数类型和方法等内容。通过这个综合代码案例,您可以更全面地了解和学习Go语言中函数的使用和特性。

今日学习总结:

在今天的学习中,我们深入了解了Go语言中函数的应用。我们从函数的基础知识出发,探讨了函数的参数传递、多返回值、作用域和变量的特性。我们还学习了匿名函数和闭包的概念及其实现方式。此外,我们了解了延迟执行的概念和使用方法,以及错误处理的基本原则和最佳实践。在函数的高级特性方面,我们学习了递归函数和函数作为参数和返回值的应用。最后,我们对比了Go语言函数与Java函数之间的区别。通过今天的学习,我们对函数的应用有了更深入的了解,并且可以更好地运用函数来解决实际问题。

在这里插入图片描述

结语

通过今天的学习,您已经踏上了Golang的学习之旅。在未来的日子里,您将探索Golang的各个方面,从基础概念到高级技巧,从实际应用到性能优化。
学习一门编程语言是一个持续的过程,每一天都是您向Golang的精通迈进的重要一步。我鼓励您坚持每天学习,保持热情和好奇心,解决挑战并享受成功的喜悦。

在您的学习旅程中,不要忘记参与社区和与其他Golang开发者交流。分享您的见解和经验,向他人学习,并在开源项目或实际应用中展示您的技能。

如果您在学习过程中遇到困难或有任何问题,不要犹豫向社区和专家寻求帮助。持续学习,勇敢探索,您将在Golang领域取得令人瞩目的成就。

最后,感谢您的阅读和支持!祝愿您在未来的每一天中都能够成为一名精通Golang的开发者!

期待听到您在学习过程中的进展和成就。如果您需要进一步的帮助,请随时告诉我。祝您在学习Golang的旅程中取得巨大成功!

点击下方名片,加入IT技术核心学习团队。一起探索科技的未来,共同成长。

如果您在学习过程中有任何疑惑,请点击下方名片,带您一对一快速入门 Go语言 的世界 ~

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

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

相关文章

SQL事务与隔离

事务 事务的定义 事务是完成一个任务的多条语句,这些语句中,只要有一条语句失败,那么整个事务就会失败,即使之前的语句已经执行完毕也会被撤回 举个例子: 我去银行给王哥转钱,这个转钱呢分两个步骤,第一步先把我的钱拿出来,第二步把钱给王哥,那万一刚把我钱拿出来但是没到王…

Swift与OC的混编

一些场面话 在一位前辈的博客里看到了关于iOS开发的各种语言的混编,浅浅学习一下怎么使用。不得不说语言混编的开发者是真的🐮🍺 Swift中用OC混编 新建一个Swift文件 创建一个OC的类 选择language为OC 继续往下走,会跳出这个界…

css基础知识二十:说说对Css预编语言的理解?有哪些区别?

一、是什么 Css 作为一门标记性语言,语法相对简单,对使用者的要求较低,但同时也带来一些问题 需要书写大量看似没有逻辑的代码,不方便维护及扩展,不利于复用,尤其对于非前端开发工程师来讲,往…

【Spring Boot】Spring Boot日志详情:基于lombok的日志输出

文章目录 1. 何为日志文件?2. 日志文件的作用3. 日志文件的基本使用3.1 Spring Boot中的日志3.2 自定义日志打印 4 日志级别4.1 日志级别的作用4.2 日志级别的分类4.3 日志级别的设置 5 日志持久化6 基于lombok的日志输出6.1 lombok 简单输出日志案例6.2 浅谈 lombo…

【C++ OJ练习】7.字符串相加

1.题目链接 力扣 2.解题思路 拿到每个字符后 减去字符0 转化成对应的数字 再相加即可 倒着加 因为有进位的情况 最后头插或 者尾插加逆置 3.代码 class Solution { public:string addStrings(string num1, string num2) {//倒着往回加int end1 num1.size() - 1;int end2…

深度学习笔记之Transformer(六)Position Embedding铺垫:Skipgram与CBOW模型

深度学习笔记之Transformer——PositionEmbedding铺垫:Skipgram与CBOW模型 引言回顾: Word2vec \text{Word2vec} Word2vec模型补充:关于 Word2vec \text{Word2vec} Word2vec的一些说明 2023 / 7 / 10 2023/7/10 2023/7/10补充:关于…

六、consumer源码解读

Consumer源码解读 本课程的核心技术点如下: 1、consumer初始化 2、如何选举Consumer Leader 3、Consumer Leader是如何制定分区方案 4、Consumer如何拉取数据 5、Consumer的自动偏移量提交 Consumer初始化 从KafkaConsumer的构造方法出发,我们跟踪到…

设计模式——迭代器模式

迭代器模式(落没的设计模式) 定义 它提供一种方法访问一个容器对象中各个元素,而又不需要暴露该对象的内部细节。 迭代器是为容器服务的,能容纳元素的对象可以称为容器,例:List、Set、Map 迭代器模式&a…

操作系统实战45讲|01程序的运行过程、02几行汇编几行C

配置环境遇到的问题 virtualBox实现windows和Ubuntu之间的复制粘贴 1.修改设置,设置共享粘贴板为双向 或者在运行的虚拟机的窗口中进行设置 2.安装virtualbox增强功能 (1)直接联网安装 设备----安装增强功能 3.补充 windows中终端和文档复制的快捷键为ctrlc&…

Element Plus el-table 自定义合并行和列

原文链接&#xff1a;Element Plus el-table 自定义合并行和列 前言 目标效果是将表格行数据中某个属性值相同的项合并到一起&#xff0c;效果如下&#xff1a; <el-table :data"tableData" :span-method"spanMethod" style"width: 100%">…

Set up the compilation environment for ESP8266-RTOS-SDK using Git on Windows

Software to be installed&#xff1a; Git BashPython Environment&#xff0c;ESP8266 Master require Python v3 environment. Please check “add to PATH” while installing Open Git Bash&#xff0c;Enter a local disk&#xff0c;create an empty folder, enter the …

JVM常用参数

以下是 JVM 常用参数的配置 内存相关参数&#xff1a; -Xmx&#xff1a;指定 JVM 最大可用内存&#xff0c;例如 -Xmx2g 表示最大可用内存为 2GB。 -Xms&#xff1a;指定 JVM 初始内存大小&#xff0c;例如 -Xms512m 表示初始内存为 512MB。 -XX:MaxPermSize&#xff1a;指定…