所以我只是出于个人原因制作一个小应用程序。基本上它所做的只是从网站解析xml,它将返回一个颜色列表,标题和&作者然后在列表视图中显示它们。它有点工作,但有时候我会得到这些indexoutofboundsexceptions,例如总是出现在for循环中。解释for循环好一点。结果是一个arraylist。列表视图中的每一行由3个元素组成:标题,用户名和颜色。 for循环遍历数组,基本上将值分配给行,因此最初第一个元素将分配给title,第二个元素将分配给用户名,依此类推。模式只是重复自己。如果有人看到问题,甚至知道更好的方法,请分享:)
for (int i = 0; i < result.size(); i++) {
sr = new SearchResults();
sr.setTitle(result.get(i));
i++;
sr.setUser(result.get(i));
i++;
sr.setHex(result.get(i));
results.add(sr);
}
错误通常看起来像这样:
07-11 14:48:08.272: E/AndroidRuntime(15370): FATAL EXCEPTION: main
07-11 14:48:08.272: E/AndroidRuntime(15370): java.lang.IndexOutOfBoundsException: Invalid index 62, size is 62
以下是代码:
public class ColorsActivity extends ListActivity {
/** Called when the activity is first created. */
private int selection = 0;
private String info;
private ArrayList<String> myArr = new ArrayList<String>();
private int resultOffset=0;
private TextView settings;
private SearchResults sr = new SearchResults();
private ArrayList<SearchResults> results = new ArrayList<SearchResults>();
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
settings = (TextView) findViewById(R.id.settings_text);
final ListView lv = getListView();
lv.setDividerHeight(0);
colorTask refTask = new colorTask();
refTask.execute();
settings.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
colorTask refTask = new colorTask();
refTask.execute();
}
});
}
public class MyCustomBaseAdapter extends BaseAdapter {
private ArrayList<SearchResults> searchArrayList;
private LayoutInflater mInflater;
public MyCustomBaseAdapter(Context context, ArrayList<SearchResults> results) {
searchArrayList = results;
mInflater = LayoutInflater.from(context);
}
public int getCount() {
return searchArrayList.size();
}
public Object getItem(int position) {
return searchArrayList.get(position);
}
public long getItemId(int position) {
return position;
}
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
convertView = mInflater.inflate(R.layout.list_item, null);
holder = new ViewHolder();
holder.txtHex = (TextView) convertView.findViewById(R.id.text1);
holder.txtTitle = (TextView) convertView.findViewById(R.id.TextView02);
holder.txtUser = (TextView) convertView.findViewById(R.id.TextView01);
holder.txtColorValue = (TextView) convertView.findViewById(R.id.TextView03);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
holder.txtTitle.setText(searchArrayList.get(position).getTitle());
holder.txtUser.setText(searchArrayList.get(position).getUser());
String c = searchArrayList.get(position).getHex();
holder.txtHex.setBackgroundColor(Integer.parseInt(c, 16)+0xFF000000);
holder.txtColorValue.setText(searchArrayList.get(position).getHex());
return convertView;
}
class ViewHolder {
TextView txtTitle;
TextView txtUser;
TextView txtHex;
TextView txtColorValue;
}
}
class colorTask extends AsyncTask<String, Void, ArrayList<String>> {
private final ProgressDialog dialog = new ProgressDialog(ColorsActivity.this);
// can use UI thread here
protected void onPreExecute() {
this.dialog.setMessage("Contacting server...");
this.dialog.show();
}
protected ArrayList<String> doInBackground(final String... args) {
URL url = null;
ParsedExampleDataSet parsedExampleDataSet = null;
try {
if (selection == 0) {
url = new URL ("http://www.colourlovers.com/api/colors/top?resultOffset=" + resultOffset);
}
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
SAXParserFactory spf = SAXParserFactory.newInstance();
SAXParser sp = null;
try {
sp = spf.newSAXParser();
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
/* Get the XMLReader of the SAXParser we created. */
XMLReader xr = null;
try {
xr = sp.getXMLReader();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
/* Create a new ContentHandler and apply it to the XML-Reader*/
getColors myExampleHandler = new getColors(selection);
xr.setContentHandler(myExampleHandler);
/* Parse the xml-data from our URL. */
try {
xr.parse(new InputSource(url.openStream()));
parsedExampleDataSet =
myExampleHandler.getParsedData();
myArr = parsedExampleDataSet.toArrayList();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return myArr;
}
// can use UI thread here
protected void onPostExecute(final ArrayList<String> result) {
if (this.dialog.isShowing()) {
this.dialog.dismiss();
}
if (result != null) {
for (int i = 0; i < result.size(); i++) {
sr = new SearchResults();
sr.setTitle(result.get(i));
i++;
sr.setUser(result.get(i));
i++;
sr.setHex(result.get(i));
results.add(sr);
}
ListView lv = getListView();
lv.setAdapter(new MyCustomBaseAdapter(ColorsActivity.this, results));
resultOffset += 20;
} else {
Toast.makeText(ColorsActivity.this, "Error contacting server.", Toast.LENGTH_SHORT).show();
}
}
}
public class SearchResults {
private String title = "";
private String hex = "";
private String user = "";
public void setTitle(String title) {
this.title = title;
}
public String getTitle() {
return title;
}
public void setHex(String hex) {
this.hex = hex;
}
public String getHex() {
return hex;
}
public void setUser(String user) {
this.user = user;
}
public String getUser() {
return user;
}
}
答案 0 :(得分:2)
for (int i = 0; i < result.size(); i++) {
sr = new SearchResults();
sr.setTitle(result.get(i));
i++;
sr.setUser(result.get(i));
i++;
sr.setHex(result.get(i));
results.add(sr);
}
你在这里盲目增加i
。这很可能就是问题所在。找到问题的根源,您解析的数据可能有时不完整或解析不正确,因此它并不总是产生所需数量的参数(即您解析期望标题,用户和颜色的东西,但是只获得一个标题和一个用户。)
由于List
的大小为62,因此建议您在解析时至少错过1个参数(标题,用户或颜色)。如果所有内容都已正确解析,则List
的大小为63。
答案 1 :(得分:0)
当你增加i(i ++)时,你将超越数组的边界,因为你从数组的0大小进行迭代。当你达到size-2时,for循环中的第二个i ++将是一个不存在的索引。
答案 2 :(得分:0)
您的问题出在for循环中。你正在增加循环内部的变量i。所以当我61岁的时候大小是62,你也加一个i,试图访问索引62,当大小是62时。
答案 3 :(得分:0)
问题是您正在尝试访问不存在的arraylist中的索引。问题肯定在for循环中:
for (int i = 0; i < result.size(); i++) {
sr = new SearchResults();
sr.setTitle(result.get(i));
i++;
sr.setUser(result.get(i));
i++;
sr.setHex(result.get(i));
results.add(sr);
}
如果你只在循环声明中增加i,那就没问题;它将与其他两个i ++语句中的一个一起出现问题,因为在每个语句之后你都没有检查是否超出了数组的长度。这必须意味着在一个或多个情况下,存在缺少一个或多个参数的三元组(标题,用户,十六进制)。如果总是存在所有三个参数,那么阵列就不能正确填充。
如果你希望代码在参数不匹配的情况下是故障安全的,那么每次增加它时都要检查i与数组的长度,即在循环内再检查两次 - 然后,如果它已到达数组的length,以你认为合适的方式处理错误(中断循环,用虚拟数据填充sr的剩余值等)。
这样的事情:
for (int i = 0; i < result.size(); i++) {
sr = new SearchResults();
sr.setTitle(result.get(i));
i++;
if (i == result.size()) {
sr.setUser("dummy");
}
else {
sr.setUser(result.get(i));
}
i++;
if (i == result.size()) {
sr.setHex("#000000");
}
else {
sr.setHex(result.get(i));
}
results.add(sr);
}