java ArrayList<>中,可以再继续添加ArrayList元素吗
时间: 2023-06-02 22:07:21 浏览: 53
可以,你可以通过添加ArrayList实例的方式继续向其添加元素。例如:
```java
ArrayList<ArrayList<String>> list = new ArrayList<ArrayList<String>>();
ArrayList<String> innerList1 = new ArrayList<String>();
innerList1.add("inner1");
list.add(innerList1);
ArrayList<String> innerList2 = new ArrayList<String>();
innerList2.add("inner2");
list.add(innerList2);
```
这样,在`list`中就包含了两个`ArrayList`实例。第一个`ArrayList`实例中包含了一个元素"inner1",第二个`ArrayList`实例中包含了一个元素"inner2"。
相关问题
Error:(32, 17) java: 对于invokeAll(ss), 找不到合适的方法 方法 java.util.concurrent.ExecutorService.<T>invokeAll(java.util.Collection<? extends java.util.concurrent.Callable<T>>)不适用 (无法推断类型变量 T (参数不匹配; ss无法转换为java.util.Collection<? extends java.util.concurrent.Callable<T>>)) 方法 java.util.concurrent.ExecutorService.<T>invokeAll(java.util.Collection<? extends java.util.concurrent.Callable<T>>,long,java.util.concurrent.TimeUnit)不适用 (无法推断类型变量 T (实际参数列表和形式参数列表长度不同))
这个报错信息提示在第32行中的invokeAll方法调用参数不匹配,无法找到合适的方法。可能有两个问题:
1. ss类没有实现Callable接口,导致无法将其转换为Callable类型的集合,所以参数不匹配。
2. invokeAll方法需要传入一个Callable的集合,而你只传入了一个ss对象,和一个ss类型的集合也无法匹配,所以报错。
你可以将ss改为实现Callable接口,然后将其放入一个Callable类型的集合中,再将集合传入invokeAll方法中。代码示例如下:
```
public class test {
public static void main(String[] args) throws InterruptedException {
// 创建一个固定大小的线程池
ExecutorService service = Executors.newFixedThreadPool(3);
Callable<String> t1 = new ss();
List<Callable<String>> list = new ArrayList<>();
list.add(t1);
service.invokeAll(list);
// 关闭启动线程
service.shutdown();
// 等待子线程结束,再继续执行下面的代码
service.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS);
//System.out.println("all thread complete");
}
}
class ss implements Callable<String> {
@Override
public String call() {
System.out.println(Thread.currentThread().getName() + "执行call方法");
return null;
}
}
```
这样就可以避免参数不匹配的问题了。
import java.util.ArrayList; class BackCounter implements Runnable{ private int count =100; public int getCount(){ return count; } public void run(){ for(int i=10;i>0;i--){ synchronized (this){ if(count<=10){ break; } count--; } try{ Thread.sleep(10); }catch(InterruptedException e){ } } } } public class Mooc72 { public static void main(String[] args) throws InterruptedException{ ArrayList<Thread>It=new ArrayList<Thread>(); BackCounter bc=new BackCounter(); It.add(new Thread(bc)); It.add(new Thread(bc)); for(Thread th:It){ } for(Thread th:It){ } System.out.println(bc.getCount()); } },两个for语句中应该补全什么代码,使得输出结果为80
两个for循环中应该加入以下代码:
```
for(Thread th:It){
th.start();
}
for(Thread th:It){
th.join();
}
```
第一个for循环启动了两个线程,第二个for循环等待这两个线程执行完毕后再继续执行下面的语句,保证了最后输出的count值为80。