次のようにOutlierInfoという名前のクラスを作成しました
public class OutlierInfo
{
public String month;
public int year;
public String id;
public int serialId;
public void setSerialId(int serialid)
{
serialId=serialid;
}
public void setMonth(String monthh)
{
month=monthh;
}
public void setYear(int yearr)
{
year=yearr;
}
public void setId(String idd)
{
id=idd;
}
}
AdタイプOutlierinfoの配列リストがあります。配列リストにOutlierInfoのオブジェクトをいくつか追加しました。ここで、SerialIdに従ってオブジェクトをグループ化し、各グループの配列リストを作成してから、グループのすべての配列リストをマージする必要があります。これは私が作成したコードですが、エラーが発生するだけで、理由がわかりません。次のコードでエラーが発生する理由を見つけるのに助けが必要ですか?</ p>
public class ArraylistSort
{
ArrayList<OutlierInfo> result = new ArrayList();
static ArrayList<ArrayList<OutlierInfo>> groupResult = new ArrayList<ArrayList<OutlierInfo>>();
String[] months = { "JAN", "FEB", "MAR", "APR" ,
"MAY", "JUN", "JUL", "AUG" ,
"SEP", "OCT", "NOV", "DECM"
};
int counter=0;
int count=0;
public ArraylistSort(){
for(int i=0;i<2;i++)
{
for(int j=0;j<4;j++)
{
int year=2000+j;
OutlierInfo o=setValues(i,months[j],year);
result.add(o);
System.out.println("result size"+result.size());
}
}
while(result.size()!=0)
{
OutlierInfo info1=new OutlierInfo();
info1=result.get(counter);
ArrayList<OutlierInfo> partialInfo=new ArrayList();
for(int j=1;j<count;j++)
{
OutlierInfo info2=new OutlierInfo();
info2=result.get(j);
if(info1.serialId==info2.serialId)
{
partialInfo.add(info2);
result.remove(info2);
}
}
partialInfo.add(info1);
System.out.println("partiainfosize"+partialInfo.size());
groupResult.add(partialInfo);
result.remove(info1);
System.out.println("r size "+result.size());
}
count=result.size();
}
private OutlierInfo setValues(int id,String month,int year)
{
OutlierInfo a = new OutlierInfo();
a.setSerialId(id);
a.setMonth(month);
a.setYear(year);
return a;
}
public static void main(String[] args)
{
ArraylistSort as=new ArraylistSort();
}
}
次のエラーが発生します:誰かがエラーを理解するのを手伝ってもらえますか?論理エラーはありますか?
initial size 0
result size1
result size2
result size3
result size4
result size5
Exception in thread "main" java.lang.IndexOutOfBoundsException: Index: 6, Size: 6
result size6
result size7
result size8
at java.util.ArrayList.RangeCheck(ArrayList.java:547)
at java.util.ArrayList.get(ArrayList.java:322)
at STAnalysis.ArraylistSort.<init>(ArraylistSort.java:56)
at STAnalysis.ArraylistSort.main(ArraylistSort.java:98)
Java Result: 1
アップデート
現在直面している最大の混乱は、実際にオブジェクトを配列リストに追加しているときに、「範囲外のインデックス」というエラーがスローされることです。
アップデート
私はそれを修正しました。私はカーリーブレースを台無しにしていたことが判明しました。私の最終的なコード
public class StAnamoliesSequencer
{
ArrayList<OutlierInfo> stAnomalies =new ArrayList();//arraylist of spatio-temporal outliers
ArrayList<ArrayList<OutlierInfo>> sequencedStAnomalies=new ArrayList<ArrayList<OutlierInfo>>();
int firstElement;
public StAnamoliesSequencer()
{
firstElement=0;
}
public ArrayList<ArrayList<OutlierInfo>> sequenceStAnomalies(ArrayList<OutlierInfo> sTanomalies)
{
int loopSizeDeterminer;//determines teh size of the inner loop and is dynamic.
for(int index=0;index<sTanomalies.size();index++)
{
OutlierInfo stOutlier=new OutlierInfo();
stOutlier=sTanomalies.get(index);
stAnomalies.add(index, stOutlier);
}
loopSizeDeterminer=stAnomalies.size();
while(stAnomalies.size()!=0)
{
OutlierInfo stOutlier1=new OutlierInfo();
ArrayList<OutlierInfo> tracker=new ArrayList();//arraylist that stores the grouped Outliers to be deleted later
stOutlier1=stAnomalies.get(firstElement);
ArrayList<OutlierInfo> similarOutlier=new ArrayList();//similaroutliers are kept in an arraylist
similarOutlier.add(stOutlier1);
tracker.add(stOutlier1);
for(int index=1;index<loopSizeDeterminer;index++)
{
OutlierInfo stOutlier2=new OutlierInfo();
stOutlier2=stAnomalies.get(index);
if(stOutlier1.serialId==stOutlier2.serialId)
{
similarOutlier.add(stOutlier2);
tracker.add(stOutlier2);
}
}
System.out.println("partiainfosize \t"+similarOutlier.size());
sequencedStAnomalies.add(similarOutlier);//adding arraylist of similar outliers to the arraylist of arraylist
for(int index=0;index<tracker.size();index++)
{
OutlierInfo groupedOutlier=new OutlierInfo();
groupedOutlier=tracker.get(index);
stAnomalies.remove(groupedOutlier);//grouped outliers are removed from original arraylist containing spatio-temporal outliers to reduce redundancy
}
System.out.println(" size "+stAnomalies.size());
loopSizeDeterminer=stAnomalies.size();
}
return sequencedStAnomalies;
}
}