dequeue java_Java中的Dueue和Deque

队列(queue)是一种常用的数据结构,可以将队列看做是一种特殊的线性表,该结构遵循的先进先出原则。Java中,LinkedList实现了Queue接口,因为LinkedList进行插入、删除操作效率较高

相关常用方法:

boolean offer(E e):将元素追加到队列末尾,若添加成功则返回true。

E poll():从队首删除并返回该元素。

E peek():返回队首元素,但是不删除

public class QueueDemo {

public static void main(String [] args) {

Queue queue = new LinkedList();

//追加元素

queue.offer("one");

queue.offer("two");

queue.offer("three");

queue.offer("four");

System.out.println(queue);

//从队首取出元素并删除

String poll = queue.poll();

System.out.println(poll);

System.out.println(queue);

//从队首取出元素但是不删除

String peek = queue.peek();

System.out.println(peek);

System.out.println(queue);

//遍历队列,这里要注意,每次取完元素后都会删除,整个

//队列会变短,所以只需要判断队列的大小即可

while(queue.size() > 0) {

System.out.println(queue.poll());

}

}

}

运行结果:

[one, two, three, four]

one

[two, three, four]

two

[two, three, four]

two

three

four

双向队列(Deque),是Queue的一个子接口,双向队列是指该队列两端的元素既能入队(offer)也能出队(poll),如果将Deque限制为只能从一端入队和出队,则可实现栈的数据结构。对于栈而言,有入栈(push)和出栈(pop),遵循先进后出原则

常用方法如下:

void push(E e):将给定元素”压入”栈中。存入的元素会在栈首。即:栈的第一个元素

E pop():将栈首元素删除并返回。

public class DequeDemo {

public static void main(String[] args) {

Deque deque = new LinkedList();

deque.push("a");

deque.push("b");

deque.push("c");

System.out.println(deque);

//获取栈首元素后,元素不会出栈

String str = deque.peek();

System.out.println(str);

System.out.println(deque);

while(deque.size() > 0) {

//获取栈首元素后,元素将会出栈

System.out.println(deque.pop());

}

System.out.println(deque);

}

}

运行结果:

[c, b, a]

c

[c, b, a]

c

b

a

[]

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`crypto_dequeue_request` 函数的功能是密码算法请求队列取出一个请求对象。 以下是该函数的定义: ```c static inline struct crypto_async_request *crypto_dequeue_request(struct crypto_queue *queue) { struct crypto_async_request *req; if (queue->qlen == 0) { return NULL; // 如果队列为空,返回 NULL } req = container_of(queue->head.next, struct crypto_async_request, list); list_del(&req->list); queue->qlen--; return req; } ``` 该函数接受一个参数: - `struct crypto_queue *queue`:表示密码算法请求队列的指针。它指定了要从取出请求对象的队列。 函数的功能是从队列取出一个请求对象,并将其从队列删除。如果队列为空,则返回 `NULL`。 在函数内部,首先检查队列的 `qlen` 成员是否为 0,如果是则表示队列为空,直接返回 `NULL`。 如果队列不为空,函数使用 `container_of` 宏根据队列头部的 `next` 成员获取对应的 `struct crypto_async_request` 结构体的指针。这个结构体包含了请求对象的信息。 接下来,使用 `list_del` 函数将请求对象从队列删除,并将队列的 `qlen` 成员减少 1。 最后,函数返回获取到的请求对象的指针。 总之,`crypto_dequeue_request` 函数用于从密码算法请求队列取出一个请求对象,并将其从队列删除。如果队列为空,则返回 `NULL`。 希望以上解释能够帮助您理解 `crypto_dequeue_request` 函数的功能和定义。如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值