今天时间学习LinkedTransferQueue api,该类是JUC原子包中的类,通过单元测试代码把所有public api方法跑了一遍,大致了解了底层实现,初学乍练,有很多一知半解的地方,待后续有了深入理解再来补充
package test.java.util.concurrent;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;
import java.util.Spliterator;
import java.util.concurrent.LinkedTransferQueue;
import java.util.concurrent.TimeUnit;
import org.junit.Test;
/**
* LinkedTransferQueue的测试类
*
* @date 2020-07-26 22:43:51
*/
public class LinkedTransferQueueTest {
/**
*无参构造函数
* @Param
*/
@Test
public void testConstruct0()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
System.out.println(testObj.toString());
}
/**
*通过集合初始化阻塞队列
* @Param
*/
@Test
public void testConstruct1()throws Exception{
Set<String> set=new HashSet<>();
set.add("32");
LinkedTransferQueue testObj=new LinkedTransferQueue(set);
System.out.println(testObj.poll());
System.out.println(testObj.poll());
}
/**
*通过拆分器遍历队列中所有元素
* @Param
*/
@Test
public void testSpliterator()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer("3213");
testObj.offer("3111");
testObj.offer("3222");
testObj.offer("3333");
Spliterator<String> spliterator=testObj.spliterator();
spliterator.forEachRemaining(s -> System.out.println(s));
}
/**
*存入元素
* @Param
*/
@Test
public void testPut()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.put(333);
testObj.put(33);
System.out.println(testObj.take());
System.out.println(testObj.take());
System.out.println(testObj.take());
}
/**
*如果队列已满,等待指定时间
* @Param
*/
@Test
public void testOffer()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(3333,3, TimeUnit.SECONDS);
testObj.offer(33,3,TimeUnit.SECONDS);
System.out.println(testObj.peek());
System.out.println(testObj.peek());
System.out.println(testObj.peek());
}
/**
*放入队列元素
* @Param
*/
@Test
public void testOffer1()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(3333);
testObj.offer(33);
System.out.println(testObj.peek());
System.out.println(testObj.peek());
System.out.println(testObj.peek());
}
/**
* 添加元素
* @Param
*/
@Test
public void testAdd()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.add(33);
System.out.println(testObj.poll());
System.out.println(testObj.poll());
}
/**
* 直接转移给等待的消费者,如果没有则返回false,不放入队列
* @Param
*/
@Test
public void testTryTransfer()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
System.out.println(testObj.tryTransfer(222));
System.out.println(testObj.poll());
}
/**
* 将元素转移给消费者,如果需要的话等待。
* @Param
*/
@Test
public void testTransfer()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.transfer(3);
System.out.println(testObj.poll());
}
/**
* 将元素转移给消费者,如果需要的话等待指定时间
* @Param
*/
@Test
public void testTryTransfer1()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.tryTransfer(3,1,TimeUnit.SECONDS);
System.out.println(testObj.poll());
}
/**
*阻塞式获取元素
* @Param
*/
@Test
public void testTake()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.put(2);
System.out.println(testObj.take());
System.out.println(testObj.take());
}
/**
* 弹出元素
* @Param
*/
@Test
public void testPoll()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.put(2);
System.out.println(testObj.poll());
System.out.println(testObj.poll());
}
/**
* 在指定时间内弹出
* @Param
*/
@Test
public void testPoll1()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.put(2);
System.out.println(testObj.poll(1,TimeUnit.SECONDS));
System.out.println(testObj.poll(1,TimeUnit.SECONDS));
}
/**
*将队列中元素一次性拷贝到指定集合中,并返回大小
* @Param
*/
@Test
public void testDrainTo()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(3333);
System.out.println(testObj.drainTo(new HashSet()));
}
/**
*将队列中元素一次性拷贝到指定集合中,并返回大小,最多存入指定元素数量
* @Param
*/
@Test
public void testDrainTo1()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(1111);
testObj.offer(0000);
testObj.offer(5555);
testObj.offer(6666);
testObj.offer(4444);
System.out.println(testObj.drainTo(new HashSet(),3));
}
/**
*通过迭代器遍历
* @Param
*/
@Test
public void testIterator()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(3333);
testObj.offer(2222);
Iterator iterator=testObj.iterator();
while (iterator.hasNext()){
System.out.println(iterator.next());
}
}
/**
* 获取头部元素
* @Param
*/
@Test
public void testPeek()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(3333);
testObj.offer(2222);
System.out.println(testObj.peek());
System.out.println(testObj.peek());
System.out.println(testObj.peek());
}
/**
*
* @Param
*/
@Test
public void testIsEmpty()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(3333);
testObj.offer(2222);
System.out.println(testObj.isEmpty());
}
/**
* 查看是否有等待的消费者
* @Param
*/
@Test
public void testHasWaitingConsumer()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(3333);
testObj.offer(2222);
System.out.println(testObj.hasWaitingConsumer());
System.out.println(testObj.peek());
}
/**
*获取队列大小
* @Param
*/
@Test
public void testSize()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(3333);
testObj.offer(2222);
System.out.println(testObj.size());
}
/**
* 获取等待的消费者数量
* @Param
*/
@Test
public void testGetWaitingConsumerCount()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(3333);
testObj.offer(2222);
System.out.println(testObj.getWaitingConsumerCount());
}
/**
* 移除指定元素
* @Param
*/
@Test
public void testRemove()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(3333);
testObj.offer(2222);
testObj.remove(2222);
System.out.println(testObj.size());
}
/**
*是否包含
* @Param
*/
@Test
public void testContains()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(3333);
testObj.offer(2222);
System.out.println(testObj.contains(2222));
}
/**
* 剩余容量
* @Param
*/
@Test
public void testRemainingCapacity()throws Exception{
LinkedTransferQueue testObj=new LinkedTransferQueue();
testObj.offer(3333);
testObj.offer(2222);
System.out.println(testObj.remainingCapacity());
}
}