禅与计算机 禅与计算机
首页
  • Java基础

    • 一文搞懂Java核心技术
    • Java面向对象知识点大总结,建议收藏
    • 聊聊Java中的异常
    • 聊聊Java中的常用类String
    • 万字长文带你细聊Java注解本质
    • 来聊聊Java的反射机制
    • 深入解析Java泛型的魅力与机制
    • Java集合框架深度解析与面试指南
    • Java常用集合类HashMap深度解析
    • LinkedHashMap源码到面试题的全解析
    • 深入解析CopyOnWriteArrayList的工作机制
    • Java基础IO总结
    • Java三大IO模型小结
    • Java BIO NIO AIO详解
    • Java进阶NIO之IO多路复用详解
    • Java8流式编程入门
    • 一文速通lambda与函数式编程
    • Java8函数式方法引用最佳实践
    • Java异常:从原理到实践
  • Java并发编程

    • Java并发编程基础小结
    • 深入理解Java中的final关键字
    • 浅谈Java并发安全发布技术
    • 浅谈Java并发编程中断的哲学
    • Java线程池知识点小结
    • 浅谈Java线程池中拒绝策略与流控的艺术
    • synchronized关键字使用指南
    • 深入源码解析synchronized关键字
    • 详解JUC包下的锁
    • 详解并发编程中的CAS原子类
    • LongAdder源码分析
    • AQS源码解析
    • 深入剖析Java并发编程中的死锁问题
    • Java并发容器总结
    • 详解Java并发编程volatile关键字
    • 并发编程ThreadLocal必知必会
    • CompletableFuture基础实践小结
    • CompletableFuture异步多任务最佳实践
    • 硬核详解FutureTask设计与实现
    • 线程池大小设置的底层逻辑与场景化方案
    • 来聊一个有趣的限流器RateLimiter
  • JVM相关

    • 从零开始掌握 JVM
    • JVM核心知识点小结
    • JVM指令集概览:基础与应用
    • JVM类加载器深度解析
    • JVM方法区深度解析
    • Java内存模型JMM详解
    • Java对象大小的精确计算方法
    • 逃逸分析在Java中的应用与优化
    • 从零开始理解JVM的JIT编译机制
    • G1垃圾回收器:原理详解与调优指南
    • JVM故障排查实战指南
    • JVM内存问题排错最佳实践
    • JVM内存溢出排查指南
    • 简明的Arthas使用教程
    • 简明的Arthas配置及基础运维教程
    • 基于Arthas Idea的JVM故障排查与指令生成
    • 基于arthas量化监控诊断java应用方法论与实践
    • 深入剖析arthas技术原理
    • 探索JVM的隐秘角落:元空间详解
  • 深入理解Spring框架

    • Spring 核心知识点全面解析
    • Spring核心功能IOC详解
    • Spring AOP 深度剖析与实践
    • Spring 三级缓存机制深度解析
    • 深入 Spring 源码,剖析设计模式的落地实践
    • 探索 Spring 事务的奥秘
    • 深入解析Spring Bean的生命周期管理
    • 解读 Spring Boot 核心知识点
    • Spring Boot 启动优化实战:1分钟到13秒的排查与优化之路
    • Spring Boot自动装配原理及实践
    • 一文快速上手Sharding-JDBC
    • sharding-jdbc如何实现分页查询
    • 基于DynamicDataSource整合分库分表框架Shardingsphere
  • 计算机组成原理

    • 计算机硬件知识小结
    • CPU核心知识点小结
    • 浅谈CPU流水线的艺术
    • 从Java程序员视角聊聊CPU缓存
    • CPU任务调度和伪共享问题小结
    • CPU MESI缓存一致性协议
    • CPU内存管理机制
    • 内存深度解析
    • 磁盘存储原理
    • 详解计算机启动步骤
    • CPU南北桥架构与发展史
    • CPU中断机制与硬件交互详解
  • 操作系统

    • 如何实现一个高性能服务器
    • Linux文件结构与文件权限
    • Linux常见压缩指令小结
    • Linux核心系统调用详解
    • Linux进程管理
    • Linux线程管理
    • 进程与线程深度解析
    • Linux进程间通信机制
    • 零拷贝技术原理与实践
    • CPU缓存一致性问题深度解析
    • IO任务与CPU调度艺术
  • 计算机网络

    • 网卡通信原理详解
    • 网卡数据包处理指南
    • 基于抓包详解TCP协议
  • 编码最佳实践

    • 浅谈现代软件工程TDD最佳实践
    • 浅谈TDD模式下并发程序设计与实现
    • 面向AI编程新范式Trae后端开发环境搭建与实践
    • 基于Vibe Coding的Redis分页查询实现
    • 告别AI无效对话:资深工程师的提示词设计最佳实践
  • 实用技巧与配置

    • Mac常用快捷键与效率插件指南
    • Keynote技术科普短视频制作全攻略
  • 元认知

    • 摩擦感:AI时代的写作自省
    • 从断墨寻径浅谈程序员的元学习能力
    • AI时代专注力培养
    • 如何阅读一本书:技术书籍的读书笔记方法论
  • 开发工具

    • IDEA配置详解与高效使用指南
    • Windows环境下JDK安装与环境变量配置
    • Windows 10 下的 Maven 安装配置教程
  • Nodejs
  • 博客搭建
  • Redis

    • Redis核心知识小结
    • 解锁Redis发布订阅模式
    • 掌握Redis事务
    • Redis主从复制技术
    • Redis的哨兵模式详解
    • 深度剖析Redisson分布式锁
    • 详解redis单线程设计思路
    • 来聊聊Redis所实现的Reactor模型
    • Redis RDB持久化源码深度解析
    • 来聊聊redis的AOF写入
    • 来聊聊Redis持久化AOF管道通信的设计
    • 来聊聊redis集群数据迁移
    • Redis SDS动态字符串深度解析
    • 高效索引的秘密:redis跳表设计与实现
    • 聊聊redis中的字典设计与实现
    • 感觉你因为AI退化了?用Redis SCAN源码打脸AI时代的孔乙己
  • MySQL

    • MySQL基础知识点小结
    • 解读MySQL 索引基础
    • MySQL 索引进阶指南
    • 解读MySQL Explain关键字
    • 探秘 MySQL 锁:原理与实践
    • 详解MySQL重做日志redolog
    • 详解undoLog在MySQL MVCC中的运用
    • MySQL二进制日志binlog核心知识点
    • MySQL高效插入数据的最佳实践
    • MySQL分页查询优化指南
    • MySQL流式查询的奥秘与应用解析
    • 来聊聊分库分表
    • 来聊聊大厂常用的分布式ID生成方案
  • ElasticSearch

    • Elasticsearch核心原理与架构设计
    • ES 基础使用指南
    • ElasticSearch如何写入一篇文档
    • 深入剖析Elasticsearch文档读取原理
    • 聊聊ElasticSearch性能调优
    • Spring借助Easy-Es操作ES
  • Netty

    • 一文快速了解高性能网络通信框架Netty
    • Netty网络传输简记
    • 来聊聊Netty的ByteBuf
    • 来聊聊Netty消息发送的那些事
    • 解密Netty高性能之谜:NioEventLoop线程池阻塞分析
    • 详解Netty中的责任链Pipeline如何管理ChannelHandler
    • Netty Reactor模型常见知识点小结
    • Netty如何驾驭TCP流式传输?粘包拆包问题全解
    • Netty解码器源码解析
  • 消息队列

    • 一文快速入门消息队列
    • 消息队列RocketMQ入门指南
    • 基于RocketMQ实现分布式事务
    • RocketMQ容器化最佳实践
    • RocketMQ常见问题与深度解析
    • Kafka快速安装与使用指南
  • Nginx

    • Linux下的nginx安装
    • Nginx基础入门总结
    • Nginx核心指令小结
    • Nginx进程结构与核心模块初探
    • Nginx应用进阶HTTP核心模块配置
    • Nginx缓存及HTTPS配置小记
    • nginx高可用实践简记
    • Nginx性能优化
  • 微服务基础

    • 微服务基础知识小结
    • 分布式事务核心概念小结
    • OpenFeign核心知识小结
    • 微服务组件Gateway核心使用小结
    • 分布式事务Seata实践
    • 用 Docker Compose 完成 Seata 的整合部署
  • Nacos

    • Nacos服务注册原理全解析
    • Nacos服务订阅流程全解析
    • Nacos服务变更推送流程全解析
    • 深入解析SpringCloud负载均衡器Loadbalancer
    • Nacos源码环境搭建与调试指南
  • Seata

    • 深度剖析Seata源码
  • Docker部署

    • 一文快速掌握docker的理念和基本使用
    • 使用docker编排容器
    • 基于docker-compose部署微服务基本环境
    • 基于docker容器化部署微服务
    • Gateway全局异常处理及请求响应监控
    • Docker图形化界面工具Portainer最佳实践
  • Go基础

    • AI时代的Go语言基础语法认知
    • 一文快速掌握Go语言切片
    • 来聊聊go语言的hashMap
    • 一文速通go语言类型系统
    • 浅谈Go语言中的面向对象
    • go语言是如何实现协程的
    • 聊聊go语言中的GMP模型
    • 极简的go语言channel入门
    • 聊聊go语言基于epoll的网络并发实现
    • 写给Java开发的Go语言协程实践
  • mini-redis实战

    • 来聊聊我用go手写redis这件事
    • mini-redis如何解析处理客户端请求
    • 实现mini-redis字符串操作
    • 硬核复刻redis底层双向链表核心实现
    • 动手复刻redis之go语言下的字典的设计与落地
    • Go 语言下的 Redis 跳表设计与实现
    • Go 语言版 Redis 有序集合指令复刻探索
    • 基于 Claude Code 复刻 Redis 慢查询指令实践
  • 项目编排

    • Spring脚手架创建简记
    • Spring脚手架集成分页插件
    • Spring脚手架集成校验框架
    • maven父子模块两种搭建方式简记
    • SpringBoot+Vue3前后端快速整合入门
    • 来聊聊Java项目分层规范
  • 场景设计

    • Java实现文件分片上传
    • 基于时间缓存优化浏览器轮询阻塞问题
    • 基于EasyExcel实现高效导出
    • 10亿数据高效插入MySQL最佳方案
    • 从开源框架中学习那些实用的位运算技巧
    • 对账核销场景设计与重构实践
    • 千万级交易流水慢查询综合治理实践
    • 记一次StarRocks源码级排错和既有架构优化实践
    • 基于快照合并修复Seata AT回滚补偿与Flink批攒导致StarRocks数据不一致最佳实践
  • CI/CD

    • 基于NETAPP实现内网穿透
    • 基于Gitee实现Jenkins自动化部署SpringBoot项目
    • Jenkins离线安装部署教程简记
    • 基于Nexus搭建Maven私服基础入门
    • 基于内网的Jenkins整合gitlab综合方案简记
  • 监控方法论

    • SpringBoot集成Prometheus与Grafana监控
    • Java监控度量Micrometer全解析
    • 从 micrometer计量器角度快速上手promQL
    • 硬核安利一个监控告警开源项目Nightingale
  • Spring AI

    • Spring AI Alibaba深度实战:一文掌握智能体开发全流程
    • Spring AI Alibaba实战:JVM监控诊断Arthas Agent的工程化构建与最佳实践
  • 大模型评测

    • M2.7 真能打!我用两个真实场景测了测,结果有点意外
    • Qoder JetBrains插件评测:祖传代码重构与接口优化实战
  • AI工具链

    • Claude Code 实战指南:从安装配置到企业级开发流程
    • 一次 Claude Code 启动失败的 AI 辅助排查复盘
    • 基于提示词工程与KITE框架的Redis签到功能开发实践
    • Claude Code 记忆管理:CLAUDE.md 最佳实践
    • Claude Code 规则管理:Rules 拆分编排与迭代实践(文末送书)
    • VSCode与Claude Code后端开发环境搭建与AI编程工作流实践
    • AI 写的企业级组件不敢用?我替你验过了
关于
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

sharkchili

计算机禅修者
首页
  • Java基础

    • 一文搞懂Java核心技术
    • Java面向对象知识点大总结,建议收藏
    • 聊聊Java中的异常
    • 聊聊Java中的常用类String
    • 万字长文带你细聊Java注解本质
    • 来聊聊Java的反射机制
    • 深入解析Java泛型的魅力与机制
    • Java集合框架深度解析与面试指南
    • Java常用集合类HashMap深度解析
    • LinkedHashMap源码到面试题的全解析
    • 深入解析CopyOnWriteArrayList的工作机制
    • Java基础IO总结
    • Java三大IO模型小结
    • Java BIO NIO AIO详解
    • Java进阶NIO之IO多路复用详解
    • Java8流式编程入门
    • 一文速通lambda与函数式编程
    • Java8函数式方法引用最佳实践
    • Java异常:从原理到实践
  • Java并发编程

    • Java并发编程基础小结
    • 深入理解Java中的final关键字
    • 浅谈Java并发安全发布技术
    • 浅谈Java并发编程中断的哲学
    • Java线程池知识点小结
    • 浅谈Java线程池中拒绝策略与流控的艺术
    • synchronized关键字使用指南
    • 深入源码解析synchronized关键字
    • 详解JUC包下的锁
    • 详解并发编程中的CAS原子类
    • LongAdder源码分析
    • AQS源码解析
    • 深入剖析Java并发编程中的死锁问题
    • Java并发容器总结
    • 详解Java并发编程volatile关键字
    • 并发编程ThreadLocal必知必会
    • CompletableFuture基础实践小结
    • CompletableFuture异步多任务最佳实践
    • 硬核详解FutureTask设计与实现
    • 线程池大小设置的底层逻辑与场景化方案
    • 来聊一个有趣的限流器RateLimiter
  • JVM相关

    • 从零开始掌握 JVM
    • JVM核心知识点小结
    • JVM指令集概览:基础与应用
    • JVM类加载器深度解析
    • JVM方法区深度解析
    • Java内存模型JMM详解
    • Java对象大小的精确计算方法
    • 逃逸分析在Java中的应用与优化
    • 从零开始理解JVM的JIT编译机制
    • G1垃圾回收器:原理详解与调优指南
    • JVM故障排查实战指南
    • JVM内存问题排错最佳实践
    • JVM内存溢出排查指南
    • 简明的Arthas使用教程
    • 简明的Arthas配置及基础运维教程
    • 基于Arthas Idea的JVM故障排查与指令生成
    • 基于arthas量化监控诊断java应用方法论与实践
    • 深入剖析arthas技术原理
    • 探索JVM的隐秘角落:元空间详解
  • 深入理解Spring框架

    • Spring 核心知识点全面解析
    • Spring核心功能IOC详解
    • Spring AOP 深度剖析与实践
    • Spring 三级缓存机制深度解析
    • 深入 Spring 源码,剖析设计模式的落地实践
    • 探索 Spring 事务的奥秘
    • 深入解析Spring Bean的生命周期管理
    • 解读 Spring Boot 核心知识点
    • Spring Boot 启动优化实战:1分钟到13秒的排查与优化之路
    • Spring Boot自动装配原理及实践
    • 一文快速上手Sharding-JDBC
    • sharding-jdbc如何实现分页查询
    • 基于DynamicDataSource整合分库分表框架Shardingsphere
  • 计算机组成原理

    • 计算机硬件知识小结
    • CPU核心知识点小结
    • 浅谈CPU流水线的艺术
    • 从Java程序员视角聊聊CPU缓存
    • CPU任务调度和伪共享问题小结
    • CPU MESI缓存一致性协议
    • CPU内存管理机制
    • 内存深度解析
    • 磁盘存储原理
    • 详解计算机启动步骤
    • CPU南北桥架构与发展史
    • CPU中断机制与硬件交互详解
  • 操作系统

    • 如何实现一个高性能服务器
    • Linux文件结构与文件权限
    • Linux常见压缩指令小结
    • Linux核心系统调用详解
    • Linux进程管理
    • Linux线程管理
    • 进程与线程深度解析
    • Linux进程间通信机制
    • 零拷贝技术原理与实践
    • CPU缓存一致性问题深度解析
    • IO任务与CPU调度艺术
  • 计算机网络

    • 网卡通信原理详解
    • 网卡数据包处理指南
    • 基于抓包详解TCP协议
  • 编码最佳实践

    • 浅谈现代软件工程TDD最佳实践
    • 浅谈TDD模式下并发程序设计与实现
    • 面向AI编程新范式Trae后端开发环境搭建与实践
    • 基于Vibe Coding的Redis分页查询实现
    • 告别AI无效对话:资深工程师的提示词设计最佳实践
  • 实用技巧与配置

    • Mac常用快捷键与效率插件指南
    • Keynote技术科普短视频制作全攻略
  • 元认知

    • 摩擦感:AI时代的写作自省
    • 从断墨寻径浅谈程序员的元学习能力
    • AI时代专注力培养
    • 如何阅读一本书:技术书籍的读书笔记方法论
  • 开发工具

    • IDEA配置详解与高效使用指南
    • Windows环境下JDK安装与环境变量配置
    • Windows 10 下的 Maven 安装配置教程
  • Nodejs
  • 博客搭建
  • Redis

    • Redis核心知识小结
    • 解锁Redis发布订阅模式
    • 掌握Redis事务
    • Redis主从复制技术
    • Redis的哨兵模式详解
    • 深度剖析Redisson分布式锁
    • 详解redis单线程设计思路
    • 来聊聊Redis所实现的Reactor模型
    • Redis RDB持久化源码深度解析
    • 来聊聊redis的AOF写入
    • 来聊聊Redis持久化AOF管道通信的设计
    • 来聊聊redis集群数据迁移
    • Redis SDS动态字符串深度解析
    • 高效索引的秘密:redis跳表设计与实现
    • 聊聊redis中的字典设计与实现
    • 感觉你因为AI退化了?用Redis SCAN源码打脸AI时代的孔乙己
  • MySQL

    • MySQL基础知识点小结
    • 解读MySQL 索引基础
    • MySQL 索引进阶指南
    • 解读MySQL Explain关键字
    • 探秘 MySQL 锁:原理与实践
    • 详解MySQL重做日志redolog
    • 详解undoLog在MySQL MVCC中的运用
    • MySQL二进制日志binlog核心知识点
    • MySQL高效插入数据的最佳实践
    • MySQL分页查询优化指南
    • MySQL流式查询的奥秘与应用解析
    • 来聊聊分库分表
    • 来聊聊大厂常用的分布式ID生成方案
  • ElasticSearch

    • Elasticsearch核心原理与架构设计
    • ES 基础使用指南
    • ElasticSearch如何写入一篇文档
    • 深入剖析Elasticsearch文档读取原理
    • 聊聊ElasticSearch性能调优
    • Spring借助Easy-Es操作ES
  • Netty

    • 一文快速了解高性能网络通信框架Netty
    • Netty网络传输简记
    • 来聊聊Netty的ByteBuf
    • 来聊聊Netty消息发送的那些事
    • 解密Netty高性能之谜:NioEventLoop线程池阻塞分析
    • 详解Netty中的责任链Pipeline如何管理ChannelHandler
    • Netty Reactor模型常见知识点小结
    • Netty如何驾驭TCP流式传输?粘包拆包问题全解
    • Netty解码器源码解析
  • 消息队列

    • 一文快速入门消息队列
    • 消息队列RocketMQ入门指南
    • 基于RocketMQ实现分布式事务
    • RocketMQ容器化最佳实践
    • RocketMQ常见问题与深度解析
    • Kafka快速安装与使用指南
  • Nginx

    • Linux下的nginx安装
    • Nginx基础入门总结
    • Nginx核心指令小结
    • Nginx进程结构与核心模块初探
    • Nginx应用进阶HTTP核心模块配置
    • Nginx缓存及HTTPS配置小记
    • nginx高可用实践简记
    • Nginx性能优化
  • 微服务基础

    • 微服务基础知识小结
    • 分布式事务核心概念小结
    • OpenFeign核心知识小结
    • 微服务组件Gateway核心使用小结
    • 分布式事务Seata实践
    • 用 Docker Compose 完成 Seata 的整合部署
  • Nacos

    • Nacos服务注册原理全解析
    • Nacos服务订阅流程全解析
    • Nacos服务变更推送流程全解析
    • 深入解析SpringCloud负载均衡器Loadbalancer
    • Nacos源码环境搭建与调试指南
  • Seata

    • 深度剖析Seata源码
  • Docker部署

    • 一文快速掌握docker的理念和基本使用
    • 使用docker编排容器
    • 基于docker-compose部署微服务基本环境
    • 基于docker容器化部署微服务
    • Gateway全局异常处理及请求响应监控
    • Docker图形化界面工具Portainer最佳实践
  • Go基础

    • AI时代的Go语言基础语法认知
    • 一文快速掌握Go语言切片
    • 来聊聊go语言的hashMap
    • 一文速通go语言类型系统
    • 浅谈Go语言中的面向对象
    • go语言是如何实现协程的
    • 聊聊go语言中的GMP模型
    • 极简的go语言channel入门
    • 聊聊go语言基于epoll的网络并发实现
    • 写给Java开发的Go语言协程实践
  • mini-redis实战

    • 来聊聊我用go手写redis这件事
    • mini-redis如何解析处理客户端请求
    • 实现mini-redis字符串操作
    • 硬核复刻redis底层双向链表核心实现
    • 动手复刻redis之go语言下的字典的设计与落地
    • Go 语言下的 Redis 跳表设计与实现
    • Go 语言版 Redis 有序集合指令复刻探索
    • 基于 Claude Code 复刻 Redis 慢查询指令实践
  • 项目编排

    • Spring脚手架创建简记
    • Spring脚手架集成分页插件
    • Spring脚手架集成校验框架
    • maven父子模块两种搭建方式简记
    • SpringBoot+Vue3前后端快速整合入门
    • 来聊聊Java项目分层规范
  • 场景设计

    • Java实现文件分片上传
    • 基于时间缓存优化浏览器轮询阻塞问题
    • 基于EasyExcel实现高效导出
    • 10亿数据高效插入MySQL最佳方案
    • 从开源框架中学习那些实用的位运算技巧
    • 对账核销场景设计与重构实践
    • 千万级交易流水慢查询综合治理实践
    • 记一次StarRocks源码级排错和既有架构优化实践
    • 基于快照合并修复Seata AT回滚补偿与Flink批攒导致StarRocks数据不一致最佳实践
  • CI/CD

    • 基于NETAPP实现内网穿透
    • 基于Gitee实现Jenkins自动化部署SpringBoot项目
    • Jenkins离线安装部署教程简记
    • 基于Nexus搭建Maven私服基础入门
    • 基于内网的Jenkins整合gitlab综合方案简记
  • 监控方法论

    • SpringBoot集成Prometheus与Grafana监控
    • Java监控度量Micrometer全解析
    • 从 micrometer计量器角度快速上手promQL
    • 硬核安利一个监控告警开源项目Nightingale
  • Spring AI

    • Spring AI Alibaba深度实战:一文掌握智能体开发全流程
    • Spring AI Alibaba实战:JVM监控诊断Arthas Agent的工程化构建与最佳实践
  • 大模型评测

    • M2.7 真能打!我用两个真实场景测了测,结果有点意外
    • Qoder JetBrains插件评测:祖传代码重构与接口优化实战
  • AI工具链

    • Claude Code 实战指南:从安装配置到企业级开发流程
    • 一次 Claude Code 启动失败的 AI 辅助排查复盘
    • 基于提示词工程与KITE框架的Redis签到功能开发实践
    • Claude Code 记忆管理:CLAUDE.md 最佳实践
    • Claude Code 规则管理:Rules 拆分编排与迭代实践(文末送书)
    • VSCode与Claude Code后端开发环境搭建与AI编程工作流实践
    • AI 写的企业级组件不敢用?我替你验过了
关于
收藏
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • Go基础

    • 关于我想写一个Go系列的这件事
    • Go环境以及IDE安装配置简记
    • AI时代的Go语言基础语法认知
      • 写在文章开头
      • 第一行go代码
        • 命令行入参
        • 工具类的使用
      • 变量扫盲
        • 基本类型
        • 字面量与字符串
        • 获取变量的类型
        • 变量赋值
        • 变量的默认值
        • 类型强转
      • 条件分支
        • if语法
        • switch判断
        • 循环分支
      • 函数
        • 基本语法
        • 多返回值
        • 函数与方法
      • Go语言常见命令
      • 小结
      • 参考
    • 速通Go语言编译过程
    • 聊聊Go程序是如何运行的
    • 一文带你速通Go语言数组
    • 一文快速掌握Go语言切片
    • 深入理解go语言中的切片
    • 一文带你速通编程语言中的指针
    • 来聊聊go语言的hashMap
    • 聊聊go语言中map如何解决散列性能下降
    • 一文速通Go语言的map
    • 一文速通go语言类型系统
    • 浅谈Go语言中的面向对象
    • 聊聊go语言中的内存填充
    • 聊聊Go语言中的字符串
    • 聊一聊go语言的空值
    • Go语言企业级日志管理
    • 基于魔改Nightingale源码浅谈go语言包模块管理
    • go语言是如何解决map并发安全问题的
    • go语言是如何实现协程的
    • go语言如何实现协程的抢占式调度的
    • 聊聊go语言中的GMP模型
    • 聊聊go语言对于协程并发的设计
    • 协程是否越多越好
    • 基于Go语言的网络IO扫盲
    • 聊聊go语言基于epoll的网络并发实现
    • 聊聊Go语言中的networkpoller工作机制
    • 聊聊go语言对于socket的抽象
    • 用Go语言实现一个单协程消费者模型
    • 用Go实现一个无界资源池
    • 用go语言实现一个有界协程池
    • 极简的go语言channel入门
    • 聊聊go语言channel为什么可以高效
    • 聊聊go语言channel中的一些小技巧
    • 写给Java开发的Go语言协程实践
  • mini-redis实战

  • Go面试题

  • Go语言
  • Go基础
sharkchili
2026-03-25
目录

AI时代的Go语言基础语法认知

# 写在文章开头

这是笔者很早写的一篇文章,刚好近期在帮助guide哥整理Go语言面试相关的知识点,于是也对这篇文章进行进一步的整理和复盘。

笔者认为在AI时代下,对于初学者而言,我们可以适当降低对于编程语言语法学习的比重,毕竟经过大量语料训练的模型,基本不会出现一些语法表达上的错误。我们更多的应该是是学会建立语言的认知框架。

能够从以下角度思考比使用AI工具完成研发工作:

  • 理解设计取舍:了解Go为什么这样设计
  • 完成工程决策:将语法表达交给AI,开发者着重于在适当场景给出,编码细节上的决策,例如:什么时候用值?什么使用使用指针
  • 建立编程审美能力:AI时代弱化了开发者编码的比重,但软件开发毕竟是一个长期的工程,建立代码审美能力依然很重要,例如:GO鼓励小函数、不提倡过度封装层层继承等,这些都是决定开发者在AI时代下能够高效写出易于维护系统的关键:

SharkChili · 禅与计算机程序设计的艺术

开源贡献

  • mini-redis:教学级 Redis 精简实现 · https://github.com/shark-ctrl/mini-redis

关注公众号,回复 【加群】 加入技术社群

# 第一行go代码

以下面这段代码为例,我们介绍一下Go语言的编码基本套路: 1. 指明运行文件的包为main: Go用包来组织代码,同一个包属于同一个编译单元

2. 导入fmt包: 因为我们要输出语句,所以需要导入fmt包(即format包),这一点与Java不同,Go本着代码简洁的原则,不允许任何多余的信息,一旦导入没有用到的包,Go语言则会编译报错

3. main函数: Go的main函数不接收任何参数也没有任何返回值,这一切都是本着简洁的原则

对应第一行代码示例如下:

// 文件中所有其余代码都属于main包
package main

//导入包
import "fmt"

// main方法,程序运行的入口
func main() {
	//用fmt包的Println输出一段话
	fmt.Println("hello world")
}

1
2
3
4
5
6
7
8
9
10
11
12

完成上述编码之后,我们通过go run main.go运行程序,即可在终端上得到打印的输出语句:

# 命令行入参

我们再来展开说明一下Go语言为什么,没有main函数没有任何的出入参:

  • 标准化原则: 语言只负责负责计算和逻辑处理上的事情,一切外部介质的读写操作都应该交由标准库执行
  • 避免非必要的异常:
  • 职责分离:C函数需要显示return 0,这使得main方法承载太多标准程序应该关心的事情

总的来说,Go语言的理念,就是摈弃一些非必要的仪式感做到简洁和标准化,对应我们也给出命令行入参的处理代码示例,如下所示,默认情况下GO语言索引0是程序名,1参数我们的参数:


import (
	"fmt"
	"os"
)

func main() {
	fmt.Println("程序名:", os.Args[0])
	fmt.Println("参数列表:", os.Args[1:])
}
1
2
3
4
5
6
7
8
9
10

输出结果如下:

# 工具类的使用

可以看到当我们需要用到相应的工具就得导入对应的包,然后通过包名.函数即完成调用。以下面这段代码为例,我们希望打印出2.6向下取整和hello go转大写的字符串,那么我们就需要依次导入:

  1. fmt包。
  2. 数学相关的math包。
  3. 字符串操作的strings包(这里我们用ToUpper将字符串转为大写)。

所以我们的导入包的语法格式如下:

package main

import (
	"fmt"
	"math"
	"strings"
)

func main() {
	//向下取整,math.Floor返回float64类型
	fmt.Println(math.Floor(2.6))
	//字符串转大写
	fmt.Println(strings.ToUpper("hello go"))
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

完成后我们运行程序,得到下面这段输出:

2
HELLO GO
1
2

# 变量扫盲

# 基本类型

对于任何一门编程语言来说,变量都会通过类型来决定内存分配和编译优化,Go语言也一样,总的来说,Go语言大抵有以下几种类型:

  1. 数字类型: int、 int8、int16、int32、int64、uint、uint8、uint16、 uint32、uint64 等,其中int为整型,后面跟着的数字代表位数,例如int8即8位(1个字节)的整型,而uint则无符号整型后面数字的含义一样,默认情况下int的字节数由平台决定,例如笔者使用的是64位架构的系统,那么int默认就是64/8即8个字节。
  2. 字符串类型:string
  3. 布尔类型:bool
  4. 复数类型: complex64 、 complex128,complex64即复数类型,这有一些数学的概念,例如下面这段complex64 即实部虚部都是32位浮点数,complex128即实部和虚部都是64位浮点数,左边为实部右边为虚部,这里我们就先简单介绍一下complex64:
	// 使用复数类型 complex64
	var z1 complex64 = 3 + 2i
	fmt.Println("Complex number:", z1)
	fmt.Println("Real part:", real(z1))
	fmt.Println("Imaginary part:", imag(z1))
1
2
3
4
5

输出结果如下,可以看到打印出来的实部为3,虚部为2:

Complex number: (3+2i)
Real part: 3     
Imaginary part: 2

1
2
3
4

再来看看complex128这个类型:

func main() {
	// 使用复数类型 complex128
	var z2 complex128 = 4 + 5i
	fmt.Println("Complex number:", z2)
	fmt.Println("Real part:", real(z2))
	fmt.Println("Imaginary part:", imag(z2))
}

1
2
3
4
5
6
7
8

对应打印结果是一致的,只不过complex128是64位浮点数,精度更高一些:

Complex number: (4+5i)
Real part: 4
Imaginary part: 5

1
2
3
4

# 字面量与字符串

对于Go语言来说,描述字符的有字符串和字面量,而两者的区别是:

  1. 字面量在Go语言中称为rune,是Unicode码点,即用数字表示字符的编码值,所以在打印时会输出对应的数字。
  2. 字符串声明时通过双引号包围,打印时直接输出字符串。

对此我们给出一段代码示例,最终常量输出位65,而字符串则原样输出:

func main() {
	//打印字面量
	fmt.Println('A')//65
	//打印字符串
	fmt.Println("A")//A
}

1
2
3
4
5
6
7

这一点我们也可以看到Go语言,由此可以看出Go语言默认rune本质上就是一个int32值,存储的则是unicode的码点:

# 获取变量的类型

Go语言的reflect包下提供各种反射的操作,其中TypeOf方法可返回变量类型,这种编写各种需要进行类型检查的高级场景中非常常见。

举个例子,我们现在需要将通过的interface按照原生类型进行转换,类型可能是字符串也可能是数字,对应我们的处理逻辑为,设定三个返回值:

  • 返回值1决定取值空间,我们将后续两个返回值在逻辑上看做一个数组,数组0代表数字,数字1代表字符串
  • 返回值2 记录转换后的数字,若非数字类型写入-1
  • 返回值3写入字符串,若非字符串写入空串

如下图,我们传入字符串,对应返回值1写入索引1,返回值2为-1,返回值3为转换后的字符串:

对应转换代码如下:

/*
*
将interface类型进行格式化转换
返回值0:代表当前类型为数字类型
返回值1代表 字符串类型
返回值-1代表 类型转换失败
*/
func formatValue(v interface{}) (int, int, string) {
	switch reflect.ValueOf(v).Kind() {
	case reflect.Int: //整数类型,返回0,整数空间返回强转数字
		return 0, v.(int), ""
	case reflect.String://字符串类型,返回1,字符串空间返回原值
		return 1, -1, v.(string)
	default://其他类型,返回-1
		return -1, 0, ""
	}
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

输出结果如下:

# 变量赋值

Go语言对于变量的赋值比较灵活,这里笔者介绍一下最基本的赋值语法,通过var声明变量后,再用等号对变量进行赋值:

import (
	"fmt"
)

func main() {
	//声明变量
	var num int
	//赋值
	num = 1
	//使用
	fmt.Println(num)
}
1
2
3
4
5
6
7
8
9
10
11
12

当然go也支持一次性声明多个变量再赋值:

import (
	"fmt"
)

func main() {
	//一次声明多变量
	var num, num2 int
	//赋值
	num = 1
	num2 = 2
	//使用
	fmt.Println(num, num2)
}
1
2
3
4
5
6
7
8
9
10
11
12
13

当然你也可以一次性声明多个变量在进行赋值操作:

import "fmt"

func main() {
	//声明变量并赋值
	var num = 1
	fmt.Println(num)
	var num2, num3 = 2, 3
	fmt.Println(num2, num3)
}
1
2
3
4
5
6
7
8
9

上文笔者说过,Go之所以灵活是因为,在内部函数级别的变量声明时,可以直接通过:=进行初始化,让Go语言再编译时获取变量类型完成内存分配和优化的工作,这也是Go语言一贯的原则:让开发者少写,让编译器多做:

func main() {
	//短变量声明一个int类型
	num := 1
	//打印值
	fmt.Println(num)
	//打印类型
	fmt.Println(reflect.TypeOf(num))
}

1
2
3
4
5
6
7
8
9

对应的输出结果如下,可以看到对应类型打印是int,可以看出Go语言的短变量声明是非常简单且优雅的:

1
int
1
2

# 变量的默认值

go语言的变量默认有值的,例如数字默认为0,布尔默认为false,其他类型同理,这里笔者简单演示一下没有进行任何赋值操作的int和bool类型默认值的打印代码:

func main() {
	//声明变量并赋值
	var num int
	fmt.Println(num)
	var b1, b2 bool
	fmt.Println(b1, b2)
}
1
2
3
4
5
6
7

可以看到结果和笔者说的一样,整型默认输出0,而bool默认为false:

0
false false
1
2

# 类型强转

与其他的编程语言(Java)有所不同,Go语言对不同的精度数字类型计算时不会进行自动的类型升级,所以在进行整数和小数的运算时,我们需要进行一下强转,强转的语法如下即类型(变量):

func main() {
	//不同类型无法通过编译
	length := 2
	width := 3.2
	//将length强转为float
	lengthFloat := float64(length)
	fmt.Println(lengthFloat * width)
}

1
2
3
4
5
6
7
8
9

最终得到正确的计算输出结果:

6.4

1
2

当然如果带小数的类型转为int时,还是需要考虑精度丢失问题,这里笔者就不输出演示了:

import "fmt"

func main() {
	//强转精度丢失问题
	width := 3.6
	fmt.Println(int(width))

}
1
2
3
4
5
6
7
8

# 条件分支

# if语法

与Java和C这类编程语言不同,Go的if语句条件不需要加括号,直接在if后面带上条件即可:

func main() {
	num := 8
	
	if num < 0 {
		fmt.Println("num < 0")
	} else if num < 5 {
		fmt.Println("num < 5")
	} else {
		fmt.Println("num > 5")
	}

}
1
2
3
4
5
6
7
8
9
10
11
12

与之对应Go还有一个强大之处,Go语言支持在逻辑判断前加一个初始化语句,它无需像Java那样进行类型声明,这使得if表达式变得十分简洁和强大。

如下代码所示,我们希望根据函数是否存在异常判断是否执行成功,对应就可以在if语句前加一个逻辑处理并接收返回值,在通过err变量判断处理结果决定输出:


func main() {
	//if判断前执行逻辑,在通过err判断是否执行
	if res, err := doSomething(); err == nil {
		fmt.Println("res:", res)
	}

}

func doSomething() (int, error) {
	return 1, nil
}
1
2
3
4
5
6
7
8
9
10
11
12

# switch判断

和其他编程语言不同的是,Go语言中switch是非常常用的判断,它时常和channel进行配合控制协程调度,这一点笔者会在后续的实际案例中演示,这里先介绍一下switch的语法格式,可以看到go语言的switch也是很清爽的,无需添加break即可完成分支:

func main() {
	num := 3
	
	switch num {
	case 1:
		fmt.Println("num = 1")
	case 2:
		fmt.Println("num = 2")
	case 3:
		fmt.Println("num = 3")
	}

}
1
2
3
4
5
6
7
8
9
10
11
12
13

需要注意的是,Go的switch默认不穿透,这是一个 安全默认值的设计——C 的 switch 穿透是无数 bug 的来源,Go 直接改了默认行为。如果确实需要穿透,必须显式写 fallthrough ,让意图清晰,就像下面这样:


func main() {
	num := 1

	switch num {
	case 1:
		fmt.Println("匹配到1")
		fallthrough
	case 2:
		fmt.Println("穿透到2")
		fallthrough
	case 3:
		fmt.Println("穿透到3")
	default:
		fmt.Println("穿透到default")
	}
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

输出结果如下:

# 循环分支

与其他语言相比Go语言没有while和do-while这种循环,取而代之的都是for循环,通过一个关键字衍生覆盖所有的循环场景,通过少即是多的设计,统一开发者认知框架,降低学习成本:

下面这个例子等同于while(i<10)这种编程习惯:

func main() {

	i := 0
	sum := 0
	for i < 10 {
		sum += i
		i++
	}

	fmt.Println(sum)
}
1
2
3
4
5
6
7
8
9
10
11

对于那些习惯了Java或者C的开发来说,Go语言的无限循环语法可能会让你感到别扭,语言如下所示,即不带任何条件的for:

func main() {

	for {
		fmt.Println("无限循环")
	}
}

1
2
3
4
5
6
7

唯一让读者感到亲切的应该就是下面这种fori格式的有界循环了,这里笔者就不多做赘述了:

func main() {

	sum := 0
	for i := 0; i < 10; i++ {
		sum += i
	}

	fmt.Println(sum)
}

1
2
3
4
5
6
7
8
9
10

# 函数

# 基本语法

函数的基本语法如下,我们希望传入两个int的值得到一个返回int的函数,Go语言的语法格式如下:

func main() {
	fmt.Println(add(1, 2))
}

func add(num1 int, num2 int) int {
	c := num1 + num2
	return c
}
1
2
3
4
5
6
7
8

不过有时候也可以这样写,看起来没有精简到哪里去,对于笔者而言这种语法基本很少用,读者了解一下即可:

func main() {

	fmt.Println(add(1, 2))
}


func add(num1 int, num2 int) (c int) {
	c = num1 + num2
	return c
}
1
2
3
4
5
6
7
8
9
10

# 多返回值

多返回值算是Go语言让读者感到惊艳的地方了,很多编程语言为了得到多返回值,都会采用传入引用进行复制或者像C这种传入指针的操作,非常不优雅,与之相比,Go语言就比较方便了,只需用括号声明多返回值的列表,然后按需返回多个返回值即可:

func main() {
	sum, str := add(1, 2)
	fmt.Println(sum)
	fmt.Println(str)
}

// add 返回int和string类型的函数
func add(num1 int, num2 int) (int, string) {
	c := num1 + num2
	return c, "计算成功"
}

1
2
3
4
5
6
7
8
9
10
11
12

对应的输出结果如下:

3
计算成功

1
2
3

# 函数与方法

与Java不同,Go语言是带有面向过程和面向对象等多种编程方式的语言,通过函数前是否带有接受者决定判断使用方式。

例如 Go语言的fmt.Println输出,则是采用面向过程式的函数,其函数定义就没有任何接受者:

使用方式也是通过包名.函数名即可:

func main() {
	fmt.Println("Hello world")
}

1
2
3
4

而方法则是说明函数名前带有接收者,带有对象属性封装意味的一种编程风格,如下所示,一个专属于Person类型的sayHello方法:


import "fmt"

type Person struct {
	Name string
}

func (p *Person) sayHello() {
	fmt.Println("Hello my name is" + p.Name)
}

func main() {
	p := &Person{"John"}
	p.sayHello()
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

当然,从设计角度我们也很好理解这种语法的理念,它本质是将函数的入参提前到方法名前,通过这种简单的移动,将面向过程式的函数与面向对象式的封装隔离,以确保多编程方式的Go语言能够让开发者快速理解和运用:

# Go语言常见命令

一般情况下,我们现在编写Go语言程序都会采用Goland,通过点击界面运行指令,所以对于下面这些常见命令我们需要简单了解一下,便于后续在Linux上操作以及了解Goland的各个界面中提供的指令的含义:

1. go build 将源代码文件编译为二进制文件
2. go run 编译并运行程序,而不保存可执行文件
3. go fmt 使用GO标准格式重新格式化源文件
4. go version 显示当前Go版本号
1
2
3
4

# 小结

本文从零出发,快速梳理了Go语言的核心语法要素:

  • 程序结构:Go以包为编译单元,main包中的main函数是程序入口,编译器强制要求导入的包必须被使用,从机制上杜绝冗余代码。
  • 变量体系:Go提供了完整的类型系统(整型、浮点、字符串、布尔、复数),支持var声明和:=短变量声明,不同类型之间不会隐式转换,需要显式强转。
  • 控制流:Go用if、switch、for三个关键字覆盖所有分支与循环场景,去掉了while和do-while,switch默认不穿透,这些设计都体现了Go"少即是多"的理念。
  • 函数设计:Go原生支持多返回值,通过接收者机制区分函数与方法,在同一种语言中兼顾面向过程和面向对象两种编程风格。

正如文章开头所说,学习一门语言的关键不在于死记语法,而在于理解其设计取舍——Go的简洁不是简陋,而是经过深思熟虑后的取舍。笔者会在后续的系列中继续深入Go语言各个常用包的源码级原理解析。

SharkChili · 禅与计算机程序设计的艺术

开源贡献

  • mini-redis:教学级 Redis 精简实现 · https://github.com/shark-ctrl/mini-redis

关注公众号,回复 【加群】 加入技术社群

# 参考

Head First Go语言程序设计:https://book.douban.com/subject/35237045/ (opens new window) Go语言实战:https://book.douban.com/subject/27015617/ (opens new window)

编辑 (opens new window)
上次更新: 2026/05/29, 11:26:07
Go环境以及IDE安装配置简记
速通Go语言编译过程

← Go环境以及IDE安装配置简记 速通Go语言编译过程→

最近更新
01
Go语言常见面试题解析(上)语言基础与核心概念
05-20
02
基于快照合并修复Seata AT回滚补偿与Flink批攒导致StarRocks数据不一致最佳实践
05-20
03
AI 写的企业级组件不敢用?我替你验过了
05-19
更多文章>
Theme by Vdoing | Copyright © 2025-2026 Evan Xu | MIT License | 桂ICP备2024034950号 | 桂公网安备45142202000030
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式
×
×