热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

android的编译版本是否直接影响性能?

最近开发的时候,需要使用到二维码扫描功能,于是本着程序猿的“分享精神”,从github上弄了个zxingdemo,demo扫码速度可以,我很满意,于是心怀感恩之心地将其引入到我的程序中。

最近开发的时候,需要使用到二维码扫描功能,于是本着程序猿的“分享精神”,从github上弄了个zxingdemo,demo扫码速度可以,我很满意,于是心怀感恩之心地将其引入到我的程序中。
但运行起来,发现的我的程序扫码速度慢得可以,排除了各项差异后,还是没有改善。于是我去追踪运行时间,就在DecodeHandler中的decode,发现自己程序的耗时远多于网上那个demo。
最后实在无计可施,我在想该不会是编译版本引起的运行速率差异吧。果然将编译版本更改过后(网上的demo编译版本为23.0.3,我的程序的版本是25.0.0),解码速度快了一大截,使用起来也完全符合预期了。
以下是降低了编译版本后的log信息:

1
2
3
4
5
6
7
8
9
10
11
12
07-14 09:55:46.687 32062-32393/com.lkl.card.value D/DecodeHandler: handleMessage: decode

07-14 09:55:46.693 32062-32393/com.lkl.card.value D/DecodeHandler: decode size:1280,720

07-14 09:55:46.693 32062-32393/com.lkl.card.value D/DecodeHandler: decode data length is 1382400

07-14 09:55:46.762 32062-32393/com.lkl.card.value D/DecodeHandler: 第 1 次事件间隔为:41

07-14 09:55:46.762 32062-32393/com.lkl.card.value D/DecodeHandler: 第 2 次事件间隔为:27

07-14 09:55:46.771 32062-32062/com.lkl.card.value D/CaptureActivityHandler: handleMessage: decode_failed

07-14 09:55:46.954 32062-32393/com.lkl.card.value D/DecodeHandler: handleMessage: decode

07-14 09:55:46.961 32062-32393/com.lkl.card.value D/DecodeHandler: decode size:1280,720

07-14 09:55:46.961 32062-32393/com.lkl.card.value D/DecodeHandler: decode data length is 1382400

07-14 09:55:47.064 32062-32393/com.lkl.card.value D/DecodeHandler: 第 1 次事件间隔为:74

07-14 09:55:47.064 32062-32393/com.lkl.card.value D/DecodeHandler: 第 2 次事件间隔为:29

07-14 09:55:47.070 32062-32062/com.lkl.card.value D/CaptureActivityHandler: handleMessage: decode_failed

以下是25.0.0下的log信息:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
07-14 10:25:41.374 32399-32649/com.lkl.valuecard D/DecodeHandler: handleMessage: decode

07-14 10:25:41.386 32399-32649/com.lkl.valuecard D/DecodeHandler: decode size:1280,720

07-14 10:25:41.387 32399-32649/com.lkl.valuecard D/DecodeHandler: decode data length is 1382400

07-14 10:25:43.419 32399-32649/com.lkl.valuecard D/DecodeHandler: 第 1 次事件间隔为:1385

07-14 10:25:43.419 32399-32649/com.lkl.valuecard D/DecodeHandler: 第 2 次事件间隔为:646

07-14 10:25:43.428 32399-32399/com.lkl.valuecard D/CaptureActivityHandler: handleMessage: decode_failed

07-14 10:25:43.591 32399-32649/com.lkl.valuecard D/DecodeHandler: handleMessage: decode

07-14 10:25:43.598 32399-32649/com.lkl.valuecard D/DecodeHandler: decode size:1280,720

07-14 10:25:43.598 32399-32649/com.lkl.valuecard D/DecodeHandler: decode data length is 1382400

07-14 10:25:45.373 32399-32649/com.lkl.valuecard D/DecodeHandler: 第 1 次事件间隔为:1214

07-14 10:25:45.373 32399-32649/com.lkl.valuecard D/DecodeHandler: 第 2 次事件间隔为:561

07-14 10:25:45.391 32399-32399/com.lkl.valuecard D/CaptureActivityHandler: handleMessage: decode_failed

07-14 10:25:45.424 32399-32649/com.lkl.valuecard D/DecodeHandler: handleMessage: decode

07-14 10:25:45.427 32399-32649/com.lkl.valuecard D/DecodeHandler: decode size:1280,720

07-14 10:25:45.428 32399-32649/com.lkl.valuecard D/DecodeHandler: decode data length is 1382400

07-14 10:25:47.362 32399-32649/com.lkl.valuecard D/DecodeHandler: 第 1 次事件间隔为:1283

07-14 10:25:47.362 32399-32649/com.lkl.valuecard D/DecodeHandler: 第 2 次事件间隔为:651

07-14 10:25:47.375 32399-32399/com.lkl.valuecard D/CaptureActivityHandler: handleMessage: decode_failed

最后是我打log的位置:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
private void decode(byte[] data, int width, int height) {

        Size size = activity.getCameraManager().getPreviewSize();

        Log.d(TAG, "decode size:"+size.width+","+size.height);

        Log.d(TAG, "decode data length is "+data.length);

        Date start = new Date();

        // 这里需要将获取的data翻转一下,因为相机默认拿的的横屏的数据

        byte[] rotatedData = new byte[data.length];

        for (int y = 0; y
            for (int x = 0; x
                rotatedData[x * size.height + size.height - y - 1] = data[x + y * size.width];

        }

        Date secOnd= new Date();

        // 宽高也要调整

        int tmp = size.width;

        size.width = size.height;

        size.height = tmp;



        Result rawResult = null;

        PlanarYUVLuminanceSource source = buildLuminanceSource(rotatedData, size.width, size.height);

        if (source != null) {

            BinaryBitmap bitmap = new BinaryBitmap(new HybridBinarizer(source));

            try {

                rawResult = multiFormatReader.decodeWithState(bitmap);

            } catch (ReaderException re) {

                // continue

            } finally {

                multiFormatReader.reset();

            }

        }

        Date third = new Date();

        TimeUtil.showUpTime(TAG,start,second,third);

结语:经过实践,编译版本直接影响程序的运行速度,但为什么版本低反而运行得快呢?是否因为我使用的zxing的版本较低,需匹配低版本的编译版本才可发挥其性能?还有就应如何认识android各个编译版本的性能差异,以对应自己的开发需求选择合适的版本?


推荐阅读
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • 欢乐的票圈重构之旅——RecyclerView的头尾布局增加
    项目重构的Git地址:https:github.comrazerdpFriendCircletreemain-dev项目同步更新的文集:http:www.jianshu.comno ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
  • Android系统源码分析Zygote和SystemServer启动过程详解
    本文详细解析了Android系统源码中Zygote和SystemServer的启动过程。首先介绍了系统framework层启动的内容,帮助理解四大组件的启动和管理过程。接着介绍了AMS、PMS等系统服务的作用和调用方式。然后详细分析了Zygote的启动过程,解释了Zygote在Android启动过程中的决定作用。最后通过时序图展示了整个过程。 ... [详细]
author-avatar
嘻嘻哈哈的二狗子
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有