1

目前我有下面的代码,我试图从 Object 转换为 String 并且我得到一个异常错误。

将此 Object 数组转换为 String 数组以便它在我的 for 循环中工作的最佳方法是什么?或者有没有办法改变我的 for 循环来显示对象数组?

<%

          Class.forName("org.sqlite.JDBC");
            Connection conn = DriverManager.getConnection("jdbc:sqlite:/Users/rhysparker/Documents/workspace/Resource_Planner/WebContent/db/RESOURCE.SQLITE");
                Statement stat = conn.createStatement();

                ArrayList<ArrayList<String>> al = new ArrayList<ArrayList<String>>();

                ResultSet rs = stat.executeQuery("select project_name from project;");

                ResultSetMetaData metaData = rs.getMetaData();
                int columns = metaData.getColumnCount();

                while (rs.next()) {
                    ArrayList<String> record = new ArrayList<String>();
                    for (int i = 1; i <= columns; i++) {
                        String value = rs.getString(i);
                        record.add(value);
                    }
                    al.add(record);
                }

                String[] testing = (String[])al.toArray();

                for(int i=0;i<testing.length;i++) 
                { %> 
                <option value="<%=testing[i]%>"><%=testing[i]%></option><% 
                } 

                rs.close();
               conn.close();
            %>
4

4 回答 4

2
 I get an exception error.

是的,因为al是类型ArrayList<String> ArrayList<ArrayList<String>> al = new ArrayList<ArrayList<String>>();

你正在把它转换成一个字符串数组

String[] testing = (String[])al.toArray();

所以它会在运行时抛出异常,比如 .

Exception in thread "main" java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to [Ljava.lang.String;

如果您Arraylist在 arraylist 中添加,那么您有责任确保类型检查。

您可以执行以下操作:

for (ArrayList<String> list: al)
 {
    String[] testing = list.toArray(new String[0]); // or (String[]) arr.toArray();
    for(int i=0;i<testing.length;i++) 
     { %> 
        <option value="<%=testing[i]%>"><%=testing[i]%></option><% 
     }
 }
于 2013-02-14T06:15:47.807 回答
0
ArrayList<ArrayList<String>> list = new ArrayList<ArrayList<String>>();
String[] array = (String[])list.toArray(new String[list.size()]);

你的意思是这样的?试试这个。

于 2013-02-14T06:08:03.027 回答
0

这是因为您al是多维的(ArrayList 的 ArrayList - 包含一个数据库表 - 我想)
下面的代码将帮助您填充testing数组

int maxColumn = 100;    //Assuming not more than 100 columns
int rowSize = a1.size();
String[] s1 = new String[maxColumn];
String[][] testing = new String[rowSize][maxColumn];    
for(int i=0; i<rowSize; i++)
{
    ArrayList a1 = al.get(i);
    s1 = a1.toArray();
    for(int j=0; j<s1.length; j++)
        testing[i][j] = s1[j];
}

testing是具有表记录的二维数组。现在,您需要在<option>重要的领域中分配到哪一列
说您需要分配column 3
所以您for-loop将成为

for(int i=0;i<rowSize;i++) 
{ %> 
    <option value="<%= testing[i][3] %>"><%=testing[i]%></option>
<% } 
于 2013-02-14T06:33:19.150 回答
0

你得到一个例外,因为al你正在转换的数组列表中的元素是类型ArrayList<String>,当然,不能强制转换为String[].

您必须使用二维数组才能使代码正常工作,因为您的列表al属于类型ArrayList<ArrayList<String>>,这意味着列表中的元素是另一个包含String

要解决您的问题,您必须手动循环遍历列表,然后将每个元素(即ArrayList<String>)转换为String[]

int yLen = al.size();
        int xLen = al.get(0).size();
        String[][] testing = new String[yLen][xLen];
        for(int a = 0; a < yLen; a++){
            testing[a] = al.get(a).toArray(testing[a]);
        }
于 2013-02-14T06:46:22.803 回答