问题场景
蓝牙配对列表排序,需要把已经连接过蓝牙设备,按时间最近排序在前面。
解决思路
创建两个list列表,一个列表list_paired存储已配对的蓝牙列表,另一个列表list_con存储已连接过的蓝牙设备地址。当前蓝牙连接成功的时候,把已连接的设备按时间先后顺序插入列表。
这步之后,list_paired里面存储的是已配对的蓝牙列表,list_con里面存储的是顺序的已连接的设备地址。然后通过以下操作,即可把已连接过的地址,按顺序排序在配对列表前面。
下面是排序的demo代码段
// An highlighted block
List<A> list_a=new ArrayList<A>();
List<A> list_b=new ArrayList<A>();
//初始化列表A
list_a.add(new A("A", "1"));
list_a.add(new A("B", "2"));
list_a.add(new A("C", "3"));
list_a.add(new A("D", "4"));
list_a.add(new A("E", "5"));
for (int i = 0; i < list_a.size(); i++) {
System.out.println("a="+list_a.get(i).getA());
}
//初始化列表B
list_b.add(new A("C", "3"));
list_b.add(new A("A", "1"));
list_b.add(new A("D", "4"));
for (int i = 0; i < list_b.size(); i++) {
System.out.println("b="+list_b.get(i).getA());
}
//排序过程
for (int i = 0; i < list_b.size(); i++) {
A b=list_b.get(i);
for (int j = 0; j < list_a.size(); j++) {
A a=list_a.get(j);
if(b.getA().equals(a.getA())){
System.out.println("置顶:"+a.getA());
list_a.remove(j);
list_a.add(i,a);
}
}
}
//输出排序后结果
for (int i = 0; i < list_a.size(); i++) {
System.out.println("aaaaaa="+list_a.get(i).getA());
}