List<String> name = new ArrayList<String>();为什么运编译不通过
时间: 2024-06-14 20:07:37 浏览: 14
List<String> name = new ArrayList<String>();为什么运编译不通过?
这是因为在Java中,泛型是用来限制集合中元素的类型的。在声明List<String> name = new ArrayList<String>();时,你指定了name这个List只能存储String类型的元素。但是在你的代码中,你没有指定具体的元素类型,而是使用了原始的ArrayList类型。因此,编译器会报错,提示你需要将ArrayList改为List<String>类型。
正确的代码应该是这样的:
```java
List<String> name = new ArrayList<String>();
name.add("qqyumidi");
name.add("corn");
```
这样就可以编译通过了。
相关问题
代码有错误 public class ListDownTest { public static void main(String[] args) { // 1. 获取原有的分页对象列表 System.out.println("原始数组"); List<Dog> originalList = getList(); for (Dog dog : originalList) { System.out.println(dog.toString()); } // 2. 从列表中删除第25、26、27项,并记录它们的位置和值 List<Dog> removedItems = new ArrayList<>(); removedItems.add(originalList.remove(24)); // 第25项 removedItems.add(originalList.remove(24)); // 第26项 removedItems.add(originalList.remove(24)); // 第27项 System.out.println("删除后数组"); for (Dog dog : originalList) { System.out.println(dog.toString()); } // 3. 将剩余的项按照原有的分页规则进行分页 int pageSize = 10; // 每页显示10项 int totalItems = originalList.size(); int totalPages = (int) Math.ceil((double) totalItems / pageSize); List<List<Dog>> pageList = new ArrayList<>(); for (int i = 0; i < totalPages; i++) { int fromIndex = i * pageSize; int toIndex = Math.min(fromIndex + pageSize, totalItems); pageList.add(originalList.subList(fromIndex, toIndex)); } // 4. 将删除的项插入到第5页的最后一项之后 int insertIndex = 0; // 第5页的最后一项 List<Dog> fifthPage = pageList.get(4); for (Dog item : removedItems) { fifthPage.add(insertIndex++, item); } // 5. 返回新的分页对象列表 List<Dog> newPageList = new ArrayList<>(); for (List<Dog> page : pageList) { newPageList.addAll(page); } for (Dog dog : newPageList) { System.out.println(dog.toString()); } } public static List<Dog> getList() { List<Dog> list = new ArrayList<>(); for (int i = 0; i < 100; i++) { list.add(new Dog("name" + i, i, 0)); } return list; } @Data @AllArgsConstructor @ToString static class Dog { private String name; private Integer num; private Integer isDown; } }
问题不是很明确,但我猜测你想知道这段代码的问题是什么。这段代码的问题在于删除第25、26、27项时的索引计算错误。代码中使用remove()方法删除元素后,原列表的大小会发生变化,这导致后续删除的索引位置也发生了变化。正确的做法是从后往前删除,避免索引位置的变化。修改方法如下:
```java
removedItems.add(originalList.remove(26)); // 第27项
removedItems.add(originalList.remove(25)); // 第26项
removedItems.add(originalList.remove(24)); // 第25项
```
另外,代码中的Dog类使用了Lombok注解,需要先安装Lombok插件才能编译通过。
import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import java.util.ArrayList; import java.util.List; //import Account.java; public class JDBCResultSet<Stu> { public void testResultSet() throws Exception { Class.forName("com.mysql.jdbc.Driver"); String url = "jdbc:mysql:///test01?useSSL=false"; String username = "root"; String password = "03928"; Connection conn = DriverManager.getConnection(url, username, password); String sql = "select * from account"; Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery(sql); List<Stu> list = new ArrayList<>(); while (rs.next()){ Stu student = new Stu(); } } }出现Type parameter 'Stu' cannot be instantiated directly这个错误如何处理
在您的代码中,`Stu`是一个泛型类型参数,它不能被直接实例化。因此,在这里创建`Stu`的实例会导致编译错误。
如果您想要将查询结果集映射到一个类型为`Stu`的对象列表中,您需要做以下几件事:
1. 定义一个具体的类来表示您想要映射的对象,例如:
```
public class Student {
private int id;
private String name;
// ...
public Student(int id, String name) {
this.id = id;
this.name = name;
}
// ...
}
```
2. 在您的方法中,使用`ResultSet`对象来获取查询结果集中的数据,并将其映射到您定义的对象中,例如:
```
List<Student> list = new ArrayList<>();
while (rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
Student student = new Student(id, name);
list.add(student);
}
```
在这个例子中,我们使用`ResultSet`对象的`getInt()`和`getString()`方法来获取查询结果集中的数据,并将其映射到`Student`对象中。最后,我们将`Student`对象添加到一个`List<Student>`中。
请注意,这只是一个示例。实际上,您需要根据您的需求定义一个适合您的类,并将查询结果映射到这个类的实例中。
相关推荐
![docx](https://img-home.csdnimg.cn/images/20210720083331.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)