File: queue1.cpp

package info (click to toggle)
libstxxl 1.4.0-3
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 5,256 kB
  • ctags: 6,830
  • sloc: cpp: 39,594; ansic: 4,217; perl: 566; sh: 555; xml: 174; makefile: 21
file content (41 lines) | stat: -rw-r--r-- 1,339 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
/***************************************************************************
 *  examples/containers/queue1.cpp
 *
 *  Part of the STXXL. See http://stxxl.sourceforge.net
 *
 *  Copyright (C) 2013 Daniel Feist <daniel.feist@student.kit.edu>
 *
 *  Distributed under the Boost Software License, Version 1.0.
 *  (See accompanying file LICENSE_1_0.txt or copy at
 *  http://www.boost.org/LICENSE_1_0.txt)
 **************************************************************************/

//! [example]
#include <stxxl/queue>
#include <iostream>

int main()
{
    typedef stxxl::queue<unsigned int> queue;
    queue my_queue;

    my_queue.push(5);
    my_queue.push(11);
    my_queue.push(3);
    my_queue.push(7);
    // my_queue now stores: |7|3|11|5|

    assert(my_queue.size() == 4);

    std::cout << "back element " << my_queue.back() << std::endl;   // prints out 7 (last inserted element)
    assert(my_queue.back() == 7);
    std::cout << "front element " << my_queue.front() << std::endl; // prints out 5 (first inserted element)
    assert(my_queue.front() == 5);
    my_queue.pop();                                                 // deletes element 5, queue now stores: |7|3|11|

    std::cout << "front element " << my_queue.front() << std::endl; // prints out 11
    assert(my_queue.front() == 11);

    return 0;
}
//! [example]