队列

作者: 点滴86 | 来源:发表于2024-07-25 22:59 被阅读0次

如何理解”队列“

队列这个概念非常好理解。可以把它想象成排队买票,先来的先买,后来的人只能站末尾,不允许插队。先进者先出,这就是典型的“队列”。
栈只支持两个基本操作:入栈push和出栈pop。队列跟栈非常相似,支持的操作也很有限,最基本的操作也是两个:入队enqueue,放一个数据到队列的末尾;出队dequeue,从队列的头部取一个元素。


队列跟栈一样,也是一种操作受限的线性表数据结构。

队列的实现

@interface DMQueue<ObjectType> : NSObject

// 入队列
- (void)enqueue:(ObjectType)aObject;

// 出队列
- (ObjectType)dequeue;

@end

@interface DMQueue ()

@property (nonatomic, strong) NSMutableArray *mArray;

@end

@implementation DMQueue

- (void)enqueue:(id)aObject
{
    [self.mArray addObject:aObject];
}

- (id)dequeue
{
    id aObject = nil;
    if ([self isEmpty] == NO) {
        aObject = [self.mArray objectAtIndex:0];
        [self.mArray removeObjectAtIndex:0];
    }
    return aObject;
}

- (BOOL)isEmpty
{
    BOOL bFlag = NO;
    if ([self.mArray count] == 0) {
        bFlag = YES;
    }
    return bFlag;
}

- (NSMutableArray *)mArray
{
    if (_mArray == nil) {
        _mArray = [[NSMutableArray alloc] init];
    }
    return _mArray;
}

@end

@interface DMQueueDemo : NSObject

@end

@implementation DMQueueDemo

- (void)demo
{
    DMQueue<NSString *> *aQueue = [[DMQueue<NSString *> alloc] init];
    [aQueue enqueue:@"Welcome"];
    [aQueue enqueue:@"To"];
    [aQueue enqueue:@"BeiJing"];
    
    NSLog(@"%@", [aQueue dequeue]);
    NSLog(@"%@", [aQueue dequeue]);
    NSLog(@"%@", [aQueue dequeue]);
}

@end

相关文章

  • 队列

    队列特性 对比队列和栈 基于数组的队列 对比队列学习循环队列 循环队列难点 阻塞队列 并发队列 应用:线程池中拒绝...

  • 队列

    文章结构 什么是队列 实现队列顺序队列链式队列循环队列 Java中的队列 1. 什么是队列 队列也是一种操作受限的...

  • iOS底层-- GCD源码分析(1)-- dispatch_qu

    手动目录认识队列队列的结构队列的产生主队列全局队列创建的队列管理队列 代码版本dispatch version :...

  • 队列,异步,同步,线程通俗理解

    一、队列 串行队列 并行队列 主队列(只在主线程执行的串行队列) 全局队列(系统的并行队列) 二、 任务(是否具有...

  • GCD基础总结一

    上代码~ 同步串行队列 同步并行队列 异步串行队列 异步并行队列 主队列同步 会卡住 主队列异步

  • OC多线程

    队列创建 线程与队列 队列线程间通信 队列组

  • GCD

    获得主队列 获得全局队列 串行队列 异步队列 同步队列 阻隔队列 (像栅栏一样 ) 例如 A -->栅栏 --...

  • 数据结构第三篇 队列

    队列的特性 前进先出。 我们来大致描述下进出队列的情况。 进队列 1 进队列现在队列是 12 进队列现在队列是 1...

  • 利用链表实现队列

    队列成员变量: 队列长度 队列头节点 队列尾节点队列方法: 队列包含元素个数 队列是否为空 进队操作 出队操作 d...

  • Git 常用操作命令(持续更新)

    当前更新到stash队列 查看stash队列 清空队列 删除某个队列

网友评论

      本文标题:队列

      本文链接:https://www.haomeiwen.com/subject/uymmhjtx.html