priority_queue::priority_queue (STL/CLR)

构造容器适配器对象。

    priority_queue();
    priority_queue(priority_queue<Value, Container> right);
    priority_queue(priority_queue<Value, Container> right);
    explicit priority_queue(value_compare^ pred);
    priority_queue(value_compare^ pred, container_type% cont);
    template<typename InIt>
        priority_queue(InIt first, InIt last);
    template<typename InIt>
        priority_queue(InIt first, InIt last,
            value_compare^ pred);
    template<typename InIt>
        priority_queue(InIt first, InIt last,
            value_compare^ pred, container_type% cont);

参数

  • 继续
    复制的容器。

  • 首先
    范围开头插入的。

  • last
    范围的末尾插入的。

  • pred
    控件序列的排序的性质。

  • right
    对象或范围插入。

备注

构造函数:

priority_queue();

使用默认排序的谓词创建一个空的包装,容器。 使用它指定空的初始控件序列,其默认值为排序的性质。

构造函数:

priority_queue(priority_queue<Value, Container>% right);

使用排序的谓词 right.value_comp()创建一 right.get_container()副本的一个包装,容器。 将它指定为的复制序列控件由队列对象 right的初始控件序列,与同一排序的性质。

构造函数:

priority_queue(priority_queue<Value, Container>^ right);

使用排序的谓词 right->value_comp()创建一 right->get_container()副本的一个包装,容器。 将它指定为的复制序列控件由队列对象 *right的初始控件序列,与同一排序的性质。

构造函数:

explicit priority_queue(value_compare^ pred);

使用排序的谓词 pred创建一个空的包装,容器。 使用它指定空的初始控件序列,与指定的排序的性质。

构造函数:

priority_queue(value_compare^ pred, container_type cont);

使用排序的谓词 pred创建一个空的包装容器,驱动器,然后将它指定从现有的容器的初始控件 cont 序列的所有元素,与指定的排序的性质。

构造函数:

template<typename InIt>

priority_queue(InIt first, InIt last);

使用默认排序的谓词创建一个空的包装,容器,然后按顺序 [first,last)。 您使用它来指定从指定的 eqeuence 的初始控件序列,与指定的排序的性质。

构造函数:

template<typename InIt>

priority_queue(InIt first, InIt last,

value_compare^ pred);

使用排序的谓词 pred创建一个空的包装,容器,然后按顺序 [first,last)。 您使用它来指定从指定的 seqeuence 的初始控件序列,与指定的排序的性质。

构造函数:

template<typename InIt>

priority_queue(InIt first, InIt last,

value_compare^ pred, container_type% cont);

使用排序的谓词 pred创建一个空的包装,容器,然后驱动器 cont 的所有元素以及顺序 [first,last)。 您使用它来指定从现有的容器和指定的 seqeuence 的初始控件序列,与指定的排序的性质。

示例

// cliext_priority_queue_construct.cpp 
// compile with: /clr 
#include <cliext/queue> 
#include <cliext/deque> 
 
typedef cliext::priority_queue<wchar_t> Mypriority_queue; 
typedef cliext::deque<wchar_t> Mydeque; 
int main() 
    { 
// construct an empty container 
    Mypriority_queue c1; 
    Mypriority_queue::container_type^ wc1 = c1.get_container(); 
    System::Console::WriteLine("size() = {0}", c1.size()); 
 
    c1.push(L'a'); 
    c1.push(L'b'); 
    c1.push(L'c'); 
    for each (wchar_t elem in wc1) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct with an ordering rule 
    Mypriority_queue c2 = cliext::greater<wchar_t>(); 
    System::Console::WriteLine("size() = {0}", c2.size()); 
 
    for each (wchar_t elem in wc1) 
        c2.push(elem); 
    for each (wchar_t elem in c2.get_container()) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct with an ordering rule by copying an underlying container 
    Mypriority_queue c2x = 
        gcnew Mypriority_queue(cliext::greater<wchar_t>(), *wc1); 
   for each (wchar_t elem in c2x.get_container()) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct with an iterator range 
    Mypriority_queue c3(wc1->begin(), wc1->end()); 
    for each (wchar_t elem in c3.get_container()) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct with an iterator range and an ordering rule 
    Mypriority_queue c4(wc1->begin(), wc1->end(), 
        cliext::greater<wchar_t>()); 
    for each (wchar_t elem in c4.get_container()) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct with an iterator range, another container, and an ordering rule 
    Mypriority_queue c5(wc1->begin(), wc1->end(), 
        cliext::greater<wchar_t>(), *wc1); 
    for each (wchar_t elem in c5.get_container()) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct from a generic container 
    Mypriority_queue c6(c3); 
    for each (wchar_t elem in c6.get_container()) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct by copying another container 
    Mypriority_queue c7(%c3); 
    for each (wchar_t elem in c7.get_container()) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
// construct with an ordering rule, by copying an underlying container 
    Mypriority_queue c8 = 
        gcnew Mypriority_queue(cliext::greater<wchar_t>(), *wc1); 
    for each (wchar_t elem in c8.get_container()) 
        System::Console::Write(" {0}", elem); 
    System::Console::WriteLine(); 
 
    return (0); 
    } 
 
  

要求

标题: <cliext/队列>

命名空间: cliext

请参见

参考

priority_queue (STL/CLR)

priority_queue::assign (STL/CLR)

priority_queue::generic_container (STL/CLR)

priority_queue::operator= (STL/CLR)