当前位置: 首页 > wzjs >正文

云南网站推广的目的旅行社网站建设方案论文

云南网站推广的目的,旅行社网站建设方案论文,域名服务器上存放着internet主机的,谷歌seo零基础教程【HarmonyOS Next】鸿蒙应用崩溃处理思路详解 一、崩溃问题发现后定位 1. 崩溃现象: 常见的崩溃问题表现为,应用操作后白屏闪退,或者应用显示无响应卡死。 2.定位问题: 发现崩溃后,我们首先需要了解复现步骤&#x…

【HarmonyOS Next】鸿蒙应用崩溃处理思路详解

一、崩溃问题发现后定位

1. 崩溃现象:
常见的崩溃问题表现为,应用操作后白屏闪退,或者应用显示无响应卡死。

2.定位问题:
发现崩溃后,我们首先需要了解复现步骤,精确定位复现步骤。因为提供复现步骤得人,可能是用户和测试,非开发人员,其中的步骤并非最短路径。

3.排查问题点
根据复现步骤,我们需要查看日志表现,鸿蒙的DevEco IDE提供了日志看板,根据HiLog和FaultLog,我们可以初步区分崩溃问题的类型。
在这里插入图片描述
根据日志看板的FaultLog,可以查看崩溃输出的

  1. JS Crash,一般是ArkTS原生逻辑的崩溃
  2. CppCrash,一般是NDK,C层的崩溃

JS Crash
点击进入JS Crash中,可以查看到崩溃信息,以下几种类型的错误:
在这里插入图片描述
可以根据JS Crash提示的错误行数,直接点击跳转到错误代码处,根据提示检查和修复问题。

Device info:xxx
Build info:xxx-xxx x.x.x.xxx(xxxx)
Fingerprint:a370fceb59011d96e41e97bda139b1851c911012ab8c386d1a2d63986d6d226d
Module name:com.xxx.xxX
Version:1.0.0
Versioncode:1000000
PreInstalled:No
Foreground:Yes
Pid:39185Uid:20020145
Reason:TypeError
Error name:TypeError
Error message:Cannot read property needRenderTranslate of undefined
Stacktrace:Cannot get SourceMap info, dump raw stack:at anonymous (entry/src/main/ets/pages/Index.ts:49:49)

在这里插入图片描述

this.translationUpY = (this,multiCardsNum >= 1)? sceneContainerSessionListlthis.multiCardsNum -1].needRenderTranslate.translateY :0
this.translationDownY = (this.multiCardsNum >= 2)? sceneContainerSessionList[this.multiCardsNum -
2].needRenderTranslate.translateY :0;

CppCrash
根据日志提示,检查是否有以下错误情况:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

AppFreeze
一般是由于耗时操作,导致堵塞主线程。此时用户操作时,会触发无响应。一般分为以下三种情况,超时时间一般在6s左右。
在这里插入图片描述

内存泄漏
这种问题排查起来是最麻烦的,所以保持良好的代码编程规范,不需要的对象该释放释放,不用的句柄也需要释放。

一般碰到内存泄漏,根据提供的复现步骤,很多情况下是非必现。(如果是必现,那最好了,修复该问题会很快。)我们需要操作复现步骤,使用鸿蒙DevEco IDE的ProFiler工具:
在这里插入图片描述
检测应用操作时的内存使用情况。
在这里插入图片描述

二、问题解决,检查类似错误情况一起修复

1.根据章节一问题定位清楚后,根据错误具体情况,思考修复方案

2.根据问题情况,检查其他代码是否有同类问题,一起修复后验证。

3.根据官网提供的材料进行学习,编码过程中进行规范和排查:
在这里插入图片描述

性能优化举例:
业务场景是:点击跳转下一页,直接加载Web页面。这是大多数三方应用的实现方式,其实应该在后台创建一个ArkWeb组件来预先启动用于渲染的Web渲染进程。这样跳转到web页面的时间就不会那么长:

// 创建NodeController
// common.ets
import { UIContext } from '@kit.ArkUI';
import { webview } from '@kit.ArkWeb';
import { NodeController, BuilderNode, Size, FrameNode } from '@kit.ArkUI';// @Builder中为动态组件的具体组件内容
// Data为入参封装类
class Data {url: string = 'https://www.example.com';controller: WebviewController = new webview.WebviewController();
}
function webBuilder(data: Data) {Column() {Web({ src: data.url, controller: data.controller }).domStorageAccess(true).zoomAccess(true).fileAccess(true).mixedMode(MixedMode.All).width('100%').height('100%').onPageEnd((event) => {// 输出Web页面加载完成时间console.info(`load page end time: ${Date.now()}`);})}
}let wrap = wrapBuilder<Data[]>(webBuilder);// 用于控制和反馈对应的NodeContainer上的节点的行为,需要与NodeContainer一起使用
export class MyNodeController extends NodeController {private rootnode: BuilderNode<Data[]> | null = null;private root: FrameNode | null = null;private rootWebviewController: webview.WebviewController | null = null;// 必须要重写的方法,用于构建节点数、返回节点挂载在对应NodeContainer中// 在对应NodeContainer创建的时候调用、或者通过rebuild方法调用刷新makeNode(uiContext: UIContext): FrameNode | null {console.info(' uicontext is undefined : ' + (uiContext === undefined));if (this.rootnode != null) {const parent = this.rootnode.getFrameNode()?.getParent();if (parent) {console.info(JSON.stringify(parent.getInspectorInfo()));parent.removeChild(this.rootnode.getFrameNode());this.root = null;}this.root = new FrameNode(uiContext);this.root.appendChild(this.rootnode.getFrameNode());// 返回FrameNode节点return this.root;}// 返回null控制动态组件脱离绑定节点return null;}// 当布局大小发生变化时进行回调aboutToResize(size: Size) {console.info('aboutToResize width : ' + size.width + ' height : ' + size.height);}// 当controller对应的NodeContainer在Appear的时候进行回调aboutToAppear() {console.info('aboutToAppear');}// 当controller对应的NodeContainer在Disappear的时候进行回调aboutToDisappear() {console.info('aboutToDisappear');}// 此函数为自定义函数,可作为初始化函数使用// 通过UIContext初始化BuilderNode,再通过BuilderNode中的build接口初始化@Builder中的内容initWeb(url: string, uiContext: UIContext, control: WebviewController) {if (this.rootnode != null) {return;}// 绑定预创建的WebviewControllerthis.rootWebviewController = control;// 创建节点,需要uiContextthis.rootnode = new BuilderNode(uiContext);// 创建动态Web组件this.rootnode.build(wrap, { url: url, controller: control });}// 此函数为自定义函数,可作为初始化函数使用loadUrl(url: string) {if (this.rootWebviewController !== null) {// 复用预创建组件,重新加载urlthis.rootWebviewController.loadUrl(url);}}
}// 创建Map保存所需要的NodeController
let NodeMap: Map<string, MyNodeController | undefined> = new Map();
// 创建Map保存所需要的WebViewController
let controllerMap: Map<string, WebviewController | undefined> = new Map();// 初始化需要UIContext 需在Ability获取
export const createNWeb = (url: string, uiContext: UIContext) => {// 创建NodeControllerlet baseNode = new MyNodeController();let controller = new webview.WebviewController();// 初始化自定义web组件baseNode.initWeb(url, uiContext, controller);controllerMap.set(url, controller);NodeMap.set(url, baseNode);
};// 自定义获取NodeController接口
export const getNWeb = (url: string): MyNodeController | undefined => {// 加载新的Url时,建议复用预创建的Web组件if (!NodeMap.get(url) && NodeMap.get('about://blank')) {// 获取预创建的Web组件let webNode = NodeMap.get('about://blank') as MyNodeController;// 重新加载urlwebNode.loadUrl(url);return webNode;}return NodeMap.get(url);
};

三、思考如何避免问题再次发生,复盘

1.保持好的开发习惯创建踩坑文档,避免自己第二次再发生该问题

2.根据错误情况,分析是否为自己代码逻辑问题,逻辑bug不可避免,只能从开发经验和code review中尽量避免

3.代码容错分支问题,只保证了主流程,未考虑代码错误分支的覆盖情况。这种情况,需要自己吸取教训,避免再次发生。

4.使用检测工具对代码进行扫描,提前规避一些问题:
在这里插入图片描述
5.使用IDE提供的AppAnglyzer生成应用检测报告。根据报告提示,进行修改:
在这里插入图片描述
6.使用鸿蒙提供的DevEco Testing工具,进行稳定性和功耗等测试:
在这里插入图片描述


文章转载自:

http://U6d5N5Ek.gnnrf.cn
http://it0QQpoU.gnnrf.cn
http://eF5aw62J.gnnrf.cn
http://P7cmU0wo.gnnrf.cn
http://xIkdpIMm.gnnrf.cn
http://LRDcbNBn.gnnrf.cn
http://SaGv7TBG.gnnrf.cn
http://tzEorsUk.gnnrf.cn
http://dVeCmpz1.gnnrf.cn
http://Fi3fii1j.gnnrf.cn
http://iiKjfJ6E.gnnrf.cn
http://O0Tcpvp4.gnnrf.cn
http://0gC2NIy5.gnnrf.cn
http://W5vSSofx.gnnrf.cn
http://eu4fqQfG.gnnrf.cn
http://WitEDZVM.gnnrf.cn
http://wU1aMCqG.gnnrf.cn
http://gtOoG8HE.gnnrf.cn
http://pFD4cTJT.gnnrf.cn
http://sabR8Dox.gnnrf.cn
http://jbPskmGM.gnnrf.cn
http://SIr1Fx1l.gnnrf.cn
http://yuzrKqvG.gnnrf.cn
http://1CLZi7xw.gnnrf.cn
http://JLoj2Oyl.gnnrf.cn
http://yLzOdWC1.gnnrf.cn
http://Tx3Eg2nn.gnnrf.cn
http://TCftlqaw.gnnrf.cn
http://aohS4Qs5.gnnrf.cn
http://WVMW5bSm.gnnrf.cn
http://www.dtcms.com/wzjs/656850.html

相关文章:

  • 怎样提高网站权重郑州博文it培训 网站开发 平面
  • 榆林网站seo圣都家居装饰有限公司
  • 做口腔科网站石狮网站建设费用
  • 企业门户网站建设与发展住建局查询系统
  • 如何做公众号影视网站wordpress 菜单栏插件
  • 湖北住房和城乡建设厅网站网站访问量统计代码怎么做
  • 做英文小说网站店铺设计图片
  • 成都建站培训佛山网站优化搜索
  • seo优化网站多少钱简述什么叫市场营销
  • 沈阳网站开发工程师招聘网xml网站地图格式
  • 赤峰网站制作公司网页设计制作公司价格便宜
  • 二手书籍交易网站开发方式做网站网页维护手机App开发
  • 建设网站方面的知识论坛推广方案
  • 建网站哪家好网站怎么做json数据
  • 石家庄网站制作机构wordpress 密码明文
  • 聊城做网站的公司流程商标备案查询官网
  • 湘潭建网站外贸没有公司 如何做企业网站
  • 门户网站域名是什么意思郑州建站网站的公司
  • 高端网站设计多少钱大气物流网站源码
  • 南京做网站工作室wordpress适应大数据
  • 4399游戏盒下载官方网站wordpress google authenticator
  • 朝阳网站建设公司电话intitlt 山西大同网站建设
  • 服装网站模板免费下载建设功能网站价格
  • 文昌网站 做炸饺子关于集团网站建设申请
  • 常用的app开发制作网站404页面优化
  • 明星网站怎么设计策划营销推广方案
  • 怎么做有个捐款的网站旅游推广赚佣金哪个平台好
  • 手机制作网站教程驾考学时在哪个网站做
  • 外贸网站建设步骤北京高端网站建设公司浩森宇特
  • 图片手机网站模板昆明网站开发公司哪家好