当前位置: 首页 > news >正文

flutter 中各种日志

日志方法对比

输出方式调试模式控制台输出发布模式控制台输出DevTools Logging 视图
print()✅ 显示✅ 显示❌ 不显示
debugPrint()✅ 显示✅ 显示❌ 不显示
stderr.writeln()✅ 显示✅ 显示✅ 显示
dart:developer.log()✅ 显示❌ 不显示✅ 显示

详细说明:

  • print():​在调试模式和发布模式下都会输出到控制台,但不会显示在 DevTools 的 Logging 视图中。​

  • debugPrint():​在调试模式和发布模式下都会输出到控制台,但不会显示在 DevTools 的 Logging 视图中。​

  • stderr.writeln():​在调试模式和发布模式下都会输出到控制台,并且会显示在 DevTools 的 Logging 视图中,适用于输出错误信息。​

  • dart:developer.log():​在调试模式下会输出到控制台,会显示在 DevTools 的 Logging 视图中,适用于生成结构化的日志事件。​

同时输出到控制台和 DevTools 的建议:

要实现日志同时显示在控制台和 DevTools 的 Logging 视图中,建议使用 stderr.writeln()。​这种方法的输出既能在控制台查看,也能在 DevTools 中进行结构化分析。​

如果您希望在调试模式下使用 print()debugPrint(),并在发布模式下使用 stderr.writeln(),可以通过以下方式实现:​

import 'dart:io';void logMessage(String message) {if (kReleaseMode) {stderr.writeln(message); // 发布模式下输出到 stderr} else {print(message); // 调试模式下输出到控制台}
}

在上述代码中,logMessage 函数会根据当前模式选择合适的输出方式。​

使用这种方法,您可以在调试模式下使用 print()debugPrint(),在发布模式下使用 stderr.writeln(),从而实现日志同时显示在控制台和 DevTools 的 Logging 视图中。​

验证debug模式

注意:debug模式 我发现怎么都可以显示在devtools面板中

🔍 性能对比与使用建议

方法性能影响特点与适用场景
print()中等(同步阻塞)简单直接,适用于开发阶段的快速调试。​在生产环境中频繁使用可能导致性能下降。
debugPrint()较低(异步处理)自动分段长文本,防止日志丢失。​适用于输出长文本,开发阶段使用。
developer.log()低(结构化日志)支持日志级别、时间戳等元信息,适用于需要结构化日志的调试和分析阶段。​在生产环境中不会输出到控制台。
stderr.writeln()中等(同步阻塞)将错误信息输出到标准错误流,适用于错误日志的输出。​在生产环境中使用需谨慎,可能影响性能。

设置 debugPrint 为自定义函数(动态控制开关)

bool enableDebugLog = true;void initDebugPrint() {debugPrint = (String? message, {int? wrapWidth}) {if (enableDebugLog && message != null) {print('📘 $message'); // 你可以替换成你自己的逻辑}};
}

使用 Zone 拦截 print(高级玩法)

void main() {runZonedGuarded(() {runApp(MyApp());}, (error, stack) {}, zoneSpecification: ZoneSpecification(print: (self, parent, zone, line) {if (kDebugMode) {parent.print(zone, "📘 $line");}},));
}

http://www.xdnf.cn/news/122023.html

相关文章:

  • Flutter 在全新 Platform 和 UI 线程合并后,出现了什么大坑和变化?
  • 【Qt6 QML Book 基础】07:布局项 —— 锚定布局与动态交互(附完整可运行代码)
  • 使用localStorage的方式存储数据,刷新之后,无用户消息,需要重新登录,,localStorage 与 sessionStorage 的区别
  • 实时操作系统在服务型机器人中的关键作用
  • 小刚说C语言刷题——1317正多边形每个内角的度数?
  • Pikachu靶场-unsafe upfileupload
  • 每日Html 4.24
  • 2025 年 Odoo 安装与部署全攻略
  • 2026届华为海思秋暑期IC实习秋招笔试真题(2025.04.23更新)
  • index.htm 文件是什么:网页开发的入门基础
  • 架构-系统可靠性分析与设计
  • js 对象深拷贝、浅拷贝有哪些方法/设拷贝循环引用报错
  • 从机械应答到智能对话:大模型为呼叫注入智慧新动能
  • AD16如何执行DRC检测
  • 事务详细介绍
  • SVN钩子脚本获取日志中文乱码解决办法
  • Pikachu靶场
  • GIT 使用小记
  • Electron Forge【实战】百度智能云千帆大模型 —— AI聊天
  • nuxt3持久化存储全局变量
  • 【深度学习核心技术解析】从理论到实践的全链路指南
  • 【Python解释器】Pycharm中找不到Python打包工具-解决办法
  • 优化Nginx的下载功能
  • EFISH-SBC-RK3588无人机地面基准站项目
  • Spring 中@Autowired,@Resource,@Inject 注解实现原理
  • 中间系统-SPF计算
  • 如何规避矩阵运营中的限流风险及解决方案
  • 如何测试短信接口
  • Java String对象创建过程
  • 如何借助ETL数据集成工具实现数据一致性?