Rust 还没进前十,TIOBE 就开始唱衰了?

本文永久链接 – https://tonybai.com/2026/04/17/tiobe-ranking-and-the-decline-of-rust-hype

大家好,我是Tony Bai。

过去几年,技术圈最热门的“猜谜游戏”之一,就是预测 Rust 什么时候能杀入 TIOBE 排行榜的前十。

这门被誉为“天选之子”的语言,连续多年霸榜 Stack Overflow“最受喜爱”的宝座,被微软、亚马逊等巨头奉为重写底层基础设施的“银弹”。所有人都觉得,它冲进前十,只是时间问题。

但就在最近,TIOBE 指数发布了 2026 年 4 月的最新排名。

榜单本身平平无奇,Rust 的排名甚至还从去年同期的 18 位微升到了 今年的16 位。

然而,TIOBE 的 CEO Paul Jansen 亲自撰写的一篇社论,却像一盆冷水,劈头盖脸地浇在了所有 Rustacean(Rust 开发者)的头上。

Paul Jansen 用极其明确的措辞,给这门甚至还没来得及摸到前十门槛的语言,提前下了一份“病危通知书”:

“Rust 的崛起显示出放缓的迹象。……它进入前十的梦想,现在看来比以前更加遥远了。”

这篇社论,瞬间引爆了全网的讨论。

无数 Rust 开发者感到匪夷所思,甚至有些愤怒:我们还没真正发力,你怎么就开始唱衰了?

这背后,到底是 TIOBE 对技术趋势的精准预判,还是这把统治了我们十几年的“认知标尺”,已经彻底失灵了?

今天,我们就来扒开这张榜单的底裤,看看在喧嚣的数据背后,Rust 的真实处境,究竟是怎样的。

官方的“诊断书”:Rust 的“阿喀琉斯之踵”

我们先来看看 TIOBE CEO Paul Jansen 的“诊断报告”。

他指出,Rust 在今年年初曾一度冲到历史最高排名第 13 位,但仅仅三个月后,就又跌回了第 16 位。

他给出的解释是:

“一个可能的解释是,尽管 Rust 能够生产出高效和安全的代码,但对于非专家程序员来说,它仍然难以学习。虽然专家们愿意投入时间去掌握这门语言,但更广泛的主流采用似乎面临着更大的挑战。”

这段话,精准地戳中了 Rust 社区最敏感、也最引以为傲的那根神经——陡峭的学习曲线

为了追求极致的内存安全,Rust 发明了极其复杂的“所有权(Ownership)”和“借用检查(Borrow Checker)”系统。这套系统像一个极其严苛的导师,在你编译代码的每一个环节,都对你进行着灵魂拷问。

无数新手在入门 Rust 时,都会经历一段被称为“与编译器搏斗”的痛苦时期。

TIOBE 的观点很明确:这种“精英主义”的设计哲学,正在成为 Rust “出圈”的最大障碍。

榜单的原罪:用“百度指数”去衡量火箭科学

TIOBE 的诊断听起来似乎很有道理。但我们必须先问一个更底层的问题:TIOBE 指数,到底是个什么东西?

TIOBE 的排名,本质上是一个基于“搜索引擎查询量”的指标。它在全球 25 个主流搜索引擎上,统计包含 +” programming” 关键词的页面数量。

看懂了吗?这套诞生于 十多年前的评判标准,在 2026 年的今天,已经变得极其荒谬

它衡量的是一门语言在公网上的“话题度”和“声量”,而不是它的“真实价值”和“商业应用”。

这就像用“微博热搜”的次数,去评判一位科学家的学术贡献一样可笑。

用这把“旧尺子”去衡量现代编程语言,会产生几个致命的认知偏差:

1. 越是难学、坑越多的语言,排名越高。

这恰恰是 TIOBE 逻辑最诡异的地方。Paul Jansen 一边抱怨 Rust 太难学,一边却忽视了,正是因为“难学”,新用户才会频繁地去 Google 搜索“Rust a lifetime that lives long enough”、“the trait Borrow is not implemented for String”这些令人抓狂的报错信息。

每一次“救命”的搜索,都在为 Rust 的 TIOBE 排名,贡献着宝贵的 KPI。

2. 越是成熟、生态完善的语言,排名越吃亏。

随着一门语言的成熟,它的文档会越来越完善,社区的最佳实践会沉淀下来。开发者遇到的问题,更多地会在官方文档、IDE 提示、或者小圈子的 Slack/Discord 里被解决,而不会产生大量的公开搜索。

没有问题,就没有搜索。没有搜索,就没有 TIOBE 排名。

3. TIOBE 无法衡量“生态位”的价值。

Rust 的江山在哪里?在 Linux 内核里(注:最近发布的Linux Kernel 7.0里,Rust已经正式转正了!),在 Windows 的系统组件里,在 Cloudflare 的边缘网络里,在 Figma 的渲染引擎里,在那些对性能和安全要求达到极致的底层基础设施里。

这些领域的开发者,是金字塔尖的系统程序员。他们讨论问题,是在 GitHub Issue、Zulip 频道,而不是在 CSDN 上问“我的 &mut 为什么传不进去”。

Rust 的价值,深藏在那些不会产生大量公开搜索记录的、高壁垒的硬核场景里。而 TIOBE 的爬虫,可能永远也爬不到那里。

真实的版图:Rust 正在经历一场“青春期的烦恼”

扒开 TIOBE 的“障眼法”,我们该如何客观看待 Rust 在 2026 年的真实处境?

Rust 并没有“增长放缓”,它只是在经历一场必然的“出圈阵痛”。

任何一门新技术的发展,都会经历两个阶段:

  1. 从 0 到 1 的“深耕期”:吸引最硬核、最狂热的一批早期用户,在特定的垂直领域里,将自己的核心优势打磨到极致。Rust 在“系统编程”领域,已经完美地完成了这个阶段。
  2. 从 1 到 N 的“出圈期”:试图将自己的影响力,扩展到更广阔的领域,吸引更多的主流开发者。

Rust 现在正处于从阶段一向阶段二过渡的关键时期。它那套为系统编程量身打造的、极致安全的内存管理哲学,在 Web 开发、数据科学、GUI 应用等场景下,确实给很多开发者带来了巨大的心智负担。

Rust 社区内部,关于是否应该为了“易用性”而牺牲部分“极致性”的争论,也从未停止。比如,关于异步运行时的分裂(Tokio vs async-std)、关于标准库的精简与扩充,都反映了这种“青春期的烦恼”。

Rust 没有停滞,它只是在“成长的十字路口”,在思考自己到底想成为谁。

我们真正应该关注什么?

作为身处一线的工程师,我们应该如何看待 TIOBE 的这份“诊断书”?

第一,永远不要把“流行度”作为技术选型的唯一标准。

JavaScript 很流行,但你不会用它去写操作系统内核。COBOL 极其冷门,但全球的银行系统依然跑在它上面,顶级 COBOL 程序员的薪资高得吓人。

技术的价值,永远取决于它在特定场景下,解决了多大规模、多高难度的商业问题。

第二,警惕“易用性”的陷阱。

Go、Python 很简单。但这种简单,可能是以牺牲“运行时安全保证”(比如Python 的动态类型、Go的Nil指针等)为代价的。

Rust 的“难”,恰恰是把所有可能在深夜引发线上雪崩的风险,全部前置到了编译阶段。它用“编译时的痛苦”,换取了“运行时的安宁”。

这种设计哲学,对于金融交易、底层基础设施、航空航天等“不容有失”的领域来说,是无价之宝。

第三,对自己的成长负责,而不是对榜单负责。

与其每个月焦虑地刷新 TIOBE 的排名,不如去问自己几个更本质的问题:

  • 我所处的行业,未来 3-5 年最核心的技术瓶颈是什么?
  • 为了解决这些瓶颈,我需要掌握哪些不可替代的底层能力?
  • 哪门语言的生态和哲学,与这个方向最契合?

你的技术护城河,从来不是由 TIOBE 的排名决定的,而是由你所处行业以及要解决问题的深度决定的。

小结:你的价值,与榜单无关

TIOBE 的这份榜单,与其说是一份严肃的技术报告,不如说是一场成功的“引流狂欢”。

它用一个看似客观的数据,精准地挑动了每个程序员心中最敏感的那根“身份焦虑”神经。

但作为身处一线的工程师,我们必须保持清醒。

衡量一门技术价值的唯一标准,从来不是它在搜索引擎上的热度,而是它在真实的商业世界里,解决了多大、多复杂、多有价值的问题。

当你在用 Rust 构建着下一代安全操作系统,或者用它重写着公司最核心的交易引擎时,你根本无需关心 TIOBE 上的排名是 16 还是 60。

因为你正在创造的价值,早已不是这些过时的“声量指标”所能衡量的。

你的技术栈没有背叛你,但你的认知,可能会。


今日互动探讨:

你觉得 TIOBE 对 Rust“增长放缓”的判断准确吗?你认为 Rust 陡峭的学习曲线,是它最大的优势,还是最大的障碍?

欢迎在评论区分享你的看法!


还在为“复制粘贴喂AI”而烦恼?我的新专栏 AI原生开发工作流实战 将带你:

  • 告别低效,重塑开发范式
  • 驾驭AI Agent(Claude Code),实现工作流自动化
  • 从“AI使用者”进化为规范驱动开发的“工作流指挥家”

扫描下方二维码,开启你的AI原生开发之旅。


原「Gopher部落」已重装升级为「Go & AI 精进营」知识星球,快来加入星球,开启你的技术跃迁之旅吧!

我们致力于打造一个高品质的 Go 语言深度学习AI 应用探索 平台。在这里,你将获得:

  • 体系化 Go 核心进阶内容: 深入「Go原理课」、「Go进阶课」、「Go避坑课」等独家深度专栏,夯实你的 Go 内功。
  • 前沿 Go+AI 实战赋能: 紧跟时代步伐,学习「Go+AI应用实战」、「Agent开发实战课」、「Agentic软件工程课」、「Claude Code开发工作流实战课」、「OpenClaw实战分享」等,掌握 AI 时代新技能。
  • 星主 Tony Bai 亲自答疑: 遇到难题?星主第一时间为你深度解析,扫清学习障碍。
  • 高活跃 Gopher 交流圈: 与众多优秀 Gopher 分享心得、讨论技术,碰撞思想火花。
  • 独家资源与内容首发: 技术文章、课程更新、精选资源,第一时间触达。

衷心希望「Go & AI 精进营」能成为你学习、进步、交流的港湾。让我们在此相聚,享受技术精进的快乐!欢迎你的加入!

img{512x368}


商务合作方式:撰稿、出书、培训、在线课程、合伙创业、咨询、广告合作。如有需求,请扫描下方公众号二维码,与我私信联系。

为什么说 go 语句是新时代的 goto?四大法则拯救失控 goroutine

本文永久链接 – https://tonybai.com/2026/04/16/structured-concurrency-in-go-research-oriented-perspective

大家好,我是Tony Bai。

Go 语言的 go 关键字是并发编程史上的一次民主化革命,它让并发变得前所未有的廉价和简单。只需在一个函数调用前加上 go,我们就拥有了一个并发执行的任务。

这种语法是如此的诱人,以至于新手 Gopher 往往会沉迷于创建成千上万个 Goroutine。

随着 Go 语言步入第 16 个年头,学术界和工程界也开始重新审视这种“极简主义”带来的副作用。

2025 年 3 月,一篇发表在《Scientific Research Journal》上的重磅论文《Structured Concurrency in Go: A Research-Oriented Perspective》,将 Go 的并发模型与 1968 年 Dijkstra 对 Goto 语句的批判联系了起来。

论文作者 Georgii Kliukovkin 指出,这种“发射后不管(Fire-and-Forget)”的模式,虽然在 Hello World 级别的程序中运行良好,但在大规模分布式系统中,它是资源泄漏、死锁和竞态条件的温床。

我们日常也常听到这样的抱怨:“Go 的并发很简单,但写出正确的并发代码很难。” 这并非语言本身的缺陷,而是因为我们缺乏一种与语言灵活性相匹配的约束纪律。这种纪律,就是结构化并发

本文将深入解读这篇论文,探讨为何“不受限制的 Goroutine”正在成为新时代的“Goto 语句”,以及我们如何通过结构化并发(Structured Concurrency)的四大法则,将失控的协程重新关回笼子,构建坚如磐石的系统。

历史的镜像——从 Goto 有害论到 Goroutine 有害论?

要理解“结构化并发”,我们必须先回顾历史。

1968年的呼喊:结构化编程的诞生

在 20 世纪 60 年代,编程界流行的是“非结构化编程”。开发者可以随心所欲地使用 goto 语句在代码的任意位置跳转。这种自由带来了极大的灵活性,但也导致了所谓的“意大利面条代码(Spaghetti Code)”——控制流杂乱无章,难以追踪程序的执行路径,维护简直是噩梦。

1968 年,图灵奖得主 Edsger W. Dijkstra 发表了那篇著名的《Go To Statement Considered Harmful》(Goto 语句有害论)。他主张废除无限制的跳转,转而使用结构化编程(Structured Programming):即所有的逻辑都应由顺序结构、选择结构(if/else)和循环结构(for/while)以及函数调用(Function Call)组成。

结构化编程的核心价值在于“黑盒化”。当你调用一个函数时,你确信控制权最终会回到你手中(除非死循环或崩溃);你确信该函数内部的变量不会污染外部环境。这种“入口-出口”的对称性,是软件可维护性的基石。

2025年的回响:go 语句 即 Goto

论文提出了一个让人振聋发聩的观点:Go 语言中的 go 语句,在某种意义上,就是并发领域的 goto。

当你执行 go func() 时,你实际上是启动了一个新的执行流,它跳出了当前的词法作用域(Lexical Scope)。

  • 它什么时候开始?不确定。
  • 它什么时候结束?不知道。
  • 它如果 Panic 了会怎样?可能会炸掉整个程序。
  • 父函数返回了,它还在运行吗?很有可能。

这种“射后不理(Fire-and-Forget)”的模式,破坏了代码的封装性。就像当年的 goto 打破了控制流的结构一样,不受约束的 go 语句打破了并发流的结构。

结构化并发的目标,就是要把这些“野生”的 Goroutine 重新关进“代码块”的笼子里,让并发程序的生命周期像同步程序一样清晰、可预测。

打破幻象——Go 并发的三个误区

在引入解决方案之前,论文首先抨击了 Go 社区中常见的三个关于并发的迷思。这些误区往往是导致系统不稳定的根源。

误区 1:“Goroutine 极度廉价,所以可以随便开”

是的,Goroutine 的初始栈只有 2KB,但这只是“内存”成本。从“生命周期”的角度看,一个泄露的 Goroutine 是极其昂贵的。

如果不加控制地启动 Goroutine 而不确保其退出,这些“孤儿”协程可能会:

  • 持有数据库连接或文件句柄不释放。
  • 阻塞在某个永远不会发送数据的 Channel 上。
  • 阻止垃圾回收器(GC)回收其引用的对象。

在长期运行的服务中,这种微小的泄漏会像滚雪球一样,最终导致服务 OOM(内存溢出)。

误区 2:“Channel 解决了所有同步问题”

Rob Pike 的名言“不要通过共享内存来通信,要通过通信来共享内存”被许多人奉为圭臬。然而,Channel 并不是银弹。

Channel 实际上引入了复杂的状态机问题:

  • 向已关闭的 Channel 发送数据会 Panic。
  • 从 nil Channel 读取会永久阻塞。
  • 无缓冲 Channel 容易导致死锁。
  • 过多的 Channel 会导致逻辑碎片化,增加认知负担。

论文强调,Channel 是一种传输机制,而不是一种架构保障。没有设计良好的生命周期管理,Channel 只会让 Bug 变得更难调试。

误区 3:“Go 的并发代码很容易测试”

Go 提供了 go test -race,但这远远不够。并发 Bug 往往是非确定性的(Heisenbugs),在本地开发环境(低负载、少核)下可能永远不会出现,一上生产环境(高负载、多核)就崩溃。

如果代码缺乏结构化,测试将变得极其困难。你无法确定在断言(Assert)的那一刻,后台的 Goroutine 是否已经完成了数据的写入。结构化并发通过明确的“等待”机制,能让并发测试变得像同步测试一样稳定。

核心法则——构建坚固的并发大厦

既然 Go 语言层面(目前)没有强制的结构化并发语法(不同于 Java Project Loom 的 StructuredTaskScope 或 Python Trio 的 Nursery),我们需要依靠工程纪律和设计模式来实现它。论文详细阐述了四大核心法则。

法则一:Scope 闭环原则 —— 在谁的 Scope 启动,就在谁的 Scope 等待

定义任何启动 Goroutine 的函数,必须负责等待它们结束。

这是结构化并发的第一天条。绝不允许 Goroutine 的生命周期“逃逸”出启动它的函数。这保证了当函数返回时,它所衍生的所有并发工作都已完结,资源已释放。

❌ 反模式:泄露的抽象

// 这是一个危险的模式:函数返回了,但后台任务还在跑
// 调用者无法知道任务何时完成,也无法处理 panic
func FireAndForget() {
    go func() {
        // 执行一些可能会阻塞很久的任务
        // 这里发生的一切,父函数都无法控制
    }()
}

✅ 正模式:Wait 优于 Sleep

论文强烈建议使用 sync.WaitGroup 或 errgroup 来显式地界定生命周期边界。

func ProcessStructured(items []Data) {
    var wg sync.WaitGroup

    for _, item := range items {
        wg.Add(1)
        // 使用闭包捕获变量时需注意
        go func(val Data) {
            defer wg.Done()
            process(val)
        }(item)
    }

    // 关键点:在函数返回前,必须收敛所有并发流
    // 这形成了一个清晰的“并发块”
    wg.Wait()
}

通过这种方式,ProcessStructured 函数的行为变成了“同步”的黑盒。调用者不需要知道它内部是否使用了并发,只需要知道“当函数返回时,所有工作都已完成”。

法则二:同步外观原则 —— API 应当表现为“同步”

定义即使函数内部使用了高并发,对外暴露的 API 签名应当是同步阻塞的。

这是一个看似反直觉的建议。既然我们写的是并发程序,为什么 API 要设计成同步的?

论文指出,异步 API(如返回一个 <-chan Result 或 Future)具有“传染性”。一旦你的函数返回了一个 Future,调用者就必须处理这个 Future 的等待逻辑,这会层层向上传递,导致整个调用链都充满了并发管理的细节。

经典案例:http.ListenAndServe

Go 标准库的 http.ListenAndServe(“:8080″, nil) 是结构化并发 API 设计的典范。

  • 内部:它是一个极其复杂的并发系统,为每个进来的 TCP 连接启动一个新的 Goroutine。
  • 外部:它是一个简单的阻塞函数。
// 调用者代码
err := http.ListenAndServe(":8080", nil)

// 当这行代码返回时,我们确切地知道:
// 1. 服务已经停止了。
// 2. 或者发生了错误(如端口冲突)。

如果 ListenAndServe 被设计成异步返回(即在后台启动服务后立即返回),那么调用者将面临巨大的困扰:我该如何知道服务启动成功了?如果启动失败,错误去哪里了?主进程该何时退出?

除非是专门的任务调度器,否则业务逻辑函数的 API 应该看起来是同步阻塞的。让调用者去决定是否使用 go 关键字来调用它。

法则三:所有权原则 —— 在哪写入,就在哪关闭

定义只有负责向 Channel 写入数据的 Goroutine,才有资格关闭该 Channel。

Channel 的关闭操作是 Go 并发中最容易导致 Panic 的环节(向已关闭的 Channel 发送数据)。论文强调,结构化并发可以极大地简化 Channel 的管理。

原则非常简单:谁生产,谁负责清理。 接收者(Consumer)永远不应该关闭 Channel,因为通过关闭 Channel 来通知生产者“我读完了”是一种错误的设计(应该使用 Context 来取消)。

结合法则一,如果生产者 Goroutine 的生命周期是受控的,那么 Channel 的生命周期自然也是受控的。

func Producer() <-chan int {
    ch := make(chan int)

    // 启动生产者协程
    go func() {
        // defer close 确保无论正常退出还是 panic,channel 都会关闭
        // 避免接收者永久阻塞
        defer close(ch) 

        for i := 0; i < 10; i++ {
            ch <- i
        }
    }()

    return ch
}

法则四:物理封装原则 —— 数据与锁不分家

定义将共享的可变数据(Mutable State)与保护它的同步原语(Mutex)封装在同一个结构体中。

在共享内存的并发模型中,最大的噩梦是“锁与数据分离”。例如,你定义了一个全局变量 var Cache map[string]int,然后又定义了一个全局锁 var Mu sync.Mutex。随着代码量的增加,开发者很容易忘记在访问 Cache 时加锁,或者错误地使用了其他的锁。

论文建议采用一种“物理强绑定”的策略:

type SafeCounter struct {
    // 1. 将锁作为结构体的第一个字段
    mu sync.Mutex

    // 2. 受保护的数据应当是私有的(小写)
    // 强制外部必须通过方法来访问
    values map[string]int
}

// 3. 只有通过这个方法才能访问数据
func (c *SafeCounter) Inc(key string) {
    c.mu.Lock()
    // 4. 利用 defer 确保锁的释放与函数作用域绑定
    defer c.mu.Unlock()

    c.values[key]++
}

这种模式被称为 Monitor Pattern(监视器模式)。它通过封装强制实施了并发安全,将“会不会加锁”的问题变成了“能不能调用方法”的问题,后者由编译器保证,前者只能靠人品。

进阶——超越标准库的尝试

虽然标准库提供了 sync.WaitGroup 和 context,但要完美实现结构化并发,样板代码依然繁多。论文提到了社区中一些优秀的尝试,其中最值得关注的是 Sourcegraph 开源的 conc 库

conc 库试图解决标准库 WaitGroup 的两个痛点:

  1. Panic 逃逸:在标准 go func 中,如果子协程 panic,整个程序会直接崩溃(Crash),父协程无法 recover。这对于高可用服务是致命的。
  2. Error 传播:WaitGroup 不支持错误返回,需要开发者自己维护一个 err 变量或使用 errgroup。

conc 提供了增强版的 WaitGroup:

import "github.com/sourcegraph/conc"

func main() {
    var wg conc.WaitGroup

    wg.Go(func() {
        // 如果这里 panic 了
        panic("something went wrong")
    })

    // Wait() 会自动捕获子协程的 panic
    // 并将其重新抛出或作为错误返回(取决于具体 API)
    // 从而避免进程直接崩溃
    wg.Wait()
}

这种工具库的出现,标志着 Go 社区正在从“手动管理并发”向“自动化管理并发”演进,这正是结构化并发理念的工程化落地。

小结:从“能用”到“可控”

Go 语言通过 go 关键字将并发编程的门槛降到了历史最低,赢得了云计算时代的入场券。但在构建大规模、高可靠的系统时,我们不能止步于“能用”。

这篇学术论文为我们提供了一个冷静的视角:并发不是目的,只是手段。 失控的并发是灾难,只有受控的并发才是生产力。

结构化并发不是一种束缚,而是一种保护。它要求我们在写下每一个 go func 的时候,都要问自己三个问题:

  1. 它什么时候结束?
  2. 谁负责等待它结束?
  3. 如果它出错了,谁来处理?

只有当这三个问题都有明确答案时,我们才能说,我们真正掌握了 Go 的并发艺术。

参考资料


你更倾向于哪一派?

有人认为 Go 的自由是生产力之源,有人认为约束才是工程的救赎。在你的项目中,你是否也曾因为“射后不理”的 goroutine 踩过坑?你认为 Go 官方是否应该在语言层面引入类似 Java 或 Python 的结构化并发原生支持?

欢迎在评论区分享你的看法或“血泪史”!

想深入掌握 Go 并发调度的底层原理?点击查看我的微专栏《Go 并发调度艺术》。


还在为“复制粘贴喂AI”而烦恼?我的新专栏 AI原生开发工作流实战 将带你:

  • 告别低效,重塑开发范式
  • 驾驭AI Agent(Claude Code),实现工作流自动化
  • 从“AI使用者”进化为规范驱动开发的“工作流指挥家”

扫描下方二维码,开启你的AI原生开发之旅。


你的Go技能,是否也卡在了“熟练”到“精通”的瓶颈期?

  • 想写出更地道、更健壮的Go代码,却总在细节上踩坑?
  • 渴望提升软件设计能力,驾驭复杂Go项目却缺乏章法?
  • 想打造生产级的Go服务,却在工程化实践中屡屡受挫?

继《Go语言第一课》后,我的《Go语言进阶课》终于在极客时间与大家见面了!

我的全新极客时间专栏 《Tony Bai·Go语言进阶课》就是为这样的你量身打造!30+讲硬核内容,带你夯实语法认知,提升设计思维,锻造工程实践能力,更有实战项目串讲。

目标只有一个:助你完成从“Go熟练工”到“Go专家”的蜕变! 现在就加入,让你的Go技能再上一个新台阶!


商务合作方式:撰稿、出书、培训、在线课程、合伙创业、咨询、广告合作。如有需求,请扫描下方公众号二维码,与我私信联系。

如发现本站页面被黑,比如:挂载广告、挖矿等恶意代码,请朋友们及时联系我。十分感谢! Go语言第一课 Go语言进阶课 AI原生开发工作流实战 Go语言精进之路1 Go语言精进之路2 Go语言第一课 Go语言编程指南
商务合作请联系bigwhite.cn AT aliyun.com
这里是 Tony Bai的个人Blog,欢迎访问、订阅和留言! 订阅Feed请点击上面图片

如果您觉得这里的文章对您有帮助,请扫描上方二维码进行捐赠 ,加油后的Tony Bai将会为您呈现更多精彩的文章,谢谢!

如果您希望通过微信捐赠,请用微信客户端扫描下方赞赏码:

如果您希望通过比特币或以太币捐赠,可以扫描下方二维码:

比特币:

以太币:

如果您喜欢通过微信浏览本站内容,可以扫描下方二维码,订阅本站官方微信订阅号“iamtonybai”;点击二维码,可直达本人官方微博主页^_^:
本站Powered by Digital Ocean VPS。
选择Digital Ocean VPS主机,即可获得10美元现金充值,可 免费使用两个月哟! 著名主机提供商Linode 10$优惠码:linode10,在 这里注册即可免费获 得。阿里云推荐码: 1WFZ0V立享9折!


View Tony Bai's profile on LinkedIn
DigitalOcean Referral Badge

文章

评论

  • 正在加载...

分类

标签

归档



View My Stats