AbstractQueue的addAll(E e)方法将指定集合中的所有元素添加到此队列中。
用法:
public boolean addAll(Collection c)
参数:此方法接受包含要添加到此队列中的元素的强制参数集合
返回:如果此队列由于调用而更改,则该方法返回true
异常:此方法引发以下异常:
- IllegalStateException:如果由于插入限制,此时无法添加所有元素
- NullPointerException :如果指定的集合包含null元素,并且此队列不允许使用null元素,或者指定的collection为null
- ClassCastException-如果指定集合的元素的类阻止将其添加到此队列中
- IllegalArgumentException-如果指定集合的元素的某些属性阻止将其添加到此队列,或者指定的集合是此队列
以下示例程序旨在说明addAll()方法:
程序1:
// Java program to illustrate the
// AbstractQueue addAll() method
import java.util.*;
import java.util.concurrent.LinkedBlockingQueue;
public class GFG1 {
public static void main(String[] argv)
throws Exception
{
// Creating object of AbstractQueue<Integer>
AbstractQueue<Integer>
AQ1 = new LinkedBlockingQueue<Integer>();
// Populating AQ1
AQ1.add(10);
AQ1.add(20);
AQ1.add(30);
AQ1.add(40);
AQ1.add(50);
// print AQ
System.out.println("AbstractQueue1 contains:" + AQ1);
AbstractQueue<Integer>
AQ2 = new LinkedBlockingQueue<Integer>();
// print AQ2 initially
System.out.println("AbstractQueue2 initially contains:" + AQ2);
// adds elements of AQ1 in AQ2
AQ2.addAll(AQ1);
System.out.println("AbstractQueue1 after addition contains:" + AQ2);
}
}
输出:
AbstractQueue1 contains:[10, 20, 30, 40, 50] AbstractQueue2 initially contains:[] AbstractQueue1 after addition contains:[10, 20, 30, 40, 50]
程序2:IllegalStateException程序
// Java program to illustrate the
// AbstractQueue addAll() method
import java.util.*;
import java.util.concurrent.LinkedBlockingQueue;
public class GFG1 {
public static void main(String[] argv)
throws Exception
{
try {
// Creating object of AbstractQueue<Integer>
AbstractQueue<Integer>
AQ1 = new LinkedBlockingQueue<Integer>();
// Populating AQ1
AQ1.add(10);
AQ1.add(20);
AQ1.add(30);
AQ1.add(40);
AQ1.add(50);
// print AQ
System.out.println("AbstractQueue1 contains:" + AQ1);
AbstractQueue<Integer>
AQ2 = new LinkedBlockingQueue<Integer>(3);
// print AQ2 initially
System.out.println("AbstractQueue2 initially contains:" + AQ2);
// adds elements of AQ1 in AQ2
AQ2.addAll(AQ1);
System.out.println("AbstractQueue1 after addition contains:" + AQ2);
}
catch (Exception e) {
System.out.println("Exception:" + e);
}
}
}
输出:
AbstractQueue1 contains:[10, 20, 30, 40, 50] AbstractQueue2 initially contains:[] Exception:java.lang.IllegalStateException:Queue full
程序3:NullPointerException的程序
// Java program to illustrate the
// AbstractQueue addAll() method
import java.util.*;
import java.util.concurrent.LinkedBlockingQueue;
public class GFG1 {
public static void main(String[] argv)
throws Exception
{
try {
// Creating object of AbstractQueue<Integer>
AbstractQueue<Integer>
AQ1 = null;
// print AQ
System.out.println("AbstractQueue1 contains:" + AQ1);
AbstractQueue<Integer>
AQ2 = new LinkedBlockingQueue<Integer>(3);
// print AQ2 initially
System.out.println("AbstractQueue2 initially contains:" + AQ2);
// adds elements of AQ1 in AQ2
AQ2.addAll(AQ1);
System.out.println("AbstractQueue1 after addition contains:" + AQ2);
}
catch (Exception e) {
System.out.println("Exception:" + e);
}
}
}
输出:
AbstractQueue1 contains:null AbstractQueue2 initially contains:[] Exception:java.lang.NullPointerException
参考: https://docs.oracle.com/javase/8/docs/api/java/util/AbstractQueue.html#addAll-E-
相关用法
- Java AbstractQueue add()用法及代码示例
- Java AbstractQueue remove()用法及代码示例
- Java AbstractQueue element()用法及代码示例
- Java AbstractQueue clear()用法及代码示例
- Java Set addAll()用法及代码示例
- Java SortedSet addAll()用法及代码示例
- Java Collection addAll()用法及代码示例
- Java AbstractCollection addAll()用法及代码示例
- Java List addAll()用法及代码示例
- Java LinkedBlockingDeque addAll()用法及代码示例
- Java AbstractSequentialList addAll()用法及代码示例
- Java Collections addAll()用法及代码示例
- Java CopyOnWriteArraySet addAll()用法及代码示例
- Java CopyOnWriteArrayList addAll()用法及代码示例
- Java ConcurrentLinkedDeque addAll()用法及代码示例
注:本文由纯净天空筛选整理自gopaldave大神的英文原创作品 AbstractQueue addAll() method in Java with examples。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。