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})

来处理。

相关推荐
浮生望1 天前
JS字符串与回文算法:从包装类到双指针的面试进阶之路
javascript·算法
疯狂的魔鬼1 天前
一套 Schema 驱动四视图:记 useCrudSchemas 的设计与实践
前端·javascript·typescript
weedsfly1 天前
栈和堆:JavaScript 内存的“旅馆”和“仓库”
前端·javascript·面试
半个落月1 天前
JavaScript 字符串面试题:反转、回文与双指针
javascript
独泪了无痕1 天前
Lodash-JavaScript的实用工具库
前端·javascript
有趣的老凌1 天前
用 Vibe Coding 搭了一个完整小程序「一定能成」
前端·javascript·后端
山河木马2 天前
矩阵专题3-怎么创建投影矩阵(uProjectionMatrix)
javascript·webgl·计算机图形学
泯泷2 天前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
泯泷2 天前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
朦胧之2 天前
页面白屏卡住排查方法
前端·javascript