【后端开发】字节跳动青训营之Go语言进阶与依赖管理

Go语言进阶与依赖管理

  • 一、Go语言进阶
    • [1.1 并发与并行](#1.1 并发与并行)
    • [1.2 协程与线程](#1.2 协程与线程)
    • [1.3 通道](#1.3 通道)
      • [1.3.1 生产消费模型](#1.3.1 生产消费模型)
    • [1.4 并发安全](#1.4 并发安全)
  • 二、依赖管理

一、Go语言进阶

Go语言一次可以创建上万个协程。

1.1 并发与并行

  1. 并发:多程序程序在单核CPU上运行。
  2. 并行:多程序程序在多核CPU上运行。

1.2 协程与线程

  1. 协程:用户态,轻量级线程,栈KB级别
  2. 线程:内核态,线程跑多个协程,栈MB级别

创建协程(实现快速加法):

go 复制代码
func main() {
    for i:=0; i<10; i++ {
        go Add(i, i)
    }
}

注:提倡通过通信共享内存,而不是通过共享内存而实现通信。

1.3 通道

使用make语言创建通道。

1.3.1 生产消费模型

go 复制代码
package main

import (
	"fmt"
	"time"
)

func producer(ch chan<- int) {
	for i := 1; i <= 10; i++ {
		ch <- i
		fmt.Println("生产者生产了", i)
		time.Sleep(time.Second)
	}
	close(ch)
}

func consumer(ch <-chan int) {
	for num := range ch {
		fmt.Println("消费者消费了", num)
		time.Sleep(2 * time.Second)
	}
}

func main() {
	// 创建一个无缓冲的通道
	ch := make(chan int)
	
	// 启动生产者和消费者
	go producer(ch)
	go consumer(ch)
	
	// 等待程序执行完毕
	time.Sleep(30 * time.Second)
}

1.4 并发安全

当多个协程同时对一个变量进行操作的时候,可能会出现并发安全Lock问题,就是可能变量最后的值并不一定是希望的值。

go 复制代码
package main

import (
	"fmt"
	"time"
)

func producer(ch chan<- int) {
	for i := 1; i <= 10; i++ {
		ch <- i
		fmt.Println("生产者生产了", i)
		time.Sleep(time.Second)
	}
	close(ch)
}

func consumer(ch <-chan int) {
	for num := range ch {
		fmt.Println("消费者消费了", num)
		time.Sleep(2 * time.Second)
	}
}

func main() {
	// 创建一个无缓冲的通道
	ch := make(chan int)
	
	// 启动生产者和消费者
	go producer(ch)
	go consumer(ch)
	
	// 等待程序执行完毕
	time.Sleep(30 * time.Second)
}

在协程对变量进行操作之前应该首先获得锁。
注!在现实开发中应该尽量避免对共享内存的并发操作。

二、依赖管理

在开发大型Go项目的时候,应该将精力放在逻辑上,而不是代码的重复开发,因此就出现了各种各样的包用来实现项目的快速搭建。

  • bin:项目编译的二进制文件
  • pkg:项目编译的中间产物,用于加速编译
  • src:项目源码

注!通过go get/go mod命令可以获取最先的项目源码。

Go在依赖配置的时候会选择一个最低兼容版本。

相关推荐
python算法(魔法师版)1 小时前
React应用深度优化与调试实战指南
开发语言·前端·javascript·react.js·ecmascript
小鹿撞出了脑震荡1 小时前
Effective Objective-C 2.0 读书笔记——关联对象
开发语言·ios·objective-c
SomeB1oody4 小时前
【Rust自学】14.6. 安装二进制crate
开发语言·后端·rust
go54631584654 小时前
MATLAB 工具库的使用说明和案例示例
开发语言·matlab
曙曙学编程5 小时前
基础项目实战——学生管理系统(c++)
开发语言·c++·windows
六毛的毛5 小时前
java后端之登录认证
java·开发语言·python
患得患失9496 小时前
【Django DRF Apps】【文件上传】【断点上传】从零搭建一个普通文件上传,断点续传的App应用
数据库·后端·django·sqlite·大文件上传·断点上传
customer087 小时前
【开源免费】基于SpringBoot+Vue.JS校园失物招领系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
深度混淆7 小时前
C#,入门教程(05)——Visual Studio 2022源程序(源代码)自动排版的功能动画图示
开发语言·c#·自动排版
中國移动丶移不动7 小时前
Java 反射与动态代理:实践中的应用与陷阱
java·spring boot·后端·spring·mybatis·hibernate