初级程序员必备的十大技能之计算机基础必备(五)

简介: 教程来源 http://vbzcj.cn 本节详解代码运行本质:从C/Java的静态编译(词法→语法→语义→中间码→优化→目标码),到JS的JIT动态编译(AST→字节码→热点优化);并结合CPU 100%、内存泄漏等线上案例,贯通编译原理与实战排障。

五、编译原理:代码是如何运行的

虽然初级程序员不需要实现编译器,但理解编译过程对调试和性能优化很有帮助。

5.1 编译过程

源代码 → 词法分析 → 语法分析 → 语义分析 → 中间代码 → 优化 → 目标代码

例如: sum = a + b * 10

1. 词法分析:拆分成 Token
   [IDENT(sum)] [ASSIGN(=)] [IDENT(a)] [PLUS(+)] [IDENT(b)] [STAR(*)] [NUMBER(10)]

2. 语法分析:生成 AST(抽象语法树)
        =
       / \
     sum   +
          / \
         a   *
            / \
           b   10

3. 语义分析:类型检查、符号表管理
   - a 和 b 必须是数字
   - 10 是整数

4. 中间代码生成:三地址码
   t1 = b * 10
   t2 = a + t1
   sum = t2

5. 优化
   t1 = b * 10
   sum = a + t1

6. 目标代码生成(汇编)
   LOAD R1, b
   MUL R1, 10
   LOAD R2, a
   ADD R2, R1
   STORE sum, R2

5.2 JavaScript 的编译执行
JavaScript 是解释型语言,但现代引擎(V8)使用 JIT(即时编译)技术。

// V8 执行 JavaScript 的过程
// 
// 源代码 → 解析器 → AST → 解释器(Ignition) → 字节码 → 执行
//                                ↓
//                          热点代码检测
//                                ↓
//                          编译器(TurboFan) → 优化机器码

// 帮助 JIT 优化的代码写法
// ✅ 保持对象形状一致(有利于隐藏类优化)
class Point {
    constructor(x, y) {
        this.x = x;
        this.y = y;
    }
}

const points = [];
for (let i = 0; i < 10000; i++) {
    // 所有对象都有相同的属性顺序
    points.push(new Point(i, i * 2));
}

// ❌ 动态添加/删除属性(破坏隐藏类)
const p = { x: 1 };
p.y = 2;  // 改变了对象形状
delete p.x;  // 再次改变

// ✅ 使用单态函数(参数类型一致)
function add(a, b) {
    return a + b;
}

// 始终传入数字
for (let i = 0; i < 10000; i++) {
    add(i, i + 1);  // 被优化为数字加法
}

// ❌ 多态调用(参数类型变化)
add(1, 2);      // 数字
add("a", "b");  // 字符串 → 导致去优化

六、综合实战:排查线上问题

把计算机基础知识综合运用于实际问题排查:

案例:CPU 100% 问题排查

// 问题代码:死循环导致 CPU 飙升
function processQueue(queue) {
    // ❌ 死循环:当 queue 为空时,一直空转
    while (true) {
        if (queue.length > 0) {
            const item = queue.shift();
            process(item);
        }
        // 缺少等待机制
    }
}

// ✅ 正确的实现
function processQueueWithBackoff(queue) {
    function process() {
        if (queue.length > 0) {
            const item = queue.shift();
            process(item);
            setImmediate(process);  // 让出 CPU
        } else {
            setTimeout(process, 100);  // 队列为空时休眠
        }
    }
    process();
}

案例:内存泄漏排查

// 使用 Node.js 的 heap snapshot 功能
// 1. 启动时增加 --inspect 参数
// node --inspect app.js

// 2. 在 Chrome DevTools 中分析 heap snapshot

// 常见内存泄漏的修复
class EventManager {
    constructor() {
        this.listeners = new Map();
    }

    on(event, callback) {
        if (!this.listeners.has(event)) {
            this.listeners.set(event, new Set());
        }
        this.listeners.get(event).add(callback);

        // ✅ 返回取消订阅函数,方便清理
        return () => {
            this.listeners.get(event)?.delete(callback);
        };
    }
}

// 使用 WeakMap 自动清理
const userCache = new WeakMap();  // 当对象被回收时,缓存自动清理

附:知识体系总结

计算机基础
├── 计算机组成原理
│   ├── 二进制与位运算
│   ├── 内存层次结构
│   └── CPU 工作原理
├── 操作系统
│   ├── 进程与线程
│   ├── 并发与并行
│   ├── 死锁
│   └── 内存管理
├── 计算机网络
│   ├── TCP/IP 协议栈
│   ├── HTTP/HTTPS
│   ├── DNS 解析
│   └── 浏览器工作原理
├── 数据库
│   ├── SQL 语言
│   ├── 索引原理
│   ├── 事务与 ACID
│   └── 设计范式
└── 编译原理
    ├── 编译过程
    └── JIT 编译

来源:
http://uklgy.cn

相关文章
|
22天前
|
移动开发 JavaScript 前端开发
前端组件库——Wot Design Uni知识点大全(一)
教程来源 https://zlpow.cn Wot Design Uni 是基于 Vue3 + TypeScript 的开源 uni-app UI 组件库,提供 70+ 高质量移动端组件,支持微信/支付宝小程序、H5、App 等多端兼容,内置暗黑模式、国际化(15+语言)与 CSS 变量主题定制,大幅提升跨平台开发效率。
|
2月前
|
人工智能 前端开发 Java
【SpringAIAlibaba新手村系列】(4)流式输出与响应式编程
本文围绕 Spring AI 中的流式输出与响应式编程展开,重点解释了传统一次性响应与流式返回的差异,以及 Flux 在异步数据流中的核心作用。文章结合 ChatModel.stream() 与 ChatClient 的多种代码示例,说明如何实现 AI 内容的边生成边返回,并帮助读者理解流式调用在用户体验、性能和长文本场景中的实际价值。
847 4
【SpringAIAlibaba新手村系列】(4)流式输出与响应式编程
|
3月前
|
SQL 缓存 算法
Java 内存模型与 volatile:并发底层的轻量级同步核心
`volatile` 是JMM核心轻量级同步关键字,通过内存屏障禁用重排、借助MESI协议保障可见性,精准解决可见性与有序性(不保证原子性),是DCL单例、状态标志等场景的基石,堪称高效并发编程的“轻量级钥匙”。(239字)
261 6
|
2天前
|
人工智能 编解码 运维
告别“氛围编程”:基于 Harness 治理和 SDD 的团队级 AI 研发范式演进与实践
文章内容基于作者个人技术实践与独立思考,旨在分享经验,仅代表个人观点。
告别“氛围编程”:基于 Harness 治理和 SDD 的团队级 AI 研发范式演进与实践
|
1天前
|
SQL 程序员 数据库
初级程序员必备的十大技能之数据库基础(三)
教程来源 http://ltglu.cn/ 本文详解数据库索引优化与事务机制:索引类比书目录,B+树大幅降低IO;详解最左前缀、函数/类型转换等索引失效场景及EXPLAIN分析法;事务部分涵盖ACID、四大隔离级别(解决脏读/不可重复读/幻读)、行锁/乐观锁及秒杀防超卖实战。
|
1天前
|
安全 程序员 开发工具
初级程序员必备的十大技能之 Git 版本控制(二)
教程来源 http://unbgv.cn Git基础操作覆盖日常开发80%场景:含仓库初始化(init/clone)、状态查看(status/diff)、文件暂存与提交(add/commit)、历史浏览(log/blame)及安全撤销(restore/reset/revert),助开发者高效管理代码版本。
|
7天前
|
资源调度 前端开发
前端组件库—— FullCalendar 知识点大全(三)
教程来源 http://fndvx.cn FullCalendar提供丰富交互回调(如dateClick、eventClick、eventDrop、loading、datesSet等),支持事件拖拽、数据加载、视图切换响应;配合Scheduler插件还可实现资源调度与自定义时长视图,满足会议室预订、排班等复杂场景需求。
|
17天前
|
弹性计算 开发框架 前端开发
前端组件库 ——A-Frame 知识点大全(一)
教程来源 https://zlpow.cn A-Frame 是 Mozilla 开源的 WebXR 框架,以声明式 HTML(如 `&lt;a-scene&gt;` `&lt;a-box&gt;`)降低 VR/AR 开发门槛。基于 Three.js 与 WebGL,支持跨平台运行,让 Web 开发者零基础快速构建沉浸式 3D 体验。
|
18天前
|
前端开发 开发者 UED
前端组件库 ——Angular Material 知识点大全(一)
教程来源 https://www.ltglu.cn/ Angular Material 是 Angular 官方维护的 UI 组件库,深度集成框架、原生支持 Material Design 3、无障碍访问与国际化。本文系统讲解其理念、安装、核心组件、主题定制及最佳实践,助开发者高效构建企业级应用。
|
18天前
|
前端开发 测试技术 开发者
前端组件库 ——Angular Material 知识点大全(三)
教程来源 www.xgmoi.cn 本节介绍 Angular Material 性能优化与最佳实践:按需导入模块、OnPush 变更检测、路由懒加载;推荐共享模块封装、standalone 组件、响应式布局,并提醒风格适配、表单国际化、版本升级及主题定制等关键注意事项。