博客
关于我
std::swap C++11示例
阅读量:278 次
发布时间:2019-03-01

本文共 1331 字,大约阅读时间需要 4 分钟。

C++11 中的std::swap

header	// moved from 
to
in C++11non-array (1) template
void swap (T& a, T& b) noexcept (is_nothrow_move_constructible
::value && is_nothrow_move_assignable
::value);array (2) template
void swap(T (&a)[N], T (&b)[N]) noexcept (noexcept(swap(*a,*b)));

注意:

Type T shall be move-constructible and move-assignable (or have swap defined for it, for version (2)).

std::swap 在C++11中定义在,而不再是头文件中。上述两个函数等效为:

template 
void swap (T& a, T& b){ T c(std::move(a)); a=std::move(b); b=std::move(c);}template
void swap (T (&a)[N], T (&b)[N]){ for (size_t i = 0; i

示例:

// swap algorithm example (C++98)#include 
// std::cout#include
// std::swap#include
// std::vectorint main () { int x=10, y=20; // x:10 y:20 std::swap(x,y); // x:20 y:10 std::vector
foo (4,x), bar (6,y); // foo:4个20 bar:6个10 std::swap(foo,bar); // foo:6个10 bar:4个20 std::cout << "foo contains:"; for (std::vector
::iterator it=foo.begin(); it!=foo.end(); ++it) std::cout << ' ' << *it; std::cout << '\n'; return 0;}
foo contains: 10 10 10 10 10 10

转载地址:http://xkqx.baihongyu.com/

你可能感兴趣的文章
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
mysql union orderby 无效
查看>>
mysql where中如何判断不为空
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>
MySQL _ MySQL常用操作
查看>>
MySQL – 导出数据成csv
查看>>
MySQL —— 在CentOS9下安装MySQL
查看>>
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>