欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

Android

當(dāng)前位置:主頁 > 軟件編程 > Android >

Flutter里面錯誤捕獲的正確方法

來源:本站原創(chuàng)|時間:2020-01-10|欄目:Android|點擊: 次

背景

我們知道,在軟件開發(fā)過程中,錯誤和異常總是在所難免。

不管是客戶端的邏輯錯誤導(dǎo)致的,還是服務(wù)器的數(shù)據(jù)問題導(dǎo)致的,只要出現(xiàn)了異常,我們都需要一個機(jī)制來通知我們?nèi)ヌ幚怼?/p>

在 APP 的開發(fā)過程中,我們通過一些第三方的平臺,比如 Fabric、Bugly 等可以實現(xiàn)異常的日志上報。

Flutter 也有一些第三方的平臺,比如 Sentry 可以實現(xiàn)異常的日志上報。

但是為了更加通用一些,本篇不具體講解配合某個第三方平臺的異常日志捕獲,我們會告知大家如何在 Flutter 里面捕獲異常。

至于具體的上報途徑,不管是上報到自家的后臺服務(wù)器,還是通過第三方的 SDK API 接口進(jìn)行異常上報,都是可以的。

Demo 初始狀態(tài)

首先我們新建 Flutter 項目,修改 main.dart 代碼如下:

import 'package:flutter/material.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
 // This widget is the root of your application.
 @override
 Widget build(BuildContext context) {
  return MaterialApp(
   home: Scaffold(
    appBar: AppBar(title: Text('Flutter Crash Capture'),),
    body: MyHomePage(),
   ),
  );
 }
}

class MyHomePage extends StatelessWidget {
 @override
 Widget build(BuildContext context) {
  return Container();
 }
}

效果如下:

捕獲錯誤

我們修改 MyHomePage,添加一個 List 然后進(jìn)行越界訪問,改動部分代碼如下:

class MyHomePage extends StatelessWidget {
 @override
 Widget build(BuildContext context) {
  List<String> numList = ['1', '2'];
  print(numList[6]);
  return Container();
 }
}

可以看到控制臺報錯如下:

flutter: ══╡ EXCEPTION CAUGHT BY WIDGETS LIBRARY ╞═══════════════════════════════════════════════════════════
flutter: The following RangeError was thrown building MyHomePage(dirty):
flutter: RangeError (index): Invalid value: Not in range 0..1, inclusive: 6

當(dāng)然這些錯誤信息在界面上也有顯示(debug 模式)。

那么我們?nèi)绾尾东@呢?

其實很簡單,有個通用模板,模板為:

import 'dart:async';

import 'package:flutter/material.dart';

Future<Null> main() async {
 FlutterError.onError = (FlutterErrorDetails details) async {
  Zone.current.handleUncaughtError(details.exception, details.stack);
 };

 runZoned<Future<void>>(() async {
  runApp(MyApp());
 }, onError: (error, stackTrace) async {
  await _reportError(error, stackTrace);
 });
}

Future<Null> _reportError(dynamic error, dynamic stackTrace) async {
 // TODO
}

在 TODO 里面就可以執(zhí)行埋點上報操作或者其他處理了。

完整例子如下:

import 'dart:async';

import 'package:flutter/material.dart';

Future<Null> main() async {
 FlutterError.onError = (FlutterErrorDetails details) async {
  Zone.current.handleUncaughtError(details.exception, details.stack);
 };

 runZoned<Future<void>>(() async {
  runApp(MyApp());
 }, onError: (error, stackTrace) async {
  await _reportError(error, stackTrace);
 });
}

Future<Null> _reportError(dynamic error, dynamic stackTrace) async {
 print('catch error='+error);
}

class MyApp extends StatelessWidget {
 // This widget is the root of your application.
 @override
 Widget build(BuildContext context) {
  return MaterialApp(
   home: Scaffold(
    appBar: AppBar(title: Text('Flutter Crash Capture'),),
    body: MyHomePage(),
   ),
  );
 }
}

class MyHomePage extends StatelessWidget {
 @override
 Widget build(BuildContext context) {
  List<String> numList = ['1', '2'];
  print(numList[6]);
  return Container();
 }
}

運(yùn)行可以看到控制臺捕獲到錯誤如下:

flutter: catch error=RangeError (index): Invalid value: Not in range 0..1, inclusive: 6

assert 妙用

我們知道,一般錯誤上報都是在打包發(fā)布到市場后才需要。

平時調(diào)試的時候如果遇到錯誤,我們是會定位問題并修復(fù)的。

因此在 debug 模式下,我們不希望上報錯誤,而是希望直接打印到控制臺。

那么,這個時候就需要一種方式來區(qū)分現(xiàn)在是 debug 模式還是 release 模式,怎么區(qū)分呢?

這個時候就需要用到 assert 了。

bool get isInDebugMode {
 // Assume you're in production mode.
 bool inDebugMode = false;

 // Assert expressions are only evaluated during development. They are ignored
 // in production. Therefore, this code only sets `inDebugMode` to true
 // in a development environment.
 assert(inDebugMode = true);

 return inDebugMode;
}

從注釋也可以知道,assert 表達(dá)式只在開發(fā)環(huán)境下會起作用,在生產(chǎn)環(huán)境下會被忽略。

因此利用這一個,我們就可以實現(xiàn)我們的需求。

上面的結(jié)論要驗證也很簡單,我們就不演示了。

完整模板

import 'dart:async';

import 'package:flutter/material.dart';

Future<Null> main() async {
 FlutterError.onError = (FlutterErrorDetails details) async {
  if (isInDebugMode) {
   FlutterError.dumpErrorToConsole(details);
  } else {
   Zone.current.handleUncaughtError(details.exception, details.stack);
  }
 };

 runZoned<Future<void>>(() async {
  runApp(MyApp());
 }, onError: (error, stackTrace) async {
  await _reportError(error, stackTrace);
 });
}

Future<Null> _reportError(dynamic error, dynamic stackTrace) async {
 // TODO
}

bool get isInDebugMode {
 // Assume you're in production mode.
 bool inDebugMode = false;

 // Assert expressions are only evaluated during development. They are ignored
 // in production. Therefore, this code only sets `inDebugMode` to true
 // in a development environment.
 assert(inDebugMode = true);

 return inDebugMode;
}

debug 模式下,直接將錯誤打印到控制臺,方便定位問題。

release 模式下,將錯誤信息收集起來,上傳到服務(wù)器。

參考鏈接:

Report errors to a service

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對我們的支持。

上一篇:Android BSearchEdit 搜索結(jié)果選擇框的實例代碼

欄    目:Android

下一篇:Flutter 滾動監(jiān)聽及實戰(zhàn)appBar滾動漸變的實現(xiàn)

本文標(biāo)題:Flutter里面錯誤捕獲的正確方法

本文地址:http://mengdiqiu.com.cn/a1/Android/9165.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有