BaseAdapter的使用与优化

1.什么是数据适配器

下图清晰易懂
1

2.ListView的显示与缓存机制

一句话:需要才显示,显示完就回收到缓存,如下图:
2

3.ListView的Item布局

activity_main.xml:

    <ListView 
        android:id="@+id/lv_main"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        ></ListView>

ListView的item布局:item.xml:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <ImageView 
        android:id="@+id/iv_image"
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:src="@drawable/ic_launcher"
        />
    <TextView 
        android:id="@+id/tv_title"
        android:layout_width="match_parent"
        android:layout_height="30dp"
        android:layout_toEndOf="@+id/iv_image"
        android:gravity="center"
        android:text="Title"
        android:textSize="25sp"
        />
    <TextView 
        android:id="@+id/tv_content"
        android:layout_width="match_parent"
        android:layout_height="30dp"
        android:layout_toEndOf="@+id/iv_image"
        android:layout_below="@+id/tv_title"
        android:gravity="center_vertical"
        android:text="Content"
        android:textSize="20sp"
        />
</RelativeLayout>

还需要一个类来封装数据:

public class ItemBean {
    public int imgResId;
    public String title;
    public String content;

    public ItemBean(int imgResId, String title, String content) {
        super();
        this.imgResId = imgResId;
        this.title = title;
        this.content = content;
    }
}

4.创建数据源

private List<ItemBean> list = new ArrayList<ItemBean>();
        //创建数据
        for(int i=0;i<20;i++){
            list.add(new ItemBean(R.drawable.ic_launcher,
                    "Title"+i, 
                    "content"+i));
        }

5.重写适配器

继承BaseAdapter

public class MyAdapter extends BaseAdapter

构造函数

    private List<ItemBean> list;

    public MyAdapter(List<ItemBean> list){
        this.list = list;
    }

重写四个方法

    @Override
    public int getCount() {
        return list.size();
    }

    @Override
    public Object getItem(int position) {
        return list.get(position);
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

重点是第四个方法getView():
下面是几种实现方法:
1.逗逼式
初始化一个inflater

inflater = LayoutInflater.from(context);
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        //逗逼式
        //通过view来找控件id
        View view = inflater.inflate(R.layout.item, null);
        ImageView image = (ImageView) view.findViewById(R.id.iv_image);
        TextView title = (TextView) view.findViewById(R.id.tv_title);
        TextView content = (TextView)view.findViewById(R.id.tv_content);
        //装载内容
        ItemBean bean = list.get(position);
        image.setBackgroundResource(bean.imgResId);
        title.setText(bean.title);
        content.setText(bean.content);

        return view;
    }

最后适配一下:

        //设置适配器
        lv_main.setAdapter(new MyAdapter(this, list));

效果不说了:

3

评价:
没有利用到缓存机制,每次都重新创建view,极大的浪费了资源,没有任何优化,效率低下。

2.一般式

        //一般式
        if(convertView==null){
            convertView = inflater.inflate(R.layout.item, null);
        }
        ImageView image = (ImageView) convertView.findViewById(R.id.iv_image);
        TextView title = (TextView) convertView.findViewById(R.id.tv_title);
        TextView content = (TextView)convertView.findViewById(R.id.tv_content);
        //装载内容
        ItemBean bean = list.get(position);
        image.setBackgroundResource(bean.imgResId);
        title.setText(bean.title);
        content.setText(bean.content);
        return convertView;

评价:
可以看到与逗逼式差别不大,但利用了缓存机制,有所优化,但findViewById任然很耗时。

3.高级式:
声明一个内部类:

class ViewHolder{
        public ImageView image;
        public TextView title;
        public TextView content;
    }
        //高级式
        ViewHolder viewHolder = null;
        if(convertView==null){
            convertView = inflater.inflate(R.layout.item, null);
            viewHolder = new ViewHolder();//不要忘了
            viewHolder.image = (ImageView) convertView.findViewById(R.id.iv_image);
            viewHolder.title = (TextView) convertView.findViewById(R.id.tv_title);
            viewHolder.content = (TextView)convertView.findViewById(R.id.tv_content);
            //viewHolder与convertView相关联
            convertView.setTag(viewHolder);
        }else{
            viewHolder = (ViewHolder) convertView.getTag();
        }
        ItemBean bean = list.get(position);
        viewHolder.image.setBackgroundResource(bean.imgResId);
        viewHolder.title.setText(bean.title);
        viewHolder.content.setText(bean.content);

        return convertView;

评价:
既利用了缓存机制,也避免了重复寻找id,极大的优化。

6.总结

1.有兴趣可以记录下时间。
2.如果List里的对象只是String,没有复杂的布局,也可以直接用系统的。
3.不要只是copy代码,要思考实现的原理与艺术,这才是最重要的。

7.源代码:

源代码

内容概要:本文详细探讨了基于MATLAB/SIMULINK的多载波无线通信系统仿真及性能分析,重点研究了以OFDM为代表的多载波技术。文章首先介绍了OFDM的基本原理和系统组成,随后通过仿真平台分析了不同调制方式的抗干扰性能、信道估计算法对系统性能的影响以及同步技术的实现分析。文中提供了详细的MATLAB代码实现,涵盖OFDM系统的基本仿真、信道估计算法比较、同步算法实现和不同调制方式的性能比较。此外,还讨论了信道特征、OFDM关键技术、信道估计、同步技术和系统级仿真架构,并提出了未来的改进方向,如深度学习增强、混合波形设计和硬件加速方案。; 适合人群:具备无线通信基础知识,尤其是对OFDM技术有一定了解的研究人员和技术人员;从事无线通信系统设计开发的工程师;高校通信工程专业的高年级本科生和研究生。; 使用场景及目标:①理解OFDM系统的工作原理及其在多径信道环境下的性能表现;②掌握MATLAB/SIMULINK在无线通信系统仿真中的应用;③评估不同调制方式、信道估计算法和同步算法的优劣;④为实际OFDM系统的设计和优化提供理论依据和技术支持。; 其他说明:本文不仅提供了详细的理论分析,还附带了大量的MATLAB代码示例,便于读者动手实践。建议读者在学习过程中结合代码进行调试和实验,以加深对OFDM技术的理解。此外,文中还涉及了一些最新的研究方向和技术趋势,如AI增强和毫米波通信,为读者提供了更广阔的视野。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值