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

news2024/11/15 15:41:09

在这里插入图片描述

🌷 博主 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 := 0
    for _, 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) // 输出:Alice

age := 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 + b
    return sum
}

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

4.2 全局变量和包级函数

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

var counter int

func increment() {
    counter++
}

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

第五节:匿名函数和闭包

5.1 匿名函数的定义和使用

匿名函数是没有名称的函数,可以在代码中直接定义和使用。示例代码如下:

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

greet("Alice") // 输出:Hello, Alice!

5.2 闭包的概念和实现

闭包是指函数和其相关的引用环境组合而成的实体。示例代码如下:

func incrementGenerator() func() int {
    count := 0
    return func() int {
        count++
        return count
    }
}

increment := incrementGenerator()
fmt.Println(increment()) // 输出:1
fmt.Println(increment()) // 输出:2

第六节:延迟执行(defer)

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) int

func 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 main

import (
	"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 := 0
	for _, 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 * width
	return area
}

// 4.2 全局变量和包级函数
var counter int

func increment() {
	counter++
}

// 5.1 匿名函数的定义和使用
func anonymousFunction() {
	func() {
		fmt.Println("This is an anonymous function")
	}()
}

// 5.2 闭包的概念和实现
func closure() func() int {
	count := 0
	return 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) int

func 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 MathFunc
	mathFunc = add
	result := 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.coloradmin.cn/o/729143.html

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

相关文章

论文学习——U-Net: Convolutional Networks for Biomedical Image Segmentation

UNet的特点 采用端到端的结构,通过FCN(最后一层仍然是通过卷积完成),最后输出图像。通过编码(下采样)-解码(上采样)形成一个“U”型结构。每次下采样时,先进行两次卷积&…

3D格式转化工具HOOPS Exchange的功能特点

​领先的CAD导入和导出库 使用用于CAD数据转换的HOOPS Exchange SDK将30多种CAD文件格式导入到您的应用程序中,具有对2D和3D CAD文件格式(包括 CATIA、SOLIDWORKS、Inventor™、Revit™、Creo、 NX™、Solid Edge 等,全部通过单个API实现。 …

aop拦截所有请求并打印请求方法参数

效果图 代码 package com.hxnwm.ny.diancan.common.aspect;import lombok.extern.slf4j.Slf4j; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.AfterReturning; import org.aspectj.lang.annotation.AfterThrowing; import org.aspectj.lang.annota…

redis的主从复制、哨兵模式和集群模式搭建

概述 redis主从复制搭建 主从复制的作用 主从复制流程 搭建Redis 主从复制 修改 Redis 配置文件(Master节点操作) 修改 Redis 配置文件(Slave节点操作) 验证主从效果 ​编辑 Redis 哨兵模式 哨兵模式的作用 故障转移机制 …

idea切换Git分支时保存未提交的文件

问题描述 现在需要开发一个新功能A时,我们需要从Dev分支上创建一个新的功能分支tenant,然后我们就在这个分支上进行开发。假设有一天,你正在开发,本地已经在tenant上修改了几个文件,但是功能还没有完全开发完成&#…

游戏反调试方案解析与frida/IDA框架分析

近来年,游戏黑灰产攻击趋势呈现出角度多样化的特点。据FairGuard游戏安全数据分析发现,游戏黑灰产攻击以工作室、定制注入挂、内存修改器、模拟点击、破解等形式为主。 游戏安全风险分布占比图 对于一款游戏而言,上述的风险中,被…

Kubernetes(k8s)实战:深入详解Volume,详解k8s文件同步存储

文章目录 一、Volume1、什么是Volume2、Host类型volume实战(不推荐)(1)小总结 二、PersistentVolume持久化volume(推荐)1、什么是PersistentVolume2、什么是PersistentVolumeClaim3、Pod中如何使用PVC 三、…

初中学物理实验室教学装备配置标准

初中物理实验室建设,以现行义务教育物理教科书为基本参照,以学生学科核心素养发展为基本遵循,以加强实验等实践性教学活动,落实立德树人根本任务为目标。因此,初中物理实验室的建设实施过程中,需结合校情、…

PCB封装设计指导(三)如何创建PAD

PCB封装设计指导(三)如何创建PAD 当我们完全看完了Datasheet之后,确定了需要建立的封装类型,以及尺寸之后,这一步就可以开始创建封装的PAD了。 下面介绍如何创建各种类型的PAD和一些技巧和注意点,包括创建flash的注意事项。 1.如何创建PAD 1. 打开pad designer ,根据尺…

STL源码刨析 string实现

目录 一. string 类介绍 二. string 的简单实现 1. 类内成员变量 2. Member functions string ~string operator string(const string& str) 3. Capacity size capacity empty clear reserve resize 4.Modifiers push_back append operator insert era…

【回溯算法part05】| 491.递增子序列、46.全排列、47.全排列||

目录 🎈LeetCode491.递增子序列 🎈LeetCode46.全排列 🎈LeetCode47.全排列|| 🎈LeetCode491.递增子序列 链接:491.递增子序列 给你一个整数数组 nums ,找出并返回所有该数组中不同的递增子序列&#xf…

【玩转Linux操作】详细讲解Linux的 权限 操作

🎊专栏【​​​​​​​玩转Linux操作】 🍔喜欢的诗句:更喜岷山千里雪 三军过后尽开颜。 🎆音乐分享【Love Story】 🥰欢迎并且感谢大家指出小吉的问题🥰 文章目录 🍔权限的基本介绍⭐具体分析&…

【复习1-2天的内容】【我们一起60天准备考研算法面试(大全)-第六天 6/60】

专注 效率 记忆 预习 笔记 复习 做题 欢迎观看我的博客,如有问题交流,欢迎评论区留言,一定尽快回复!(大家可以去看我的专栏,是所有文章的目录)   文章字体风格: 红色文字表示&#…

网络编程---day4

广播发送方: 广播接收方: 组播发射方: 组播接收方:

OpenCV的remap实现图像垂直翻转

以下是完整的代码: #include <opencv2/highgui/highgui.hpp> #include <opencv2/imgproc/imgproc.hpp> #include <iostream>int main() {

从“存算一体”到“存算分离”:金融核心数据库改造的必经之路

科技云报道原创。 近年来&#xff0c;数据库国产化趋势愈发明显&#xff0c;上百家金融业试点单位在数据库国产化的进程中&#xff0c;进一步增强信心&#xff0c;向50%国产化率大步迈进。 但随着数据库国产化的深入&#xff0c;一些金融机构采用国产数据库服务器本地盘的“存…

【微信小程序创作之路】- 小程序中WXML、JS、JSON、WXSS作用

【微信小程序创作之路】- 小程序中WXML、JS、JSON、WXSS作用 第三章 微信小程序WXML、JS、JSON、WXSS作用 文章目录 【微信小程序创作之路】- 小程序中WXML、JS、JSON、WXSS作用前言一、WXML是什么&#xff1f;二、JS是什么&#xff1f;三、JSON是什么&#xff1f;四、WXSS是什…

IPC 进程间通讯 (1)

目录 1.1 为什么要通信 1.2 为什么能通信 2.1 进程间通信机制的结构 2.2 进程间通信机制的类型 2.3 进程间通信机制的接口设计 3.1 SysV共享内存 3.2 POSIX共享内存 3.3 共享内存映射 3.4 Android ION 3.5 dma-buf heaps 3.6 匿名管道 3.7 命名管道 3.8 SysV消息队列…

基于Java实验室考勤管理系统设计实现(源码+lw+部署文档+讲解等)

博主介绍&#xff1a;✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专…

buuctf pwn入门1

目录 1. test_your_nc(简单nc ) pwn做题过程 2. rip(简单栈溢出) 3. warmup_csaw_2016(栈溢出 覆盖Return_Address) 4. ciscn_2019_n_1(栈溢出 浮点数十六进制) (1) 覆盖v2值 (2) 利用system("cat /flag"); 5. pwn1_sctf_2016(字符逃逸栈溢出 32位) 6. jarvis…