Flutter开发进阶之错误信息

Flutter开发进阶之错误信息

在Flutter开发中错误信息通常是由Exception和Error表示,Error表示严重且不可恢复的错误,一般会导致程序直接终止,而Exception可以被显式抛出,一般为代码逻辑错误,根据Flutter的解释说Exception为异常而Error为错误。

本文将通过源码和实际操作来比较Exception和Error的异同。

介绍比对

dart 复制代码
@pragma('flutter:keep-to-string-in-subtypes')
abstract interface class Exception

@pragma('flutter:keep-to-string-in-subtypes')
class Error

@pragma('flutter:keep-to-string-in-subtypes') 是一个特殊的注解(annotation),它用于指导Flutter的Dart编译器在编译时保留某些类型信息。

具体来说,这个注解是为了确保当类型被用作其他类型的子类型时,其字符串表示形式(通常是类型名称)会被保留在生成的代码中。

Exception是一个抽象类,一般需要通过指定的类型去使用,例如

dart 复制代码
class FormatException implements Exception

处理的是字符串类型的异常。
Exception还有

dart 复制代码
@Deprecated("Use UnsupportedError instead")
class IntegerDivisionByZeroException implements Exception, UnsupportedError

现已废弃,开始采用UnsupportedError

对于Error,源码中的注释相对于Exception要严重的多,程序员应该避免其出现在测试以外。

其类型有

dart 复制代码
class AssertionError extends Error

class TypeError extends Error

class ArgumentError extends Error

class RangeError extends ArgumentError

class IndexError extends ArgumentError implements RangeError

class NoSuchMethodError extends Error

@pragma("vm:entry-point")
class UnsupportedError extends Error

class UnimplementedError extends Error implements UnsupportedError

class ConcurrentModificationError extends Error

final class OutOfMemoryError implements Error

final class StackOverflowError implements Error

名称很直白,很容易就知道具体是什么错误。

使用比对

dart 复制代码
    try {
      ///
    } on FormatException {
      ///
    } catch(e, s) {
      ///
    } finally {
      ///
    }

通过try可以执行一些可能抛出异常的方法,可以通过on可以对指定类型的异常进行对应处理,catch会收到对应的错误,无论代码是否异常最后都会执行finally
FormatException还可以自定义类型,比如我们在进行数据请求时就是通过自定义异常类型去处理异常。

可以通过throw const FormatException('xxxxx');主动抛出异常,还可以通过rethrow;进行异常重抛。

异常的收集需要在WidgetsFlutterBinding.ensureInitialized()执行之后。

主动抛出的错误也是可以通过throw来执行,对于Flutter的错误可以通过

dart 复制代码
    FlutterError.onError = (e) {
      FlutterError.presentError(e);
    };

来收集。

对于异步的错误可以通过

dart 复制代码
  PlatformDispatcher.instance.onError = (error, stack) {
    myBackend.sendError(error, stack);
    return true;
  };

来收集,或者通过

dart 复制代码
R? runZonedGuarded<R>(R body(), void onError(Object error, StackTrace stack),
    {Map<Object?, Object?>? zoneValues, ZoneSpecification? zoneSpecification})

来处理。

相关推荐
JieE2125 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
冬奇Lab7 小时前
AI Workflow 定义的四次演进:从 Markdown 到 JS 脚本,再到分布式多 Agent
javascript·人工智能·agent
一颗烂土豆13 小时前
Meshopt 压缩深度解析,为什么它比 Draco 更快
前端·javascript·webgl
kyriewen16 小时前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程
weedsfly18 小时前
迭代器、生成器与异步迭代——让数据“按需流动”的艺术
前端·javascript
假如让我当三天老蒯18 小时前
前端跨域解决方案(学习用)
前端·javascript·面试
铁皮饭盒20 小时前
Bun 哪比 Node.js 快?
javascript·后端
JieE2121 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
candyTong1 天前
RTK 技术原理:一次典型会话里,80% 上下文是怎么省下来的
javascript·后端·架构
_柳青杨1 天前
深入理解 JavaScript 事件循环
前端·javascript