当前位置:首页>java>Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!

Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!

  • 2026-03-26 20:21:50
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!

  • 前言
  • 正文
    • 最初的痛点
    • 进化:拥抱 try-with-resources
    • Pro: 函数式接口
    • Pro Max:异常处理
    • 完整代码
    • 一个DEMO
    • 改进建议
  • 总结

前言

在开发过程中,性能监控和调试是我们经常面对的问题。

虽然市面上有许多成熟的性能监控工具,但有时我们需要一个轻量级、灵活且优雅的解决方案。

当然也可以自己手动在业务代码中进行追踪,比如先记录startTime,执行结束后再拿当前时间减去startTime,计算出耗时。但是毕竟会制造很多重复代码。

本文将介绍如何设计和实现一个简洁而优雅的TimeTracker工具类,它不仅能满足基本的性能追踪需求,还支持了函数式接口、try-with-resources等多种调用机制。

正文

最初的痛点

还记得我们是怎么记录代码执行时间的吗?到处都是这样的代码:

long start = System.currentTimeMillis();try {// 业务逻辑finally {// 计算耗时}

每次都得写这种重复又啰嗦的代码,要不就得复制粘贴,还容易漏掉,CV大法固然好,但懒人总想要更懒的方式。

进化:拥抱 try-with-resources

偶然间,我想到了 AutoCloseable 接口,再想到每次处理流的时候,直接 try 里面一包,什么都不用关心,那是不是我也可以这样处理执行时间?

想象一下,如果能这样写,那岂不是很优雅:

try (TimeTracker ignored = new TimeTracker("数据库操作")) {// 业务代码,耗时自动搞定!}

瞬间,代码变得清爽多了!资源自动管理,耗时自动计算,福音嘛这不是!

说干就干,新建一个 TimeTracker类,实现 AutoCloseable,简单鼓捣一番,重点在于,在 close() 中计算耗时,实现全自动化。于是就有了第一版。

当然,这才是刚开始。

Pro: 函数式接口

但是,还能更懒一点吗?当然可以!

不妨试试函数式接口!

比如下面这样:

TimeTracker.track("用户查询", () -> {return userService.findById(123);});

连 try 都不用写了!一行代码搞定性能监控,是不是很牛?这下点题了不是!

什么?你说这明明是3行?

那如果我这样写呢?

TimeTracker.track("操作", () -> riskyMethod());

这下没毛病了吧 😂

如果想要返回值,那也很简单,直接这样写:

String result = TimeTracker.track("简单任务", () -> {    Thread.sleep(1000);return"完成";});

和普通的调用没有区别,毫无心智负担。

Pro Max:异常处理

虽然现在一行就搞定了,但是缺少一个关键的功能,那就是异常处理。

考量一个程序员是否🐂🍺的标准,从来不是他能写出多高大上的代码,而且丰富的开发经验和强大的问题追踪能力。 因为这里怎么能缺少异常处理。

在上面的版本中,都没有涉及异常,因为 .track() 内部把异常消化掉并重新包装成了 RuntimeException

publicstatic <T> track(String operationName, ThrowableSupplier<T> execution){try {return trackThrows(operationName, execution);    } catch (Exception e) {thrownew RuntimeException("执行失败: " + operationName, e);    }}

考虑到不同场景对于异常处理的需求不同,所以还得再额外提供一种模式,允许调用方显式地进行异常处理,把选择权交给用户。

比如下面这样:

try {    TimeTracker.trackThrows("操作", () -> {return riskyMethod(); // 保留原始异常    });catch (SpecificException e) {// 精确处理}

那这样就大功告成了。

完整代码

下面这是完整代码。

各种注释都写在里面,可以说是非常详细了。

包括使用示例,也写在JavaDoc里面,真正做到注释比代码还多。😁

/** * 性能跟踪工具类,用于测量代码执行时间并提供灵活的异常处理机制。 * * <p>主要特性: * <ul> *   <li>精确测量代码执行时间</li> *   <li>支持带返回值和无返回值的方法跟踪</li> *   <li>提供两种异常处理模式</li> *   <li>支持自动资源管理</li> * </ul> * * <h2>使用示例:</h2> * * <h3> try-with-resources 手动跟踪</h3> * <pre>{@code * // 手动管理资源和性能跟踪 * try (TimeTracker tracker = new TimeTracker("数据库操作")) { *     database.connect(); *     database.executeQuery(); * } // 自动关闭,并打印执行时间 * * // 带返回值的try-with-resources * try (TimeTracker tracker = new TimeTracker("复杂计算"); *      Resource resource = acquireResource()) { *     return performComplexCalculation(resource); * } * }</pre> * * <h3>结合静态方法的try-with-resources</h3> * <pre>{@code * try (TimeTracker ignored = TimeTracker.of("网络请求")) { *     httpClient.sendRequest(); *     httpClient.receiveResponse(); * } * }</pre> * * <p>注意:使用try-with-resources可以确保资源正确关闭, * 并自动记录执行时间。</p> * * <h3>lambda自动处理异常</h3> * <pre>{@code * // 无返回值方法 * TimeTracker.track("数据处理", () -> { *     processData(); // 可能抛出异常的方法 * }); * * // 有返回值方法 * String result = TimeTracker.track("查询用户", () -> { *     return userService.findById(123); * }); * }</pre> * * <h3>lambda显式异常处理</h3> * <pre>{@code * try { *     // 允许抛出原始异常 *     String result = TimeTracker.trackThrows("复杂查询", () -> { *         return complexQuery(); // 可能抛出检查异常 *     }); * } catch (SQLException e) { *     // 精确处理特定异常 *     logger.error("数据库查询失败", e); * } * }</pre> * * <h3>lambda嵌套使用</h3> * <pre>{@code * TimeTracker.track("整体流程", () -> { *     // 子任务1 *     TimeTracker.track("数据准备", () -> prepareData()); * *     // 子任务2 *     return TimeTracker.track("数据处理", () -> processData()); * }); * }</pre> * * <p>注意:默认情况下会打印执行时间到控制台。对于生产环境, * 建议根据需要自定义日志记录机制。</p> * * @author [Your Name] * @version 1.0 * @since [版本号] */publicclass TimeTracker implements AutoCloseable {/** 操作名称 */    privatefinal String operationName;/** 开始时间(纳秒) */    privatefinallong startTime;/** 是否启用日志 */    privatefinalboolean logEnabled;/**     * 创建一个新的TimeTracker实例。     *     * @param operationName 要跟踪的操作名称     */publicTimeTracker(String operationName){this(operationName, true);    }/**     * 私有构造函数,用于创建TimeTracker实例。     *     * @param operationName 操作名称     * @param logEnabled 是否启用日志输出     */privateTimeTracker(String operationName, boolean logEnabled){this.operationName = operationName;this.startTime = System.nanoTime();this.logEnabled = logEnabled;if (logEnabled) {            System.out.printf("开始执行: %s%n", operationName);        }    }/**     * 创建一个新的TimeTracker实例的静态工厂方法。     *     * @param operationName 要跟踪的操作名称     * @return 新的TimeTracker实例     */publicstatic TimeTracker of(String operationName){returnnew TimeTracker(operationName);    }/**     * 跟踪带返回值的代码块执行时间,异常会被包装为RuntimeException。     *     * @param operationName 操作名称     * @param execution 要执行的代码块     * @param <T> 返回值类型     * @return 代码块的执行结果     * @throws RuntimeException 如果执行过程中发生异常     */    publicstatic <T> track(String operationName, ThrowableSupplier<T> execution){try {return trackThrows(operationName, execution);        } catch (Exception e) {thrownew RuntimeException("执行失败: " + operationName, e);        }    }/**     * 跟踪带返回值的代码块执行时间,允许抛出异常。     *     * @param operationName 操作名称     * @param execution 要执行的代码块     * @param <T> 返回值类型     * @return 代码块的执行结果     * @throws Exception 如果执行过程中发生异常     */    publicstatic <T> trackThrows(String operationName, ThrowableSupplier<T> execution)throws Exception {try (TimeTracker ignored = new TimeTracker(operationName, true)) {return execution.get();        }    }/**     * 跟踪无返回值的代码块执行时间,异常会被包装为RuntimeException。     *     * @param operationName 操作名称     * @param execution 要执行的代码块     * @throws RuntimeException 如果执行过程中发生异常     */publicstaticvoidtrack(String operationName, ThrowableRunnable execution){try {            trackThrows(operationName, execution);        } catch (Exception e) {thrownew RuntimeException("执行失败: " + operationName, e);        }    }/**     * 跟踪无返回值的代码块执行时间,允许抛出异常。     *     * @param operationName 操作名称     * @param execution 要执行的代码块     * @throws Exception 如果执行过程中发生异常     */publicstaticvoidtrackThrows(String operationName, ThrowableRunnable execution)throws Exception {try (TimeTracker ignored = new TimeTracker(operationName, true)) {            execution.run();        }    }@Overridepublicvoidclose(){if (logEnabled) {// 计算执行时间(转换为毫秒)long timeElapsed = (System.nanoTime() - startTime) / 1_000_000;            System.out.printf("%s 执行完成,耗时: %d ms%n", operationName, timeElapsed);        }    }/**     * 可抛出异常的Supplier函数式接口。     *     * @param <T> 返回值类型     */@FunctionalInterface    publicinterface ThrowableSupplier<T> {/**         * 获取结果。         *         * @return 执行结果         * @throws Exception 如果执行过程中发生错误         */get()throws Exception;    }/**     * 可抛出异常的Runnable函数式接口。     */@FunctionalInterface    publicinterface ThrowableRunnable {/**         * 执行操作。         *         * @throws Exception 如果执行过程中发生错误         */voidrun()throws Exception;    }}

一个DEMO

在JavaDoc里面已经清楚写明了调用示例,这里额外再补充一个Demo类,可能更清晰

import java.io.IOException;publicclass TimeTrackerDemo {publicvoiddemonstrateUsage(){// 1. 使用不抛出检查异常的版本(异常被包装为RuntimeException)        TimeTracker.track("简单任务", () -> {            Thread.sleep(1000);return"完成";        });// 2. 使用可能抛出异常的版本try {            TimeTracker.trackThrows("可能失败的任务", () -> {if (Math.random() < 0.5) {thrownew IOException("模拟IO异常");                }return"成功";            });        } catch (Exception e) {// 处理异常            e.printStackTrace();        }// 3. 嵌套使用示例try {            TimeTracker.trackThrows("复杂流程", () -> {// 子任务1:使用不抛出异常的版本                TimeTracker.track("子任务1", () -> {                    Thread.sleep(500);                });// 子任务2:使用抛出异常的版本return TimeTracker.trackThrows("子任务2", () -> {                    Thread.sleep(500);return"全部完成";                });            });        } catch (Exception e) {// 处理异常            e.printStackTrace();        }// 4. try-with-resources 示例try (TimeTracker tracker = TimeTracker.of("资源管理演示")) {// 模拟资源操作            performResourceIntensiveTask();        }// 5. 多资源管理的try-with-resourcestry (                TimeTracker tracker1 = TimeTracker.of("第一阶段");                TimeTracker tracker2 = TimeTracker.of("第二阶段");// 可以同时管理其他资源                CustomResource resource = acquireResource()        ) {            processResourcesSequentially(resource);        } catch (Exception e) {// 异常处理            e.printStackTrace();        }// 6. 忽略返回值的try-with-resourcestry (TimeTracker ignored = TimeTracker.of("后台任务")) {            performBackgroundTask();        }    }// 辅助方法(仅作示例)privatevoidperformResourceIntensiveTask(){        Thread.sleep(1000);        System.out.println("资源密集型任务完成");    }private CustomResource acquireResource(){returnnew CustomResource();    }privatevoidprocessResourcesSequentially(CustomResource resource){// 处理资源的示例方法        resource.process();    }privatevoidperformBackgroundTask(){// 后台任务示例        System.out.println("执行后台任务");    }// 模拟自定义资源类    privatestaticclass CustomResource implements AutoCloseable {publicvoidprocess(){            System.out.println("处理资源");        }@Overridepublicvoidclose(){            System.out.println("关闭资源");        }    }}

改进建议

当然,这个类还有很大的改进空间,我简单列几个,列位看官可以根据自己的真实场景再逐步进行优化。

  • 集成日志框架,比如Slf4j,支持更灵活的输出方式
  • 添加更多的时间统计维度(最大值、最小值、平均值等)
  • 添加性能指标收集,支持监控数据统计
  • 支持异步操作

革命尚未成功,同志仍需努力。

总结

一点点经验

先来点经验总结,仁者见仁,智者见智。

  • 工具类设计务必要注重实用性和易用性的平衡
  • 工具类只是工具,千万不能在工具类中牵扯业务
  • 异常处理需要考虑实际的真实的使用场景
  • 合理使用语言特性,可以大大简化代码
  • 鲁棒性非常重要

写在最后

写代码这些年,常常要记录些执行时间。起初也是简单,System.currentTimeMillis() 放在前后,相减便知道耗了多少毫秒。后来觉得这样写着繁琐,且容易忘记处理异常,索性就做了这么个工具类。

说来也没什么新奇的,不过是用了Java里的AutoCloseable接口,再配上lambda表达式,让代码看起来干净些。倒是在处理异常时费了点心思,毕竟实际开发中,异常处理往往比主要逻辑还要来得复杂。

回头再看这段代码,倒也不觉得有多少技术含量,但确实解决了实际问题。这大概就是写程序的意思:不是为了写出多么惊世骇俗的代码,而是让原本繁琐的事情变得简单,让使用者觉得舒服。

就像一把称手的菜刀,好就好在切起菜来只觉得顺手,从不会让人去想它多么多么精妙。这个工具类也是这样,它就在那里,不声不响地做着它的事情。

总说要写优雅的代码,但其实代码写到最后,都是平常的。

就像一碗白米饭,好就好在它的本分。

来源:juejin.cn/post/7436784712028815371

-End-

你的「赞」+「在看」,小黑都看得见👇

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-03-27 08:11:35 HTTP/2.0 GET : https://f.mffb.com.cn/a/481712.html
  2. 运行时间 : 0.191524s [ 吞吐率:5.22req/s ] 内存消耗:4,781.28kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=4d2726026b685ca86d00b2864dbb13dc
  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.001157s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001579s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.001679s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000682s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001340s ]
  6. SELECT * FROM `set` [ RunTime:0.000603s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001433s ]
  8. SELECT * FROM `article` WHERE `id` = 481712 LIMIT 1 [ RunTime:0.002108s ]
  9. UPDATE `article` SET `lasttime` = 1774570295 WHERE `id` = 481712 [ RunTime:0.006826s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 65 LIMIT 1 [ RunTime:0.000559s ]
  11. SELECT * FROM `article` WHERE `id` < 481712 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.001032s ]
  12. SELECT * FROM `article` WHERE `id` > 481712 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.001049s ]
  13. SELECT * FROM `article` WHERE `id` < 481712 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.001906s ]
  14. SELECT * FROM `article` WHERE `id` < 481712 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.006551s ]
  15. SELECT * FROM `article` WHERE `id` < 481712 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.002328s ]
0.195287s