/*
* make_shared
*/
描述 (Description)
它构造一个T类型的对象,将args传递给它的构造函数,并返回一个shared_ptr类型的对象拥有并存储指向它的指针。
声明 (Declaration)
以下是std :: make_shared的声明。
template <class T, class... Args>
shared_ptr<T> make_shared (Args&&... args);
C++11
template <class T, class... Args>
shared_ptr<T> make_shared (Args&&... args);
参数 (Parameters)
args - 它是零个或多个类型的列表。
返回值 (Return Value)
它返回一个shared_ptr对象。
异常 (Exceptions)
noexcep - 它不会抛出任何异常。
在动态内存中分配一个对象并初始化它, 返回指向此对象的 shared_ptr,与智能指针一样,make_shared定义在头文件memory中.
构造函数是保护或私有时,无法使用 make_shared。
/*
* example
*/
int main ()
{
std::shared_ptr<int> foo = std::make_shared<int> (100);
std::shared_ptr<int> foo2 (new int(100));
auto bar = std::make_shared<int> (200);
auto baz = std::make_shared<std::pair<int,int>> (300,400);
std::cout << "*foo: " << *foo << '\n';
std::cout << "*bar: " << *bar << '\n';
std::cout << "*baz: " << baz->first << ' ' << baz->second << '\n';
/* 实际项目中使用 */
// pHdl = std::make_shared<sdk_functions::RecvSyncData>(_rIp); /* RecvSyncData 是一个类 */
return 0;
}
/*
*foo: 100
*bar: 200
*baz: 300 400
*/