原文地址:http://halohoop.com/2017/06/05/cookies-kotlin-trick-001/
好的文章有时候不在于鸿篇巨制,而在于一目了然,有时候这种快餐小技巧更能帮助人,没有铺垫没有客套,直戳掌握知识的要害。所以从这篇开始会不间断的记录一些小技巧,文章已[饼干]开头的都是一篇短文。
一些重复的工作,比如说我们在性能调优的时候经常用到的Trace,以下是一个实例:
Java:
Trace.beginSection(sectionName);
doSomeCalculation();
Trace.endSection();
问题:
如果在每个地方都加入Trace.beginSection(sectionName)和Trace.endSection()会疯掉的,搞不好还忘记加Trace.endSection()。
When it comes to Kotlin:
inline fun trace(sectionName: String, body: () -> Unit) {
Trace.beginSection(sectionName)
try {
body()
} finally {
Trace.endSection()
}
}
//and use it
trace("foo") {
doSomeCalculation()
}
这样我们就可以把Trace.beginSection(sectionName)和Trace.endSection()省略了。
甚至你还可以有返回值:
inline fun <T> trace(sectionName: String, body: () -> T): T {
Trace.beginSection(sectionName)
try {
return body()
} finally {
Trace.endSection()
}
}
//and use it
val result = trace("foo") {
doSomeCalculation()
}
总结
实际上这种方式是方法拓展,lambda带给我们的额便利,同样的技巧,相信你能应用到Trace以外更多的地方,相信你能接触到更好的用法。
本文介绍了一种使用Kotlin简化性能调优中Trace记录的方法。通过定义内联函数实现自动开始和结束Trace记录,避免遗漏并提高代码整洁度。

被折叠的 条评论
为什么被折叠?



