Java中的LinkedBlockingQueue迭代器(iterator())方法

Java中的LinkedBlockingQueue迭代器(iterator())方法

LinkedBlockingQueue的 iterator() 方法返回一个迭代器,这个迭代器包含与该LinkedBlockingQueue相同的元素,并按正确的顺序排列。从该方法返回的元素包含LinkedBlockingQueue的 first(head)last(tail) 之间的所有元素。返回的迭代器是弱一致性的。

语法:

public Iterator<E> iterator()

返回值: 该方法返回迭代器,其元素与LinkedBlockingQueue中的元素相同,按照从first(head)到last(tail)的顺序排列。

下面的程序说明了LinkedBlockingQueue类的iterator()方法:

程序 1: 创建从包含班级不同学生名称的LinkedBlockingQueue中创建迭代器。

// Java程序演示LinkedBlockingQueue的iterator()方法
 
import java.util.concurrent.LinkedBlockingQueue;
import java.util.Iterator;
 
public class GFG {
 
    public static void main(String[] args)
    {
        // 定义LinkedBlockingQueue的容量
        int capacityOfQueue = 7;
 
        // 创建LinkedBlockingQueue的对象
        LinkedBlockingQueue<String> linkedQueue
            = new LinkedBlockingQueue<String>(capacityOfQueue);
 
        // 将元素添加到LinkedBlockingQueue中
        linkedQueue.add("John");
        linkedQueue.add("Tom");
        linkedQueue.add("Clark");
        linkedQueue.add("Kat");
 
        // 使用iterator()方法创建linkedQueue的迭代器
        Iterator<String> listOfNames = linkedQueue.iterator();
 
        // 打印结果
        System.out.println("list of names:");
        while (listOfNames.hasNext())
            System.out.println(listOfNames.next());
    }
}

输出:

list of names:
John
Tom
Clark
Kat

Program 2: 创建从包含员工名单的LinkedBlockingQueue中创建迭代器。

// Java程序演示iterator()方法的使用
// LinkedBlockingQueue
 
import java.util.concurrent.LinkedBlockingQueue;
import java.util.Iterator;
 
public class GFG {
 
    public void collectIterator()
    {
        // 定义LinkedBlockingQueue的容量
        int capacityOfQueue = 7;
 
        // 创建LinkedBlockingQueue对象
        LinkedBlockingQueue<Employee> linkedQueue
            = new LinkedBlockingQueue<Employee>(capacityOfQueue);
 
        // 将对象添加到LinkedBlockingQueue
        Employee emp1 = new Employee("Sachin", "Developer", "39000");
        Employee emp2 = new Employee("Sanjeev", "Tester", "26000");
 
        // 将Employee对象添加到linkedQueue中
        linkedQueue.add(emp1);
        linkedQueue.add(emp2);
 
        // 使用iterator()方法创建linkedQueue的迭代器
        Iterator<Employee> listOfEmployee = linkedQueue.iterator();
 
        // 打印迭代器的结果
        System.out.println("职员列表:");
        while (listOfEmployee.hasNext()) {
            System.out.println("*************************");
            Employee emp = listOfEmployee.next();
            System.out.println("职员姓名 : " + emp.name);
            System.out.println("职员职位 : " + emp.position);
            System.out.println("职员工资 : " + emp.salary);
        }
    }
 
    // 创建一个Employee对象,包括姓名、职位和薪资属性
    public class Employee {
 
        public String name;
        public String position;
        public String salary;
 
        Employee(String name, String position, String salary)
        {
            this.name = name;
            this.position = position;
            this.salary = salary;
        }
 
        @Override
        public String toString()
        {
            return "Employee [name=" + name + ", position="
                + position + ", salary=" + salary + "]";
        }
    }
 
    // 主方法
    public static void main(String[] args)
    {
        GFG gfg = new GFG();
        gfg.collectIterator();
    }
}

输出:

职员列表:
*************************
职员姓名 : Sachin
职员职位 : Developer
职员工资 : 39000
*************************
职员姓名 : Sanjeev
职员职位 : Tester
职员工资 : 26000

参考资料: https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/LinkedBlockingQueue.html#iterator–

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程