大家好,我是鸭鸭!
最近刷到 AMD 裁员的新闻!
新闻公布的消息,AMD 这次将在全球裁员 4%。按照 AMD 去年提交给美国证券交易委员会的文件数据显示,AMD 在全球拥有约 26000 名员工,也就是说,有约 1000 人将在这次裁员中失去工作。
虽然 AMD 并未透露有哪些部门受到影响,不过鸭鸭从评论区吃到的瓜,这次中国、美国、新加坡等地区都有员工被裁。
据说国内就裁 3 天,这周二到周四如果没有收到通知,那就是躲过一劫。(正好可以 v 鸭鸭 50 压压惊~)
国内的补偿方案也已经出炉,员工可以在 N+1 的基础上额外获得 2 个月基础工资,公司还会继续缴纳社保到年底。
这次裁员或许是受到第三季度财报公布后,嵌入式芯片和游戏芯片收入下降,研发成本上升影响,加上近期 AMD 股价持续下跌。
不过这并不一定意味着 AMD 在收缩业务,作为全球第二大 GPU 生产商,AMD 仍在努力追赶市场巨头英伟达,按理说此时正是用人之际。
AMD 现在还在印度建研发中心呢,鸭鸭觉得,主要还是在内部调整。
……
最近几个月不少企业加入了裁员的行列。不管是工作还是求职的小伙伴,都不要停下学习,时刻保持成长,才能更好地在职场生存。
今天鸭鸭也从面试鸭里为大家准备好了题目:
栈和队列在 Java 中的区别是什么?
回答重点
栈(Stack):遵循后进先出(LIFO,Last In, First Out)原则。即,最后插入的元素最先被移除。主要操作包括 push
(入栈)和 pop
(出栈)。Java 中的 Stack
类(java.util.Stack
)实现了这个数据结构。
队列(Queue):遵循先进先出(FIFO,First In, First Out)原则。即,最早插入的元素最先被移除。主要操作包括 enqueue
(入队)和 dequeue
(出队)。Java 中的 Queue
接口(java.util.Queue
)提供了此数据结构的实现,如 LinkedList
和 PriorityQueue
。
使用场景:
- 栈:常用于函数调用、表达式求值、回溯算法(如深度优先搜索)等场景。
- 队列:常用于任务调度、资源管理、数据流处理(如广度优先搜索)等场景。
扩展知识
栈的变体:
- 双端队列(Deque):支持在两端插入和删除元素,可以用作栈或队列。
java.util.ArrayDeque
和java.util.LinkedList
都实现了Deque
接口,提供了栈和队列的功能。
队列的变体:
- 优先队列(PriorityQueue):队列中的元素按优先级排序,而不是按插入顺序。适用于需要按优先级处理任务的场景。
- 阻塞队列(BlockingQueue):支持阻塞操作,特别适合多线程环境中的生产者-消费者问题。常用实现包括
ArrayBlockingQueue
、LinkedBlockingQueue
和PriorityBlockingQueue
。