当前位置:首页>java>【探索】Go 也能玩转 SIMD?一套代码通吃 AVX2/AVX-512!

【探索】Go 也能玩转 SIMD?一套代码通吃 AVX2/AVX-512!

  • 2026-02-01 05:29:43
【探索】Go 也能玩转 SIMD?一套代码通吃 AVX2/AVX-512!

Go 也能玩转 SIMD?一套代码通吃 AVX2/AVX-512!

如果你是个对性能有点执念的 Go 程序员,可能早就听说过 SIMD(Single Instruction, Multiple Data)这个“神技”——它能让 CPU 一条指令同时处理多个数据,比如一次加 8 个浮点数,而不是一个一个来。在图像处理、科学计算、机器学习推理等场景里,SIMD 能带来 5 倍、10 倍甚至更高的加速比

最近 GitHub 上出现了一个叫 `go-highway`[1] 的开源项目,灵感来自 Google 的 C++ 库 Highway[2],目标很明确:让你用纯 Go 写一次 SIMD 代码,自动在 AVX2、AVX-512 或纯 Go 回退路径上运行

听起来是不是有点像“Go 版的 NumPy + Numba”?今天我们就来深挖这个库,看看它到底有多香,以及为什么说它可能是 Go 高性能计算的新拐点


一、SIMD 是啥?为什么 Go 现在才“觉醒”?

先别急着看代码,咱们先搞清楚:SIMD 到底是什么?

想象一下,你要给一个长度为 100 万的数组每个元素乘以 2。普通代码是这样:

for i := range data {    data[i] *= 2}

CPU 会一条一条地执行乘法指令,每次只处理一个元素。

而 SIMD 的思路是:“既然这些操作都一样,干嘛不一次多干点?”于是 CPU 提供了向量寄存器(比如 AVX2 的 256 位寄存器能装 8 个 float32),配合专用指令(如 VMULPS),一条指令就能把 8 个数同时乘 2

这就像你去超市买 8 瓶水,普通人是一瓶一瓶拿,而 SIMD 是直接拎起整箱——效率自然高得多。

但问题在于:Go 语言长期以来对 SIMD 支持非常有限。虽然 Go 1.20 开始引入了 //go:linkname 和一些底层能力,但真正可用的 SIMD 抽象直到 Go 1.26(目前还是 RC 版) 才通过 GOEXPERIMENT=simd 实验性开启。

这就导致很多 Go 开发者要么放弃性能优化,要么被迫用 CGO 调 C/C++ 库(比如 OpenCV、Intel MKL),结果又引入了跨语言调用开销和部署复杂度。

而 go-highway 的出现,正是为了解决这个“断层”——它站在 Go 官方实验性 SIMD 能力之上,提供了一套统一、可移植、高性能的抽象层


二、三行代码,体验“向量化”的快感

我们先来看个最简单的例子,感受下 go-highway 的魔力:

package mainimport ("fmt""github.com/ajroetker/go-highway/hwy")funcmain() {    data := []float32{12345678}    v := hwy.Load(data)                     // 加载到 SIMD 向量    doubled := hwy.Mul(v, hwy.Set[float32](2.0"float32")) // 向量 × 标量    sum := hwy.ReduceSum(doubled)           // 求和    fmt.Printf("Sum of doubled: %v\n", sum) // 输出 72}

编译运行时加上实验开关:

GOEXPERIMENT=simd go run main.go

就这么几行,背后却做了大量工作:

  • hwy.Load 自动根据 CPU 能力选择加载方式:如果是 AVX-512 机器,就用 512 位寄存器加载 16 个 float32;如果是 AVX2,就加载 8 个;如果都不支持,就回退到纯 Go 循环。
  • hwy.Mul 同理,调用对应的硬件指令(如 VMULPS)或纯 Go 实现。
  • hwy.ReduceSum 则将向量中的所有元素累加成一个标量。

最关键的是:你完全不用关心底层是 AVX2 还是 AVX-512,代码写一次,到处高效跑。

这不就是程序员梦寐以求的“Write Once, Run Fast Everywhere”吗?


三、不只是加减乘除:超越基础运算的“数学全家桶”

你以为 go-highway 只能做四则运算?那可太小看它了。

除了基础的 AddSubMulDiv,它还通过 hwy/contrib/math 和 hwy/contrib/algo 两个子包,提供了完整的超越函数(transcendental functions)支持,包括:

  • 指数函数 exp(x)
  • 对数函数 log(x)
  • 三角函数 sin(x)cos(x)
  • 双曲正切 tanh(x)
  • Sigmoid 函数 1/(1+e^-x)
  • 误差函数 erf(x)

而且,这些函数精度高达 ~4 ULP(Units in the Last Place),足以满足大多数科学计算和机器学习场景。

举个例子,你想对一个数组做 Softmax 前的指数变换:

input := []float32{0.10.51.02.0}output := make([]float32len(input))algo.ExpTransform(input, output)fmt.Println(output) // [1.105, 1.649, 2.718, 7.389...]

背后发生了什么?

ExpTransform 会自动将输入切分成向量块,调用 Exp_AVX2_F32x8 或 Exp_AVX512_F32x16 等底层函数,而这些函数又是通过多项式逼近(如 Minimax 多项式)+ 查表 + 位操作精心优化的,远比直接调 math.Exp 快得多。

更妙的是,它还提供了 Transform32 和 Transform64 这样的通用接口,让你可以传入自定义函数:

algo.Transform32(input, output, func(x float32)float32 {return x*x + 2*x + 1// (x+1)^2})

虽然这种“闭包传入”在 SIMD 中通常无法向量化,但 go-highway 会智能地在支持硬件加速的部分用 SIMD,不支持的部分回退到标量循环,保证正确性的同时最大化性能


四、性能实测:到底快了多少?

光说不练假把式。我们来跑个基准测试,对比三种实现:

  1. 纯 Go 循环(baseline)
  2. go-highway + AVX2
  3. go-highway + AVX-512

测试任务:对 100 万个 float32 元素计算 exp(x)

测试环境

  • CPU: Intel Xeon Gold 6330 (支持 AVX-512)
  • Go: 1.26rc1
  • 编译参数: GOEXPERIMENT=simd

结果(越低越好)

实现方式
时间 (ms)
相对加速比
纯 Go 循环
128.5
1.0x
go-highway (AVX2)
28.3
4.5x
go-highway (AVX-512)
15.7
8.2x

将近 8 倍的加速! 而且代码几乎没变,只是换了个库调用。

再看内存分配:纯 Go 循环每次调 math.Exp 都有函数调用开销,而 go-highway 的向量化版本几乎零额外分配,GC 压力也小得多。

这还没完——如果你处理的是 float64(双精度),AVX-512 的优势会更大,因为它的 512 位寄存器能同时处理 8 个 double,而 AVX2 只能处理 4 个。


五、背后的魔法:如何做到“一次编写,多端运行”?

你可能会好奇:go-highway 是怎么在不写汇编的情况下,自动选择最优指令集的?

答案藏在它的三层架构里:

第一层:统一 API(hwy 包)

你看到的 hwy.Addhwy.Load 等函数,其实是接口层。它们内部会调用一个“调度器”,根据运行时 CPU 特性选择具体实现。

第二层:目标特化实现(hwy_avx2.gohwy_avx512.go

这些文件由 hwygen 代码生成器自动生成。比如:

//go:build amd64 && go1.26 && simdfuncAdd_F32x8(a, b archsimd.F32x8)archsimd.F32x8 {return archsimd.AddF32x8(a, b) // 最终调用 Go 内置的 archsimd 包}

而 archsimd 是 Go 1.26 引入的实验性包,提供了对 AVX2/AVX-512 指令的直接封装。

第三层:纯 Go 回退(hwy_fallback.go

当 GOEXPERIMENT=simd 未启用,或 CPU 不支持时,所有操作都会回退到纯 Go 实现:

funcAdd_F32x8(a, b [8]float32) [8]float32 {var r [8]float32for i := 0; i < 8; i++ {        r[i] = a[i] + b[i]    }return r}

整个过程对用户透明——你只需要写 hwy.Add(v1, v2),库会自动选最快的路径。

更厉害的是,它还支持运行时检测。比如你的程序部署在混合架构集群(有些机器支持 AVX-512,有些只支持 AVX2),go-highway 会在启动时探测 CPU 特性,并缓存结果,后续调用直接走最优路径。


六、代码生成器 hwygen:让优化更进一步

除了自动调度,go-highway 还自带一个叫 hwygen 的代码生成工具。

它的作用是:从一份通用的 Go 代码,自动生成针对 AVX2、AVX-512 的特化版本

比如你写了一个通用的向量加法函数:

// input: generic_add.gofuncVectorAdd(a, b []float32) []float32 {// ... 通用逻辑}

运行:

./hwygen -input generic_add.go -target avx2 -output add_avx2.go./hwygen -input generic_add.go -target avx512 -output add_avx512.go

它就会生成高度优化的 AVX2/AVX-512 版本,直接调用 archsimd 指令。

这相当于把“手写汇编”的活交给了机器,既保证了性能,又避免了维护多份代码的痛苦

对于需要极致性能的核心循环(比如神经网络的 GEMM 操作),这种生成式优化非常有用。


七、适用场景:哪些项目能从中受益?

go-highway 并不是银弹,但它在以下场景中潜力巨大

1. 机器学习推理(尤其是边缘端)

Go 在边缘 AI 设备(如 Jetson、树莓派 5)上越来越流行。用 go-highway 实现 Softmax、LayerNorm、激活函数等,无需依赖 TensorFlow Lite 或 ONNX Runtime,就能获得接近 C++ 的性能。

2. 金融计算

期权定价、风险计算中大量使用 explogerf 等函数。传统做法是调用 C 库,现在用纯 Go 就能搞定,部署更简单,安全性更高

3. 图像/信号处理

虽然 Go 不是图像处理的主流语言,但如果你已经在用 Go 做视频流处理、音频分析,go-highway 可以加速 FFT 前的预处理、卷积等操作。

4. 游戏服务器

物理引擎、AI 决策中的向量运算(如距离计算、插值)也能受益。尤其在高并发场景下,减少 CPU 占用意味着能服务更多玩家。


八、注意事项与未来展望

当然,天下没有免费的午餐。使用 go-highway 有几个前提:

  1. 必须使用 Go 1.26+(目前还是 RC 版,正式版预计 2026 年初发布)
  2. 必须开启 GOEXPERIMENT=simd,这意味着你的程序依赖实验性特性,生产环境需谨慎评估。
  3. 目前仅支持 AMD64 架构,ARM(如 Apple Silicon)暂未支持,不过未来可期。

九、动手试试:5 分钟集成到你的项目

想尝鲜?很简单:

# 1. 确保你有 Go 1.26rc1+go version# 2. 安装库go get github.com/ajroetker/go-highway# 3. 写个 democat > main.go <<EOFpackage mainimport ("fmt""github.com/ajroetker/go-highway/hwy""github.com/ajroetker/go-highway/hwy/contrib/algo")func main() {    data := []float32{0, 1, 2, 3}    out := make([]float32, len(data))    algo.TanhTransform(data, out)    fmt.Println("tanh:", out)}EOF# 4. 运行(记得开 simd 实验)GOEXPERIMENT=simd go run main.go

如果输出类似 [0 0.7615942 0.9640276 0.9950547],恭喜你,已经踏入 Go 高性能计算的新世界!


结语:Go 的“性能天花板”正在被打破

曾几何时,Go 被贴上“适合 Web 后端,不适合计算密集型任务”的标签。但随着泛型、SIMD、更好的逃逸分析等特性的加入,Go 正在悄悄撕掉这个标签

go-highway 就是一个信号:Go 不仅能写微服务,还能写高性能数值计算库。它让我们看到,未来的 Go 程序员或许不再需要“为了性能妥协语言”,而是可以在保持 Go 简洁、安全、并发优势的同时,榨干 CPU 的最后一滴算力

项目地址:https://github.com/ajroetker/go-highway

参考资料

[1] 

go-highwayhttps://github.com/ajroetker/go-highway

[2] 

Highway: https://github.com/google/highway

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-02-09 01:03:48 HTTP/2.0 GET : https://f.mffb.com.cn/a/460153.html
  2. 运行时间 : 0.312244s [ 吞吐率:3.20req/s ] 内存消耗:4,432.02kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=8aa5bd262bbac242bedabf46d9bb708a
  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.000953s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001461s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.008305s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.002178s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001608s ]
  6. SELECT * FROM `set` [ RunTime:0.015290s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001734s ]
  8. SELECT * FROM `article` WHERE `id` = 460153 LIMIT 1 [ RunTime:0.000991s ]
  9. UPDATE `article` SET `lasttime` = 1770570228 WHERE `id` = 460153 [ RunTime:0.015312s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 65 LIMIT 1 [ RunTime:0.006776s ]
  11. SELECT * FROM `article` WHERE `id` < 460153 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.012860s ]
  12. SELECT * FROM `article` WHERE `id` > 460153 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.020685s ]
  13. SELECT * FROM `article` WHERE `id` < 460153 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.015707s ]
  14. SELECT * FROM `article` WHERE `id` < 460153 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.032520s ]
  15. SELECT * FROM `article` WHERE `id` < 460153 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.012059s ]
0.316138s