爆款云主机2核4G限时秒杀,88元/年起!
查看详情

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 618智算钜惠季 爆款云主机2核4G限时秒杀,88元/年起!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 首保服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      Go 并发编程基础:什么是上下文

      首页 知识中心 软件开发 文章详情页

      Go 并发编程基础:什么是上下文

      2023-03-29 09:39:45 阅读次数:494

      Go,上下文

      0 前言

      相信大家以前在做阅读理解的时候,一定有从老师那里学一个技巧或者从参考答案看个:结合上下文。根据上下文我们能够找到有助于解题的相关信息,也能更加了解段落的思想。

      在开发过程中,也有这个上下文(Context)的概念,而且上下文也必不可少,缺少上下文,就不能获取完整的程序信息。那么什么是程序中的上下文呢?

      简单来说,就是在 API 之间或者函数调用之间,除了业务参数信息之外的额外信息。比如,服务器接收到客户端的 HTTP 请求之后,可以把客户端的 IP 地址和端口、客户端的身份信息、请求接收的时间、Trace ID 等信息放入到上下文中,这个上下文可以在后端的方法调用中传递。

      1 Go 中的 Context

      Golang 的上下文也是应用开发常用的并发控制工具。同理,上下文可以用于在程序中的 API 层或进程之间共享请求范围的数据,除此之外,Go 的 Context 库还提供取消信号(Cancel)以及超时机制(Timeout)。

      Context 又被称为上下文,与 WaitGroup 不同的是,Context 对于派生 goroutine 有更强的控制力,可以管理多级的 goroutine。

      但我们在 Go 中创建一个 goroutine 时,如果发生了一个错误,并且这个错误永远不会终止,而其他程序会继续进行。加入有一个不被调用的 goroutine 运行无限循环,如下所示:

      package main

      import "fmt"

      func main() {
      dataCom := []string{"alex", "kyrie", "kobe"}

      go func(data []string) {
      // 模拟大量运算的死循环
      }(dataCom)


      // 其他代码正常执行
      fmt.Println("剩下的代码执行正常逻辑")
      }

      上面的例子并不完整,​​dataCom​​ goroutine 可能会也可能不会成功处理数据。它可能会进入无限循环或导致错误。我们的其余代码将不知道发生了什么。

      有多种方法可以解决这个问题。其中之一是使用通道向我们的主线程发送一个信号,表明这个 goroutine 花费的时间太长,应该取消它。

      package main

      import (
      "fmt"
      "time"
      )

      func main() {

      stopChannel := make(chan bool)

      dataCom := []string{"alex", "kyrie", "kobe"}

      go func(stopChannel chan bool) {

      go func(data []string) {
      // 大量的计算
      }(dataCom)

      for range time.After(2 * time.Second) {
      fmt.Println("此操作运行时间过长,取消中")
      stopChannel <- true
      }

      }(stopChannel)

      <-stopChannel

      // 其他代码正常执行
      fmt.Println("剩下的代码执行正常逻辑")
      }

      上面的逻辑很简单。我们正在使用一个通道向我们的主线程发出这个 goroutine 花费的时间太长的信号。但是同样的事情可以用 context 来完成,这正是 context 包存在的原因。

      package main

      import (
      "context"
      "fmt"
      "time"
      )

      func main() {

      ctx, cancel := context.WithTimeout(context.Background(), time.Second*2)

      defer cancel()

      dataCom := []string{"alex", "kyrie", "kobe"}

      go func() {

      go func(data []string) {
      // 大量的计算
      }(dataCom)

      for range time.After(2 * time.Second) {
      fmt.Println("此操作运行时间过长,取消中")
      cancel()
      return
      }

      }()

      select {
      case <-ctx.Done():
      fmt.Println("上下文被取消")
      }
      }

      2 Context 接口

      Context 接口定义:

      type Context interface {
      Deadline() (deadline time.Time, ok bool)

      Done <-chan struct{}
      Err() error
      Value(key interface{}) interface{}
      }

      Context 接口定义了 4 个方法:

      • ​​Deadline()​​: 返回取消此上下文的时间 deadline(如果有)。如果未设置 deadline 时,则返回 ok==false,此时 deadline 为一个初始值的 time.Time 值。后续每次调用这个对象的 Deadline 方法时,都会返回和第一次调用相同的结果。
      • ​​Done()​​​ : 返回一个用于探测 Context 是否取消的 channel,当 Context 取消会自动将该 channel 关闭,如果该 Context 不能被永久取消,该函数返回 nil。例如​​context.Background()​​​;如果​​Done​​ 被 close,Err 方法会返回 Done 被 close 的原因。
      • ​​Err()​​​: 该方法会返回 context 被关闭的原因,关闭原因由 context 实现控制,不需要用户设置;如果​​Done()​​​ 尚未关闭,则​​Err()​​ 返回 nil
      • ​​Value()​​​ : 在树状分布的​​goroutine​​ 之间共享数据,用 map 键值的工作方法,通过 key 值查询 value。

      每次创建新上下文时,都会得到一个符合此接口的类型。上下文的真正实现隐藏在这个包和这个接口后面。这些是您可以创建的工厂类型的上下文:

      1. ​​context.TODO​​
      2. ​​context.Background​​
      3. ​​context.WithCancel​​
      4. ​​context.WithValue​​
      5. ​​context.WithTimeout​​
      6. ​​context.WithDeadline​​

      3 Context Tree

      在实际实现中,我们通常使用派生上下文。我们创建一个父上下文并将其传递到一个层,我们派生一个新的上下文,它添加一些额外的信息并将其再次传递到下一层,依此类推。通过这种方式,我们创建了一个从作为父级的根上下文开始的上下文树。这种结构的优点是我们可以一次性控制所有上下文的取消。如果根信号关闭了上下文,它将在所有派生的上下文中传播,这些上下文可用于终止所有进程,立即释放所有内容。这使得上下文成为并发编程中非常强大的工具。

      Go 并发编程基础:什么是上下文

      4 创建上下文

      4.1 上下文创建函数

      我们可以从现有的上下文中创建或派生上下文。顶层(根)上下文是使用 ​​Background​​​ 或 ​​TODO​​ 方法创建的,而派生上下文是使用 WithCancel、WithDeadline、WithTimeout 或 WithValue 方法创建的。

      所有派生的上下文方法都返回一个取消函数 CancelFunc,但 WithValue 除外,因为它与取消无关。调用 CancelFunc 会取消子项及其子项,删除父项对子项的引用,并停止任何关联的计时器。调用 CancelFunc 失败会泄漏子项及其子项,直到父项被取消或计时器触发。

      context.Background() ctx Context

      此函数返回一个空上下文。这通常只应在主请求处理程序或顶级请求处理程序中使用。这可用于为主函数、初始化、测试以及后续层或其他 goroutine 派生上下文的时候。

      ctx, cancel := context.Background()

      context.TODO() ctx Context

      此函数返回一个非 nil 的、空的上下文。没有任何值、不会被 cancel,不会超时,也没有截止日期。但是,这也应该仅在您不确定要使用什么上下文或者该函数还不能用于接收上下文时,可以使用这个方法,并且将在将来需要添加时使用。

      ctx, cancel := context.TODO()

      context.WithValue(parent Context, key, val interface{}) Context

      这个函数接受一个上下文并返回一个派生的上下文,其中值 val 与 key 相关联,并与上下文一起经过上下文树。

      ​​WithValue​​ 方法其实是创建了一个类型为 valueCtx 的上下文,它的类型定义如下:

      type valueCtx struct {
      Context
      key, val interface{}
      }

      这意味着一旦你得到一个带有值的上下文,任何从它派生的上下文都会得到这个值。该值是不可变的,因此是线程安全的。

      提供的键必须是可比较的,并且不应该是字符串类型或任何其他内置类型,以避免使用上下文的包之间发生冲突。 WithValue 的用户应该为键定义自己的类型。为避免在分配给 ​​interface{}​​​ 时进行分配,上下文键通常具有具体类型 ​​struct{}​​。或者,导出的上下文键变量的静态类型应该是指针或接口。

      package main

      import (
      "context"
      "fmt"
      )

      type contextKey string

      func main() {

      var authToken contextKey = "auth_token"

      ctx := context.WithValue(context.Background(), authToken, "Hello123456")

      fmt.Println(ctx.Value(authToken))
      }

      运行该代码:

      $ go run .           
      Hello123456

      func WithCancel(parent Context) (ctx Context, cancel CancelFunc)

      此函数接收父上下文并返回派生上下文,返回 parent 的副本,只是副本中的 Done Channel 是新建的对象,它的类型是 cancelCtx。在这个派生上下文中,添加了一个新的 ​​Done​​​ channel,该 channel 在调用 ​​cancel​​ 函数或父上下文的 Done 通道关闭时关闭。

      要记住的一件事是,我们永远不应该在不同的函数或层之间传递这个 ​​cancel​​ ,因为它可能会导致意想不到的结果。创建派生上下文的函数应该只调用取消函数。

      下面是一个使用 Done 通道演示 goroutine 泄漏的示例:

      package main

      import (
      "context"
      "fmt"
      "math/rand"
      "time"
      )

      func main() {

      rand.Seed(time.Now().UnixNano())

      ctx, cancel := context.WithCancel(context.Background())
      defer cancel()

      for char := range randomCharGenerator(ctx) {
      generatedChar := string(char)
      fmt.Printf("%v\n", generatedChar)

      if generatedChar == "o" {
      break
      }
      }
      }

      func randomCharGenerator(ctx context.Context) <-chan int {

      char := make(chan int)

      seedChar := int('a')

      go func() {
      for {
      select {
      case <-ctx.Done():
      fmt.Printf("found %v", seedChar)
      return

      case char <- seedChar:
      seedChar = 'a' + rand.Intn(26)
      }
      }
      }()

      return char
      }

      运行结果:

      $ go run .           
      a
      m
      q
      c
      l
      t
      o

      func WithDeadline(parent Context, d time.Time) (Context, CancelFunc)

      此函数从其父级返回派生上下文,返回一个 parent 的副本。

      当期限超过或调用取消函数时,该派生上下文将被取消。例如,您可以创建一个在未来某个时间自动取消的上下文,并将其传递给子函数。当该上下文由于截止日期用完而被取消时,所有获得该上下文的函数都会收到通知停止工作并返回。如果 parent 的截止日期已经早于 d,则上下文的 Done 通道已经关闭。

      下面是我们正在读取一个大文件的示例,该文件的截止时间为当前时间 2 毫秒。我们将获得 2 毫秒的输出,然后将关闭上下文并退出程序。

      package main

      import (
      "bufio"
      "context"
      "fmt"
      "log"
      "os"
      "time"
      )

      func main() {
      // context with deadline after 2 millisecond
      ctx, cancel := context.WithDeadline(context.Background(), time.Now().Add(2*time.Millisecond))
      defer cancel()

      lineRead := make(chan string)

      var fileName = "sample-file.txt"
      file, err := os.Open(fileName)
      if err != nil {
      log.Fatalf("failed opening file: %s", err)
      }

      scanner := bufio.NewScanner(file)
      scanner.Split(bufio.ScanLines)

      // goroutine to read file line by line and passing to channel to print
      go func() {
      for scanner.Scan() {
      lineRead <- scanner.Text()
      }

      close(lineRead)
      file.Close()
      }()

      outer:
      for {
      // printing file line by line until deadline is reached
      select {
      case <-ctx.Done():
      fmt.Println("process stopped. reason: ", ctx.Err())
      break outer
      case line := <-lineRead:
      fmt.Println(line)
      }
      }
      }

      func WithTimeout(parent Context, timeout time.Duration) (Context, CancelFunc)

      这个函数类似于 context.WithDeadline。不同之处在于它将持续时间作为输入而不是时间对象。此函数返回一个派生上下文,如果调用取消函数或超过超时持续时间,该上下文将被取消。

      WithTimeout 的实现是:

      func WithTimeout(parent Context, timeout time.Duration) (Context, CancelFunc) {
      // 当前时间+timeout就是deadline
      return WithDeadline(parent, time.Now().Add(timeout))
      }

      WithTimeout 返回 ​​WithDeadline(parent, time.Now().Add(timeout))​​ 。

      package main

      import (
      "bufio"
      "context"
      "fmt"
      "log"
      "os"
      "time"
      )

      func main() {
      // context with deadline after 2 millisecond
      ctx, cancel := context.WithTimeout(context.Background(), 2*time.Millisecond)
      defer cancel()

      lineRead := make(chan string)

      var fileName = "sample-file.txt"
      file, err := os.Open(fileName)
      if err != nil {
      log.Fatalf("failed opening file: %s", err)
      }

      scanner := bufio.NewScanner(file)
      scanner.Split(bufio.ScanLines)

      // goroutine to read file line by line and passing to channel to print
      go func() {
      for scanner.Scan() {
      lineRead <- scanner.Text()
      }

      close(lineRead)
      file.Close()
      }()

      outer:
      for {
      // printing file line by line until deadline is reached
      select {
      case <-ctx.Done():
      fmt.Println("process stopped. reason: ", ctx.Err())
      break outer
      case line := <-lineRead:
      fmt.Println(line)
      }
      }
      }

      如果父上下文的 Done 通道关闭,它最终将关闭所有派生的 Done 通道(所有后代),如:

      package main

      import (
      "context"
      "fmt"
      "time"
      )

      func main() {
      c := make(chan string)
      go func() {
      time.Sleep(1 * time.Second)
      c <- "one"
      }()

      ctx1 := context.Context(context.Background())

      ctx2, cancel2 := context.WithTimeout(ctx1, 2*time.Second)
      ctx3, cancel3 := context.WithTimeout(ctx2, 10*time.Second) // derives from ctx2
      ctx4, cancel4 := context.WithTimeout(ctx2, 3*time.Second) // derives from ctx2
      ctx5, cancel5 := context.WithTimeout(ctx4, 5*time.Second) // derives from ctx4

      cancel2()
      defer cancel3()
      defer cancel4()
      defer cancel5()

      select {
      case <-ctx3.Done():
      fmt.Println("ctx3 closed! error: ", ctx3.Err())
      case <-ctx4.Done():
      fmt.Println("ctx4 closed! error: ", ctx4.Err())
      case <-ctx5.Done():
      fmt.Println("ctx5 closed! error: ", ctx5.Err())
      case msg := <-c:
      fmt.Println("received", msg)
      }
      }

      在这里,由于我们在创建其他派生上下文后立即关闭 ctx2,因此所有其他上下文也会立即关闭,随机打印 ctx3、ctx4 和 ctx5 关闭消息。 ctx5 是从 ctx4 派生的,由于 ctx2 关闭的级联效应,它正在关闭。尝试多次运行,您会看到不同的结果。

      使用 Background 或 TODO 方法创建的上下文没有取消、值或截止日期。

      package main

      import (
      "context"
      "fmt"
      )

      func main() {
      ctx := context.Background()

      _, ok := ctx.Deadline()

      if !ok {
      fmt.Println("no dealine is set")
      }

      done := ctx.Done()

      if done == nil {
      fmt.Println("channel is nil")
      }
      }

      4.2 Context 使用规范

      • 不要将上下文存储在结构类型中;相反,将 Context 显式传递给需要它的每个函数。 Context 应该是第一个参数,通常命名为 ctx。
      func DoSomething(ctx context.Context, arg Arg) error {
      // ... use ctx ...
      }
      • 不要传递 nil 上下文,即使函数允许。如果不确定要使用哪个 Context,请传递​​context.TODO​​​ 或使用​​context.Background()​​ 创建一个空的上下文对象。
      • 仅使用上下文传递请求范围的数据。不要传递应该使用函数参数传递的数据。
      • 始终寻找 goroutine 泄漏并有效地使用上下文来避免这种情况。
      • 如果父上下文的 Done 通道关闭,它最终将关闭所有派生的 Done 通道(所有后代)
      • 上下文只是临时做函数之间的上下文传透,不能持久化上下文
      • key 的类型不应该是字符串类型或者其它内建类型,否则容易在包之间使用 Context 时候产生冲突。使用 WithValue 时,key 的类型应该是自己定义的类型。

      4.3 Context 使用场景

      • 上下文信息传递 (request-scoped),比如处理 http 请求、在请求处理链路上传递信息;
      • 控制子 goroutine 的运行;
      • 超时控制的方法调用;
      • 可以取消的方法调用。

      5 总结

      Context 是在 Go 中进行并发编程时最重要的工具之一。上下文的主要作用是在多个 Goroutine 或者模块之间同步取消信号或者截止日期,用于减少对资源的消耗和长时间占用,避免资源浪费。标准库中的 database/sql、os/exec、net、net/http 等包中都使用到了 Context。​

      版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://blog.51cto.com/yuzhou1su/5506104,作者:宇宙之一粟,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

      上一篇:Spring5参考指南:SpringAOP简介

      下一篇:Go 语言入门很简单 -- 5. 控制结构 #私藏项目实操分享#

      相关文章

      2025-04-14 09:31:41

      文心一言 VS 讯飞星火 VS chatgpt (283)-- 算法导论21.2 1题

      在并查集(Disjoint Sets)或集合合并(Union-Find)问题中,我们可以使用加权合并启发式策略(通常是按秩合并或按大小合并)来优化UNION操作,以便在多个UNION操作后,仍然能够保持较低的树高,从而提高后续FIND-SET操作的效率。

      2025-04-14 09:31:41
      Go , 合并 , 节点 , 链表 , 集合
      2025-04-11 07:16:37

      文心一言 VS 讯飞星火 VS chatgpt (276)-- 算法导论20.3 3题

      伪代码 Van Emde Boas树通常用于支持在[0, 2^w - 1]范围内的高效查找、插入和删除操作,其中w是一个正整数,代表树的宽度。

      2025-04-11 07:16:37
      Go , 代码
      2025-04-01 10:29:01

      golang如何写一个插件?

      golang如何写一个插件?

      2025-04-01 10:29:01
      go , Go , golang , 加载
      2025-03-31 08:58:01

      探秘 Spring Application 启动流程:从初始化到运行的全景解析

      探秘 Spring Application 启动流程:从初始化到运行的全景解析

      2025-03-31 08:58:01
      Spring , 上下文 , 加载 , 启动 , 容器 , 应用
      2025-03-26 08:57:33

      Go to Learn Go之函数

      在上一节的内容中,我们介绍了Go的指针,包括:使用指针、空指针、指针数组、指向指针的指针等。在本节中,我们将介绍Go的函数。函数允许开发者将相关的代码组织在一起,并将其命名,以便在其他地方进行调用。在Go语言中,函数是一段可重用的代码块,用于执行特定的操作。

      2025-03-26 08:57:33
      Go , 函数 , 参数 , 定义 , 返回
      2025-03-21 08:23:19

      实战指南:理解 ThreadLocal 原理并用于Java 多线程上下文管理

      实战指南:理解 ThreadLocal 原理并用于Java 多线程上下文管理

      2025-03-21 08:23:19
      key , ThreadLocal , 上下文 , 引用 , 线程
      2025-02-26 07:21:05

      Python上下文管理器(Context managers)

      Python上下文管理器(Context managers)

      2025-02-26 07:21:05
      hello , https , Python , 上下文 , 管理器 , 语句
      2025-02-19 09:02:32

      【协程】协程与线程、线程与进程的区别

      每个进程都有自己的独立内存空间,进程比较重量,占据独立的内存,所以上下文进程间的切换开销(栈、寄存器、虚拟内存、文件句柄等)比较大,但相对比较稳定安全。

      2025-02-19 09:02:32
      上下文 , 切换 , 协程 , 寄存器 , 线程 , 资源 , 进程
      2025-01-15 08:07:07

      文心一言 VS 讯飞星火 VS chatgpt (118)-- 算法导论10.3 3题

      在 Go 语言中,ALLOCATE-OBJECT 和 FREE-OBJECT 过程的实现通常不需要显式地设置或重置对象的 prev 属性。这是因为在 Go 语言的内存管理中,对象(或更具体地说,变量)的生命周期通常由垃圾回收器(Garbage Collector)来管理。

      2025-01-15 08:07:07
      Go , 内存 , 对象
      2025-01-07 09:43:34

      文心一言 VS 讯飞星火 VS chatgpt (256)-- 算法导论18.3 2题

      文心一言 VS 讯飞星火 VS chatgpt (256)-- 算法导论18.3 2题

      2025-01-07 09:43:34
      Go , 代码 , 删除 , 树中 , 节点
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5245587

      查看更多

      最新文章

      文心一言 VS 讯飞星火 VS chatgpt (276)-- 算法导论20.3 3题

      2025-04-11 07:16:37

      探秘 Spring Application 启动流程:从初始化到运行的全景解析

      2025-03-31 08:58:01

      实战指南:理解 ThreadLocal 原理并用于Java 多线程上下文管理

      2025-03-21 08:23:19

      Python上下文管理器(Context managers)

      2025-02-26 07:21:05

      【协程】协程与线程、线程与进程的区别

      2025-02-19 09:02:32

      文心一言 VS 讯飞星火 VS chatgpt (256)-- 算法导论18.3 2题

      2025-01-07 09:43:34

      查看更多

      热门文章

      Go 语言入门很简单 -- Go 语言解析JSON #私藏项目实操分享#

      2023-04-19 09:23:13

      golang基础-编写单元测试

      2023-02-10 10:10:49

      Go 语言入门很简单 -- 6. 数组 #私藏项目实操分享#

      2023-04-18 14:14:25

      Go 语言入门很简单 -- Go 语言转化为 JSON #私藏项目实操分享#

      2023-04-06 09:56:33

      Go 语言入门很简单 -- 13. Go 接口 #私藏项目实操分享#

      2023-04-21 03:11:48

      #私藏项目实操分享#Go 语言入门很简单:String

      2023-04-07 06:43:39

      查看更多

      热门标签

      java Java python 编程开发 代码 开发语言 算法 线程 Python html 数组 C++ 元素 javascript c++
      查看更多

      相关产品

      弹性云主机

      随时自助获取、弹性伸缩的云服务器资源

      天翼云电脑(公众版)

      便捷、安全、高效的云电脑服务

      对象存储

      高品质、低成本的云上存储服务

      云硬盘

      为云上计算资源提供持久性块存储

      查看更多

      随机文章

      Go语言入门编程学习结束

      Go 语言入门很简单:Go 语言中操作 MySQL 数据库

      Go 语言入门很简单 -- 13. Go 接口 #私藏项目实操分享#

      go 语言中的并发特性

      golang基础-编写单元测试

      探秘 Spring Application 启动流程:从初始化到运行的全景解析

      • 7*24小时售后
      • 无忧退款
      • 免费备案
      • 专家服务
      售前咨询热线
      400-810-9889转1
      关注天翼云
      • 旗舰店
      • 天翼云APP
      • 天翼云微信公众号
      服务与支持
      • 备案中心
      • 售前咨询
      • 智能客服
      • 自助服务
      • 工单管理
      • 客户公告
      • 涉诈举报
      账户管理
      • 管理中心
      • 订单管理
      • 余额管理
      • 发票管理
      • 充值汇款
      • 续费管理
      快速入口
      • 天翼云旗舰店
      • 文档中心
      • 最新活动
      • 免费试用
      • 信任中心
      • 天翼云学堂
      云网生态
      • 甄选商城
      • 渠道合作
      • 云市场合作
      了解天翼云
      • 关于天翼云
      • 天翼云APP
      • 服务案例
      • 新闻资讯
      • 联系我们
      热门产品
      • 云电脑
      • 弹性云主机
      • 云电脑政企版
      • 天翼云手机
      • 云数据库
      • 对象存储
      • 云硬盘
      • Web应用防火墙
      • 服务器安全卫士
      • CDN加速
      热门推荐
      • 云服务备份
      • 边缘安全加速平台
      • 全站加速
      • 安全加速
      • 云服务器
      • 云主机
      • 智能边缘云
      • 应用编排服务
      • 微服务引擎
      • 共享流量包
      更多推荐
      • web应用防火墙
      • 密钥管理
      • 等保咨询
      • 安全专区
      • 应用运维管理
      • 云日志服务
      • 文档数据库服务
      • 云搜索服务
      • 数据湖探索
      • 数据仓库服务
      友情链接
      • 中国电信集团
      • 189邮箱
      • 天翼企业云盘
      • 天翼云盘
      ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
      公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
      • 用户协议
      • 隐私政策
      • 个人信息保护
      • 法律声明
      备案 京公网安备11010802043424号 京ICP备 2021034386号