Android开发——09Google I/O之让Android UI性能更高效(1)

1、前言html

前几天发现09年Google IO大会关于移动应用方面的主题有一些不错的PPT,对移动应用开发颇有帮助。本身看了一些,边看边和你们分享。既然是PPT就很简化了,我会根据实际状况写一些Demo供你们参考。app

Android在UI优化方面能够从如下五个方面入手:ide

  • Adapter优化布局

  • 背景和图片优化测试

  • 绘图优化优化

  • 视图和布局优化spa

  • 内存分配优化code

    2、Adapter优化移动应用开发

    什么是Adapter,能够先看看个人上一篇文章,Android开发——说说Adapter那点事 Adapter与View的链接主要依靠getView这个方法返回咱们须要的自定义view。ListView是Android app中一个最最最经常使用的控件了,因此如何让ListView流畅运行,获取良好的用户体验是很是重要的。对ListView优化就是对Adapter中的getView方法进行优化。09年的Google IO大会给出的优化建议以下:htm

    Adapter优化示例代码:

       1: @Override
       2: public View getView(int position, View convertView, ViewGroup parent) {
       3:     Log.d("MyAdapter", "Position:" + position + "---"
       4:             + String.valueOf(System.currentTimeMillis()));
       5:     ViewHolder holder;
       6:     if (convertView == null) {
       7:         final LayoutInflater inflater = (LayoutInflater) mContext
       8:                 .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
       9:         convertView = inflater.inflate(R.layout.list_item_icon_text, null);
      10:         holder = new ViewHolder();
      11:         holder.icon = (ImageView) convertView.findViewById(R.id.icon);
      12:         holder.text = (TextView) convertView.findViewById(R.id.text);
      13:         convertView.setTag(holder);
      14:     } else {
      15:         holder = (ViewHolder) convertView.getTag();
      16:     }
      17:     holder.icon.setImageResource(R.drawable.icon);
      18:     holder.text.setText(mData[position]);
      19:     return convertView;
      20: }
      21:
      22: static class ViewHolder {
      23:     ImageView icon;
      24:
      25:     TextView text;
      26: }

    以上是Google io大会上给出的优化建议,通过尝试ListView确实流畅了许多。

     

       1: @Override
       2:  public View getView(int position, View convertView, ViewGroup parent) {
       3:      Log.d("MyAdapter", "Position:" + position + "---"
       4:              + String.valueOf(System.currentTimeMillis()));
       5:          final LayoutInflater inflater = (LayoutInflater) mContext
       6:                  .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
       7:          View v = inflater.inflate(R.layout.list_item_icon_text, null);
       8:          ((ImageView) v.findViewById(R.id.icon)).setImageResource(R.drawable.icon);
       9:          ((TextView) v.findViewById(R.id.text)).setText(mData[position]);
      10:         return v;
      11:  }

    以上是不建议的作法!!

     

    不过咱们仍是要怀疑一下,SO,咱们仍是来测试对比一下。

     

    测试说明:

    你们能够看到在getView的时候咱们经过log打印出position和当前系统时间。咱们经过初始化1000条数据到Adapter显示到ListView,而后滚动到底部,计算出position=0和position=999时的时间间隔。

    测试机子:HTC Magic

    测试实录:打开测序,让ListView一直滚动底部。:-)

  • device

    测试结果:

    两种状况在操做过程当中体验明显不一样,在优化的状况下流畅不少不少!

    一、优化建议测试结果:

    12-05 10:44:46.039: DEBUG/MyAdapter(13929): Position:0---1291517086043 
    12-05 10:44:46.069: DEBUG/MyAdapter(13929): Position:1---1291517086072 
    12-05 10:44:46.079: DEBUG/MyAdapter(13929): Position:2---1291517086085

    ……

    12-05 10:45:04.109: DEBUG/MyAdapter(13929): Position:997---1291517104112 
    12-05 10:45:04.129: DEBUG/MyAdapter(13929): Position:998---1291517104135 
    12-05 10:45:04.149: DEBUG/MyAdapter(13929): Position:999---1291517104154


    耗时:17967

    二、没优化的测试结果

    12-05 10:51:42.569: DEBUG/MyAdapter(14131): Position:0---1291517502573 
    12-05 10:51:42.589: DEBUG/MyAdapter(14131): Position:1---1291517502590 
    12-05 10:51:42.609: DEBUG/MyAdapter(14131): Position:2---1291517502617

    ……

    12-05 10:52:07.079: DEBUG/MyAdapter(14131): Position:998---1291517527082 
    12-05 10:52:07.099: DEBUG/MyAdapter(14131): Position:999---1291517527108 

    耗时:24535

相关文章
相关标签/搜索