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

来处理。

相关推荐
Live000002 小时前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉2 小时前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化
忆江南2 小时前
iOS 深度解析
flutter·ios
球球pick小樱花3 小时前
游戏官网前端工具库:海内外案例解析
前端·javascript·css
没有故事的Zhang同学3 小时前
05-主题|事件响应者链@iOS-应用场景与进阶实践
ios
喝水的长颈鹿3 小时前
【大白话前端 02】网页从解析到绘制的全流程
前端·javascript
明君879973 小时前
Flutter 实现 AI 聊天页面 —— 记一次 Markdown 数学公式显示的踩坑之旅
前端·flutter
用户14536981458783 小时前
VersionCheck.js - 让前端版本更新变得简单优雅
前端·javascript
codingWhat3 小时前
整理「祖传」代码,就是在开发脚手架?
前端·javascript·node.js
码路飞3 小时前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python