std::make_pair的目的是什么?

为什么不直接做std::pair<int, char>(0, 'a')?

这两种方法有什么区别吗?


当前回答

Make_pair在直接构造函数上创建一个额外的副本。我总是对我的对进行类型定义,以提供简单的语法。 这显示了差异(Rampal Chaudhary的例子):

class Sample
{
    static int _noOfObjects;

    int _objectNo;
public:
    Sample() :
        _objectNo( _noOfObjects++ )
    {
        std::cout<<"Inside default constructor of object "<<_objectNo<<std::endl;
    }

    Sample( const Sample& sample) :
    _objectNo( _noOfObjects++ )
    {
        std::cout<<"Inside copy constructor of object "<<_objectNo<<std::endl;
    }

    ~Sample()
    {
        std::cout<<"Destroying object "<<_objectNo<<std::endl;
    }
};
int Sample::_noOfObjects = 0;


int main(int argc, char* argv[])
{
    Sample sample;
    std::map<int,Sample> map;

    map.insert( std::make_pair( 1, sample) );
    //map.insert( std::pair<int,Sample>( 1, sample) );
    return 0;
}

其他回答

值得注意的是,这是c++模板编程中常见的习惯用法。它被称为对象生成器成语,您可以在这里找到更多信息和一个很好的示例。

正如有人在评论中建议的那样(已删除),以下是对链接稍加修改的摘录,以防它中断。

对象生成器允许在不显式指定对象类型的情况下创建对象。它基于类模板所不具备的函数模板的一个有用属性:函数模板的类型形参是自动从其实际形参推导出来的。Std::make_pair是一个简单的例子,它根据Std::make_pair函数的实际参数返回Std::pair模板的实例。

template <class T, class U>
std::pair <T, U> 
make_pair(T t, U u)
{
  return std::pair <T, U> (t,u);
}

Make_pair在直接构造函数上创建一个额外的副本。我总是对我的对进行类型定义,以提供简单的语法。 这显示了差异(Rampal Chaudhary的例子):

class Sample
{
    static int _noOfObjects;

    int _objectNo;
public:
    Sample() :
        _objectNo( _noOfObjects++ )
    {
        std::cout<<"Inside default constructor of object "<<_objectNo<<std::endl;
    }

    Sample( const Sample& sample) :
    _objectNo( _noOfObjects++ )
    {
        std::cout<<"Inside copy constructor of object "<<_objectNo<<std::endl;
    }

    ~Sample()
    {
        std::cout<<"Destroying object "<<_objectNo<<std::endl;
    }
};
int Sample::_noOfObjects = 0;


int main(int argc, char* argv[])
{
    Sample sample;
    std::map<int,Sample> map;

    map.insert( std::make_pair( 1, sample) );
    //map.insert( std::pair<int,Sample>( 1, sample) );
    return 0;
}

从c++11开始,只对pair使用统一初始化。所以不要:

std::make_pair(1, 2);

or

std::pair<int, int>(1, 2);

只使用

{1, 2};

使用make_pair和显式地使用指定类型参数调用pair构造函数之间没有区别。当类型是verbose时,Std::make_pair更方便,因为模板方法具有基于给定参数的类型推断。 例如,

std::vector< std::pair< std::vector<int>, std::vector<int> > > vecOfPair;
std::vector<int> emptyV;

// shorter
vecOfPair.push_back(std::make_pair(emptyV, emptyV));

 // longer
vecOfPair.push_back(std::pair< std::vector<int>, std::vector<int> >(emptyV, emptyV));

正如@MSalters上面回答的那样,你现在可以在c++ 11中使用花括号来做到这一点(刚刚用c++ 11编译器验证了这一点):

pair<int, int> p = {1, 2};