【鸿蒙性能优化】基于AOP的代码插桩

场景一:统计自定义方法耗时及调用次数。

方案:通过Aspect.addBefore对自定义方法进行执行前插桩记录方法调用前时间、Aspect.addAfter对自定义方法进行执行后插桩记录执行后时间,以统计方法耗时及调用次数。

核心代码:

function addTimePrinter(targetClass: Object, methodName: string, isStatic: boolean) { 
  let count: number = 0 
  let t1 = 0; 
  let t2 = 0; 
  util.Aspect.addBefore(targetClass, methodName, isStatic, () => { 
    t1 = new Date().getTime(); 
  }) 
  util.Aspect.addAfter(targetClass, methodName, isStatic, (instance: Object, ret: number) => { 
 
    count+=1 
    t2 = new Date().getTime(); 
    console.log(methodName+"方法耗时为t2 - t1 = " + (t2 - t1).toString()); 
    console.log(methodName+"方法调用次数为count = " + count); 
    return ret; 
  }) 
} 
 
function doSomeWork(time: number) { 
  let start = Date.now() 
  while (Date.now()-start<time){ 
    continue 
  } 
  console.log('延时 '+time+"ms"); 
} 
 
export class Test { 
  delay1000() { 
    doSomeWork(1000);  // 1000ms的任务 
  } 
  static delay2000() { 
    doSomeWork(2000);  // 1000ms的任务 
  } 
} 
addTimePrinter(Test,'delay1000',false) 
addTimePrinter(Test,'delay2000',true)

场景二:应用间跳转–获取目标应用包名。

方案:在EntryAbility的onCreate方法中对UIAbilityContext类的startAbility方法进行插桩,以获取Want参数的bundleName属性。此场景addAfter、addBefore都可完成,本例通过addAfter实现。

核心代码:

由于UIAbilityContext是系统提供的类且没有导出,无法直接import,因此可以通过EntryAbility的context成员(该成员是从UI

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值