当前位置:首页>java>深入理解 FIRM 中间表示:从 C 代码到图表示的转换

深入理解 FIRM 中间表示:从 C 代码到图表示的转换

  • 2026-02-05 00:54:53
深入理解 FIRM 中间表示:从 C 代码到图表示的转换

摘要

本文通过多个 C 语言示例,详细解析 FIRM 中间表示(IR)的图结构特性。我们将从简单的算术运算开始,逐步深入到条件分支、循环控制和函数调用等复杂结构,每个示例都基于实际的 FIRM IR 图,直观展示 FIRM 如何将传统线性代码转换为基于图的中间表示。通过本文,读者将全面了解 FIRM IR 的设计哲学、图节点类型及其在实际编译中的应用。

目录

  1. 1. FIRM IR 设计哲学
  2. 2. 简单算术运算的 IRG 表示
  3. 3. 条件分支(if-else)的 IRG 表示
  4. 4. 循环控制(break/continue)的 IRG 表示
  5. 5. 函数调用的 IRG 表示
  6. 6. 综合示例与模式总结

1. FIRM IR 设计哲学

FIRM(Flexible IR Manipulation)是由奥地利林茨大学开发的编译器基础架构,采用完全图基中间表示,将程序的控制流和数据流统一表示为有向图。与传统的线性 IR(如三地址码)相比,FIRM 的设计代表了现代编译器中间表示的发展方向。

FIRM 框架概述

FIRM 是一个用于编译器优化的开源框架,具有以下特点:

  • • SSA 形式内置:所有值都是静态单赋值形式,Phi 节点处理控制流汇合
  • • 图结构表示:程序表示为有向图,节点表示操作,边表示依赖关系
  • • 多种优化:内建多种优化算法,如常量传播、死代码消除、循环优化等
  • • 目标无关:支持多种后端目标架构
  • • 模块化设计:易于扩展和集成到其他编译器项目中

核心特性

  1. 1. 双重图结构
    • • 控制流图:基本块作为节点,控制流转移作为边
    • • 数据流图:操作作为节点,数据依赖作为边
  2. 2. 显式依赖表示
    • • 控制依赖:通过红色边表示执行顺序
    • • 数据依赖:通过黑色边(块内)和蓝色虚线边(块间)表示
    • • 内存依赖:通过蓝色虚线边表示内存操作顺序
  3. 3. 统一的节点模型
    • • 所有操作都是图中的节点,包括算术运算、控制转移、内存访问等
    • • 节点具有明确的类型和模式信息
  4. 4. 基本块作为容器
    • • 基本块包含一组节点,这些节点共享相同的控制流入口
    • • 块内节点可以并行执行(如果没有数据依赖)

设计优势

FIRM 的图IR设计具有以下优势:

  1. 1. 优化友好:图结构天然支持多种优化算法,许多优化可以表示为简单的图变换
  2. 2. 分析准确:显式的依赖关系消除了传统IR中的隐式依赖,提高了分析的准确性
  3. 3. 并行化潜力:显式的数据依赖便于识别可并行执行的操作
  4. 4. 目标代码生成:图结构可以更直接地映射到现代处理器的指令调度

与线性 IR 的对比

特性
线性 IR(如三地址码)
FIRM图 IR
控制流表示
基本块+跳转指令
基本块节点+控制依赖边
数据流表示
操作数在指令中
显式数据依赖边
跨块数据依赖
通过寄存器/内存隐式
显式跨块数据边
优化分析
需要构建额外数据结构
图结构自然支持
循环处理
需要循环分析
图循环自然表示
内存操作
隐式顺序
显式内存依赖边

2. 简单算术运算的 IRG 表示

C 语言示例

int add_example(int a, int b) {    int c = a + b;    int d = c * 2;    return d;}

对应 IRG 图

图结构解析

这个简单的 IRG 展示了 FIRM 的基本构建块:

  1. 1. Start 节点:函数入口点,产生一个包含参数元组和控制流的元组
  2. 2. Proj 节点:从元组中投影出具体值
  • • Proj args:投影出参数元组
  • • Proj M:投影出内存状态
  • • Proj a 和 Proj b:从参数元组中投影出具体参数
  1. 3. 计算节点:执行实际运算
  • • Add:加法运算节点
  • • Mul:乘法运算节点
  1. 4. 常量节点Const 2 表示字面量常量 2
  2. 5. Return 节点:函数返回点,连接到 End 节点

数据流和控制流

在 FIRM 中,数据流和控制流是分离的:

  1. 1. 数据流
    a → Add → Mul → Returnb ↗          ↗ Const 2

    数据流清晰地表示了值的计算顺序和依赖关系。

  2. 2. 内存流
    Proj M → Return

    内存状态在函数开始时被投影,在函数返回时被使用,确保内存操作的顺序性。

  3. 3. 控制流
    Start → 主计算块 → Return → End

    控制流表示执行的顺序,从 Start 开始,经过主计算块,到 Return 结束。

关键观察

  1. 1. 所有值都是 SSA 形式:每个值只被赋值一次,通过数据依赖边传递
  2. 2. 显式依赖:所有依赖关系都通过边显式表示
  3. 3. 块内并行潜力:如果两个操作没有数据依赖,它们可以在同一基本块内并行执行
  4. 4. 内存状态显式化:内存操作通过特殊边序列化,支持精确的内存分析

3. 条件分支(if-else)的 IRG 表示

C 语言示例

int max(int a, int b) {    int result;    if (a > b) {        result = a;    } else {        result = b;    }    return result;}

对应 IRG 图

控制流模式

这个 IRG 展示了条件分支的标准模式:

  1. 1. 条件判断块:包含 Cmp 比较节点和 Cond 条件节点,产生两个控制流投影(true/false)
  2. 2. 分支块分离:then 和 else 分支位于不同基本块,通过 Jmp 节点连接到汇合块
  3. 3. Phi 节点合并:在控制流汇合点的 Phi 节点根据前驱块选择正确的值
  4. 4. 显式跨块数据依赖Phi 节点直接从源基本块的 Proj 节点获取值(蓝色虚线)

关键特性

  1. 1. 控制流边:从控制流节点(Proj true/false)指向基本块(红色实线)
  2. 2. 跨块数据边:从源节点的数据输出到目标节点的数据输入(蓝色虚线)
  3. 3. 内存依赖边:从 Proj M 到 Return 的内存状态传递(蓝色实线)
  4. 4. Phi 节点:在控制流汇合点合并来自不同路径的值,这是 SSA 形式的核心

与传统三地址码对比

传统三地址码

t1 = a > bif t1 goto L1result = bgoto L2L1:result = aL2:return result

FIRM 优势

  • • 显式的数据依赖边
  • • 跨块数据流直接表示
  • • 无显式标签,控制流通过边表示
  • • Phi 节点直接合并值,无需额外的移动指令

4. 循环控制(break/continue)的 IRG 表示

C 语言示例

int loop_example(int n) {    int sum = 0;    int i = 0;    while (i < n) {        if (i == 5) {            break;      // 提前退出循环        }        if (i % 2 == 0) {            i++;        // continue 的等价操作            continue;        }        sum += i;        i++;    }    return sum;}

对应 IRG 图

循环结构解析

这个复杂的 IRG 展示了循环控制流的完整表示:

  1. 1. 循环头 Phi 节点
  • • Phi[loop] M:内存状态Phi节点,跟踪循环中的内存状态
  • • Phi i:循环变量i的Phi节点,合并每次迭代的值
  • • Phi sum:累加和的Phi节点
  1. 2. 嵌套条件判断
  • • 外层:循环条件 i < n
  • • 内层1:break条件 i == 5
  • • 内层2:continue条件 i % 2 == 0
  1. 3. 控制流分离
  • • break路径:直接跳转到循环后块
  • • continue路径:跳过sum累加,直接进行i++
  • • 正常路径:执行sum累加和i++
  1. 4. 数据流更新
  • • 循环体中的计算通过跨块数据边更新Phi节点
  • • 加法操作的结果通过跨块数据边反馈到对应的Phi节点
  1. 5. 循环出口:正常退出(条件为假)和提前退出(break)都汇聚到循环后块

内存状态管理

  • • Phi[loop] M:特殊的循环内存Phi节点,确保内存操作在循环中的正确顺序
  • • Pin M:内存状态钉住节点,将内存状态从循环体传递回循环头

循环优化潜力

FIRM 的循环表示为优化提供了丰富的信息:

  1. 1. 循环不变代码外提:可以识别循环中不变的计算并移到循环外
  2. 2. 归纳变量优化:循环变量i的Phi节点和更新操作便于进行归纳变量优化
  3. 3. 循环展开:循环结构明确,便于进行循环展开优化
  4. 4. 软件流水线:显式的数据依赖便于安排指令执行顺序

5. 函数调用的 IRG 表示

C 语言示例

int helper(int x) {    return x * 2;}int caller(int a, int b) {    int temp = helper(a);    return temp + b;}

对应 IRG 图

函数调用模式

函数调用在 FIRM 中表示为特殊结构:

  1. 1. Call 节点:表示函数调用,连接到被调用函数的 IRG
  2. 2. 参数传递:调用者参数通过 Call 节点的输入边传递
  3. 3. 控制流转移:Call 节点会等待被调用函数执行完毕
  4. 4. 返回值处理:Call 节点的结果投影包含返回值
  5. 5. 独立 IRG:每个函数有自己独立的 IRG,通过 Call 节点连接
  6. 6. 内存依赖传递:内存状态通过 Call 节点在调用者和被调用者之间传递

内存状态流

Proj M (caller) → Call helper → Return (caller)

内存状态在函数调用前后保持一致,确保内存操作的顺序性。

函数调用优化

FIRM 的函数调用表示支持多种优化:

  1. 1. 内联优化:Call 节点可以被被调用函数的 IRG 替换
  2. 2. 尾调用优化:识别尾调用并优化为跳转
  3. 3. 参数传递优化:通过显式的参数边优化参数传递
  4. 4. 过程间优化:跨函数的数据流分析

6. 综合示例与模式总结

FIRM IR 节点类型总结

节点类型功能示例
Start
函数入口点产生参数和控制流
Start
Proj
从元组中投影出具体值
Proj args
Proj true/false
Const
常量值
Const 0
Const 1
计算节点
算术/逻辑运算
Add
MulCmpAnd
Cond
条件分支
Cond
Phi
SSA Phi函数,合并不同路径的值
Phi result
Phi[loop]
循环内存Phi节点
Phi[loop] M
Pin
内存状态钉住节点
Pin M
Call
函数调用
Call helper
Return
函数返回
Return
Jmp
无条件跳转
Jmp
End
函数结束
End

边类型总结

边类型表示颜色/样式功能
控制流边
节点→基本块
红色实线
表示执行顺序和控制转移
块内数据边
节点→节点(同一块内)
黑色实线
同一基本块内的数据依赖
块间数据边
节点→节点(不同块间)
蓝色虚线
跨基本块的数据依赖
内存依赖边
内存相关节点间
蓝色实线
内存操作顺序依赖
跨函数调用边
Call节点→被调用函数
灰色虚线
函数调用关系

如果您希望更加极端地限制每行长度(强制每行最多6-8个字符):

边类型表示颜色/样式功能
控制流边
节点→基本
红色实线
表示执行顺序和控制转移
块内数据边
节点→节点(同一块内)
黑色实线
同一基本块内的数据依赖
块间数据边
节点→节点(不同块间)
蓝色虚线
跨基本块的数据依赖
内存依赖边
内存相关节点间
蓝色实线
内存操作顺序依赖
跨函数调用边
Call节点→被调用函数
灰色虚线
函数调用关系

FIRM IR 的设计优势

  1. 1. 显式依赖关系:所有依赖(控制、数据、内存)都显式表示为边,优化器可以直接利用图结构
  2. 2. 自然循环表示:循环在图中形成环,循环头有专门的Phi节点,便于循环优化
  3. 3. 统一的SSA表示:所有值都是SSA形式,Phi节点机制天然支持SSA
  4. 4. 跨块数据流:允许数据依赖跨越基本块边界,更精确地表示数据流
  5. 5. 内存模型显式化:内存操作通过特殊依赖边序列化,支持复杂的内存优化
  6. 6. 函数边界清晰:每个函数有独立IRG,通过Call节点连接,支持过程间优化

实际编译器中的应用

FIRM 的图IR在编译器中提供了以下优势:

  1. 1. 优化算法简化:许多优化(如常量传播、死代码消除)可以表示为图变换
  2. 2. 分析效率高:数据流分析可以直接遍历图边,无需额外数据结构
  3. 3. 并行化支持:显式的依赖关系便于识别可并行执行的部分
  4. 4. 硬件映射直接:图结构可以更直接地映射到现代硬件的并行执行单元

与传统编译器的对比

特性传统编译器FIRM 编译器
中间表示
线性IR(三地址码)
图IR
优化方式
基于基本块的局部优化
基于图的全局优化
循环分析
需要额外的循环分析
循环自然表示为图中的环
数据流分析
需要构建的数据流方程
可以直接遍历图边
并行化
需要复杂的依赖分析
依赖关系显式表示

结论

通过以上示例和分析,我们可以看到 FIRM 的图中间表示不仅能够准确表达程序语义,还通过显式的依赖边提供了丰富的结构信息。这种表示方法在保留传统控制流图直观性的同时,通过统一的数据依赖边和特殊的内存模型实现了更强大的分析和优化能力。

FIRM 的设计体现了现代编译器中间表示的发展趋势:

  • • 从线性表示到图表示
  • • 从隐式依赖到显式依赖
  • • 从局部优化到全局优化
  • • 从串行处理到并行处理

对于编译器开发者而言,理解 FIRM 的图IR设计有助于掌握现代编译器技术的关键概念;对于计算机科学学生而言,FIRM 提供了学习和研究编译器优化的绝佳平台。

随着计算机体系结构的发展和多核处理器的普及,图基中间表示的重要性将日益凸显。FIRM 作为这一领域的先驱,为未来的编译器设计提供了宝贵的经验和思路。

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-02-07 18:29:35 HTTP/2.0 GET : https://f.mffb.com.cn/a/472009.html
  2. 运行时间 : 0.203917s [ 吞吐率:4.90req/s ] 内存消耗:4,572.18kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=05a724e1001f816931b2561c01191531
  1. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/public/index.php ( 0.79 KB )
  2. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/autoload.php ( 0.17 KB )
  3. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_real.php ( 2.49 KB )
  4. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/platform_check.php ( 0.90 KB )
  5. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/ClassLoader.php ( 14.03 KB )
  6. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_static.php ( 4.90 KB )
  7. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  10. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  11. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  12. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  13. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  14. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  15. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  16. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  17. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-dumper/src/helper.php ( 0.18 KB )
  18. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/VarDumper.php ( 4.30 KB )
  19. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  20. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  21. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  22. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/provider.php ( 0.19 KB )
  23. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  24. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  25. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  26. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/common.php ( 0.03 KB )
  27. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  28. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  29. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/app.php ( 0.95 KB )
  30. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cache.php ( 0.78 KB )
  31. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/console.php ( 0.23 KB )
  32. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cookie.php ( 0.56 KB )
  33. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/database.php ( 2.48 KB )
  34. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  35. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/filesystem.php ( 0.61 KB )
  36. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/lang.php ( 0.91 KB )
  37. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/log.php ( 1.35 KB )
  38. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/middleware.php ( 0.19 KB )
  39. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/route.php ( 1.89 KB )
  40. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/session.php ( 0.57 KB )
  41. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/trace.php ( 0.34 KB )
  42. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/view.php ( 0.82 KB )
  43. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/event.php ( 0.25 KB )
  44. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  45. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/service.php ( 0.13 KB )
  46. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/AppService.php ( 0.26 KB )
  47. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  48. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  49. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  50. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  51. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  52. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/services.php ( 0.14 KB )
  53. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  54. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  55. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  56. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  57. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  58. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  59. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  60. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  61. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  62. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  63. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.21 KB )
  64. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.44 KB )
  65. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  66. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  67. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.29 KB )
  68. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  69. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  70. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  71. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  72. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  73. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  74. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  75. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  76. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  77. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  78. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  79. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Arr.php ( 16.63 KB )
  80. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/driver/File.php ( 7.84 KB )
  81. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  82. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  83. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/Request.php ( 0.09 KB )
  84. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  85. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/middleware.php ( 0.25 KB )
  86. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  87. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  88. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/middleware/SessionInit.php ( 1.94 KB )
  89. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Session.php ( 1.80 KB )
  90. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/driver/File.php ( 6.27 KB )
  91. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php ( 0.87 KB )
  92. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/Store.php ( 7.12 KB )
  93. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  94. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  95. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  96. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  97. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  98. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  99. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/route/app.php ( 1.72 KB )
  100. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  101. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  102. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  103. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/controller/Index.php ( 4.81 KB )
  104. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/BaseController.php ( 2.05 KB )
  105. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  106. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.44 KB )
  107. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/PDOConnection.php ( 52.47 KB )
  108. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  109. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  110. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  111. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Builder.php ( 24.06 KB )
  112. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  113. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Query.php ( 15.71 KB )
  114. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  115. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  116. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  117. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  118. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  119. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  120. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  121. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  122. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  123. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  124. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  125. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  126. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  127. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  128. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  129. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/View.php ( 1.70 KB )
  130. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  131. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  132. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  133. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  134. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-view/src/Think.php ( 8.38 KB )
  135. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  136. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/Template.php ( 46.61 KB )
  137. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/driver/File.php ( 2.41 KB )
  138. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/contract/DriverInterface.php ( 0.86 KB )
  139. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/runtime/temp/067d451b9a0c665040f3f1bdd3293d68.php ( 11.98 KB )
  140. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000822s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001527s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000646s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.002431s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001370s ]
  6. SELECT * FROM `set` [ RunTime:0.003125s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001421s ]
  8. SELECT * FROM `article` WHERE `id` = 472009 LIMIT 1 [ RunTime:0.001040s ]
  9. UPDATE `article` SET `lasttime` = 1770460175 WHERE `id` = 472009 [ RunTime:0.023205s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 65 LIMIT 1 [ RunTime:0.000568s ]
  11. SELECT * FROM `article` WHERE `id` < 472009 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.001134s ]
  12. SELECT * FROM `article` WHERE `id` > 472009 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.001044s ]
  13. SELECT * FROM `article` WHERE `id` < 472009 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.001856s ]
  14. SELECT * FROM `article` WHERE `id` < 472009 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.001382s ]
  15. SELECT * FROM `article` WHERE `id` < 472009 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.001741s ]
0.207621s