HarmonyOS NEXT应用开发之异常处理案例_import { logger } from ‘@ohos base‘;(3)

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!


img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上鸿蒙开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以戳这里获取

    domain: hiAppEvent.domain.OS,
    names: [hiAppEvent.event.APP_CRASH, hiAppEvent.event.APP_FREEZE]
  }
],
// TODO:知识点:获取事件组信息。开发者可以自行实现订阅实时回调函数,以便对订阅获取到的事件数据进行自定义处理
onReceive: async (domain: string, appEventGroups: Array<hiAppEvent.AppEventGroup>) => {
  logger.info(TAG, `HiAppEvent onReceive: domain=${domain}`);
  // 获取事件组信息,与ApplicationException文件中的@StorageLink('faultMessage') faultMessage进行双向数据绑定
  AppStorage.setOrCreate('appEventGroups', appEventGroups);
}

});
}


3. @StorageLink(‘appEventGroups’)接收订阅事件函数传递的事件组信息,调用getFaultMessage函数对信息进行处理,将处理后的信息通过 this.faultDataSource.pushData(message) 添加到懒加载数据源中,并通过this.faultDataSource.persistenceStorage()执行持久化存储,最后通过使用LazyForEach将数据信息加载到页面上。 具体源码参考[ApplicationException.ets]( )



@Component
struct FaultArea {
// 懒加载数据源
@State faultDataSource: FaultDataSource = new FaultDataSource();
// 双向数据绑定懒加载数据源的数组长度
@StorageLink(‘faultDataSourceLength’) faultDataSourceLength: number = 0;
// 双向数据绑定事件组,与AppStorage.setOrCreate进行绑定,此变量发生变化触发getFaultMessage函数
@StorageLink(‘appEventGroups’) @Watch(‘getFaultMessage’) appEventGroups: Array<hiAppEvent.AppEventGroup> = [];
@Consume eventIndex: number;

async aboutToAppear() {
logger.info(TAG, aboutToAppear start);
// 获取Preferences实例
PreferencesManager.getPreferences(this.faultDataSource);
}

// 获取应用异常信息
async getFaultMessage() {
logger.info(TAG, getAppEventGroups start);
if (this.appEventGroups && this.appEventGroups.length > 0) {
// 遍历事件组
this.appEventGroups.forEach((eventGroup: hiAppEvent.AppEventGroup) => {
// 遍历事件对象集合
eventGroup.appEventInfos.forEach(async (eventInfo: hiAppEvent.AppEventInfo) => {
let message: string = ‘’;
message += HiAppEvent eventInfo.domain=${eventInfo.domain}\n // 事件领域
+ HiAppEvent eventInfo.name=${eventInfo.name}\n // 事件名称
+ HiAppEvent eventInfo.eventType=${eventInfo.eventType}\n // 事件名称
+ HiAppEvent eventInfo.params.time=${eventInfo.params['time']}\n // 事件发生的时间
+ HiAppEvent eventInfo.params.crash_type=${eventInfo.params['crash_type']}\n
+ HiAppEvent eventInfo.params.foreground=${eventInfo.params['foreground']}\n
+ HiAppEvent eventInfo.params.bundle_version=${eventInfo.params['bundle_version']}\n
+ HiAppEvent eventInfo.params.bundle_name=${eventInfo.params['bundle_name']}\n
+ HiAppEvent eventInfo.params.exception=${JSON.stringify(eventInfo.params['exception'])}\n
+ HiAppEvent eventInfo.params.hilog.size=${eventInfo.params['hilog'].length}\n;
// TODO:知识点:将异常信息存储到数组faultMessage当中
this.faultDataSource.pushData(message);
})
})
}
// TODO:知识点:持久化存储异常信息集合
this.faultDataSource.persistenceStorage();
}

build() {
List() {
// 添加判断,如果异常信息集合的信息条数大于0,遍历异常信息
if (this.faultDataSourceLength > 0) {
// 性能:动态加载数据场景可以使用LazyForEach遍历数据。https://developer.harmonyos.com/cn/docs/documentation/doc-guides-V3/arkts-rendering-control-lazyforeach-0000001524417213-V3
LazyForEach(this.faultDataSource, (message: string) => {
ListItem() {
Text(message)
.textAlign(TextAlign.Start)
}
}, (item: string) => item)
} else {
ListItem() {
// 根据被点击事件的下标响应指定的信息
Text(this.eventIndex === 0 ? $r(‘app.string.crash_event_message’) :
(this.eventIndex === 1 ? $r(‘app.string.freeze_event_message’) :
(this.faultSign ? $r(‘app.string.data_delay_toast’) :
KaTeX parse error: Expected 'EOF', got '}' at position 39: …e')))) }̲ } } …r(‘app.string.ohos_id_corner_radius_default_m’))
.padding($r(‘app.string.ohos_id_card_padding_start’))
}
}


4. 以上代码中有引用懒加载数据类和持久化存储类,源码可参考[DataSource.ets]( )和 [PreferencesManager.ets]( )。



// DataSource.ets
export class FaultDataSource extends BasicDataSource {
// 懒加载数据
private faultMessage: Array = [];

// TODO:知识点:获取懒加载数据源的数据长度
totalCount(): number {
return this.faultMessage.length;
}

// 获取指定数据项
getData(index: number): string {
return this.faultMessage[index];
}

// TODO:知识点:存储数据到懒加载数据源中
pushData(data: string): void {
this.faultMessage.push(data);
// 在数组头部添加数据
this.notifyDataAdd(this.faultMessage.length - 1);
AppStorage.setOrCreate(‘faultDataSourceLength’, this.totalCount());
}

// TODO:知识点:持久化存储异常信息集合
persistenceStorage(): void {
PreferencesManager.putFaultMessage(this.faultMessage);
}
}

// PreferencesManager.ets
/**

  • 存储数据异常信息
  • @param faultMessage 异常信息集合
    */
    public static putFaultMessage(faultMessage: Array) {
    logger.info(putMessage start);
    try {
    // TODO:知识点:通过 dataPreferencesManager.put方法存储数据
    dataPreferencesManager.put(‘faultMessage’, JSON.stringify(faultMessage), async (err: BusinessError) => {
    if (err) {
    logger.error(“Failed to put value of ‘faultMessage’. code =” + err.code + “, message =” + err.message);
    return;
    }
    logger.info(‘Succeeded in putting value of faultMessage.’);
    dataPreferencesManager.flush();
    })
    } catch (err) {
    let code = (err as BusinessError).code;
    let message = (err as BusinessError).message;
    logger.error(“Failed to put value of ‘catch err’. code =” + err.code + “, message =” + err.message);
    }
    }

/**

  • 获取数据异常信息
  • @param faultMessage 异常信息集合
    */
    public static getFaultMessage(faultDataSource:FaultDataSource) {
    logger.info(getFaultMessage start);
    try {
    // TODO:知识点:通过dataPreferencesManager.get方法获取异常信息数据
    let promise = dataPreferencesManager.get(‘faultMessage’, []);
    promise.then(async (data: dataPreferences.ValueType) => {
    if (typeof data === ‘string’) {
    let faultData: Array = JSON.parse(data);
    // 将异常数据添加到懒加载数据源中
    faultData.forEach((item: string) => {
    faultDataSource.pushData(item);
    })
    // 双向数据绑定懒加载数据源长度,更新数据源长度
    AppStorage.setOrCreate(‘faultDataSourceLength’,faultDataSource.totalCount())
    logger.info(‘Succeeded in getting value of faultMessage.’);
    }
    })
    } catch (err) {
    logger.error(“Failed to get value of ‘catch err’. code =” + err.code + “, message =” + err.message);
    }
    }

#### 高性能知识点


本示例使用了[LazyForEach]( )进行数据懒加载,将叠加获取到的应用异常信息进行渲染。


#### 工程结构&模块类型



aplicationexception // har类型
|—model
| |—DataSource.ets // 模型层-懒加载数据源
| |—EventSubscription.ets // 数据模型层-订阅应用事件
| |—MockData.ets // 数据模型层-模拟数据
| |—PreferencesManager.ets // 数据模型层-持久化存储
|—view
| |—PreferencesManager.ets // 视图层-应用异常页面


#### 模块依赖


本实例依赖common模块来实现[日志]( )的打印、[资源]( )的调用以及[公共组件FunctionDescription]( )的引用。


#### 参考资料


[应用事件打点HiAppEvent]( ) [数据懒加载LazyForEach]( )


**为了能让大家更好的学习鸿蒙(HarmonyOS NEXT)开发技术,这边特意整理了《鸿蒙开发学习手册》(共计890页),希望对大家有所帮助:[`https://qr21.cn/FV7h05`]( )**


#### 《鸿蒙开发学习手册》:[`https://qr21.cn/FV7h05`]( )


![img](https://img-blog.csdnimg.cn/img_convert/77cf0e3b20de98a28e2fafddd0aca3ef.png)
![img](https://img-blog.csdnimg.cn/img_convert/b1514539f99888919b0eeeeb2e0bf78c.png)

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化的资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618636735)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

]

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化的资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618636735)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值