软件构造实验遇到的问题
在进行学校的软件构造实验时,我遇到了一些问题,故以此方式记录下来,希望以后自己有能力解决。
ArrayList的使用
ArrayList<Integer> al= new ArrayList<>();
ArrayList<ArrayList<Integer>> alList= new ArrayList<>();
for(int i=0;i<3;i++){
al.clear();
for(int j=0;j<5;j++){
al.add(i+j);
}
alList.add(al);
}
System.out.println(alList);
在执行上面一段代码时,我认为能够以此来达到读取多行数据的目的,然而实际的运行结果为
也就是说最终alList只是将最后一行数据存储了三遍,通过不断调试,最终发现是因为错用了clear()函数,AarrayList.clear()应该只是将存储在对应地址上的数据抹除了,而在进行alList.add(al)时只是将al对应的地址进行了存储,所以才会出现最终alList中是三次最后一行的元素,解决方法也挺简单,就是将al.clear()替换成
al= new ArrayList<>();
通过开辟新地址来做到多行数据的存储。
HashMap的使用
HashMap<k,Integer> mp=new HashMap<>();
mp.put(new k(1,1),1);
mp.put(new k(1,2),1);
mp.put(new k(1,3),1);
System.out.println(mp.containsKey(new k(1,1)));
我用HashMap来存储一个抽象类对应的数据,其中成员类k的代码如下:
private int x1;
private int x2;
public k(int x1, int x2) {
this.x1 = x1;
this.x2 = x2;
}
我本以为只需要两个成员类中的x1,x2相同,那么对应的k就应该相同,然而实际上的结果为
经过反思,我觉得即便是成员类对应的参数相同,也不代表它们相等,还是自己的java水平太差了,解决方法也很简单,只需将k的代码改为:
private int x1;
private int x2;
private int length;
public k(int x1, int x2,int length) {
this.x1 = x1;
this.x2 = x2;
this.length=length;
}
这样根本没必要使用HashMap的必要,感觉还是自己的基础不够扎实才会出现这个问题。
HashSet的使用
HashSet<Integer> set=new HashSet<>();
for(int i=0;i<5;i++){
set.add(i);
}
for(Integer item:set){
if(item==3){
set.remove(3);
}
}
这个纯粹是自己脑残,当初老师教的时候说过for each循环只能用来遍历,不能用来更新数据,当时那会没咋用过HashSet,用的数据结构都是能用key来取值的,蛋疼的是HashSet只能用for each循环来取值,而我此时又需要HashSet所具有的元素不重复性,所以两个知识盲区直接混在一起,就导致了接下来这种报错
解决方法也挺简单粗暴,那就是在每次即需要对HashSet中的数据进行更新时先建立一个新的HashSet,然后在用for each遍历原来的HashSet时对新的HashSet进行操作,最后再将新值赋给旧变量就可以了:
HashSet<Integer> set=new HashSet<>();
for(int i=0;i<5;i++){
set.add(i);
}
HashSet<Integer> temp=new HashSet<>();
for(Integer item:set){
if(item!=3){
temp.add(item);
}
}
set=temp;
有关for each更详细的讲解可以看看这个文章:
https://blog.csdn.net/qq_45363655/article/details/106108646