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

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

C++11中的std::swap函数是一个强大的工具,它在

头文件中定义。这个函数用于高效地交换两个对象的内容,而无需显式创建临时变量。

std::swap的两个版本

std::swap函数有两个版本:

  • 非数组版本

    模板函数定义为:

    template
    void swap(t& a, t& b) noexcept( is_nothrow_move_constructible
    ::value && is_nothrow_move_assignable
    ::value);

    这个版本用于交换两个对象的内容。它利用了移动构造和移动赋值的特性,确保交换过程不会导致异常。

  • 数组版本

    另一个版本用于交换两个数组的内容:

    template
    void swap( t (&a)[n], t (&b)[n]) noexcept(noexcept(swap(*a, *b)));

    这个版本适用于数组类型,确保在交换数组时不会抛出异常。

  • std::swap的实现原理

    std::swap函数的实现通常依赖于移动操作。对于非数组版本,交换操作可以通过以下步骤完成:

  • 创建一个临时对象c,使用std::move移动a的内容。
  • 将b的内容移动到a中。
  • 将c的内容移动到b中。
  • 这种方法确保了操作的高效性和安全性。

    注意事项

    在使用std::swap时,需确保交换的类型T具备以下特性:

    • 移动构造可抛出:即T可以通过移动操作创建而不导致异常。
    • 移动赋值可抛出:即T可以通过移动操作赋值而不导致异常。
    • (对于版本(2)):交换数组时,T必须定义swap函数。

    示例

    以下是一个使用std::swap的示例:

    #include 
    #include
    int main() { int x = 10, y = 20; std::swap(x, y); // x和y交换内容 std::vector
    foo(4, x), bar(6, y); // foo包含4个20,bar包含6个10 std::swap(foo, bar); // foo和bar交换内容 // foo现在包含6个10,bar包含4个20}

    这个示例展示了如何在实际应用中使用std::swap来高效交换对象和数组的内容。

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

    你可能感兴趣的文章
    SQL-CLR 类型映射 (LINQ to SQL)
    查看>>
    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
    查看>>
    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
    查看>>
    org.springframework.web.multipart.MaxUploadSizeExceededException: Maximum upload size exceeded
    查看>>
    org.tinygroup.serviceprocessor-服务处理器
    查看>>
    org/eclipse/jetty/server/Connector : Unsupported major.minor version 52.0
    查看>>
    org/hibernate/validator/internal/engine
    查看>>
    SQL-36 创建一个actor_name表,将actor表中的所有first_name以及last_name导入改表。
    查看>>
    ORM sqlachemy学习
    查看>>
    Ormlite数据库
    查看>>
    orm总结
    查看>>
    os.environ 没有设置环境变量
    查看>>
    os.path.join、dirname、splitext、split、makedirs、getcwd、listdir、sep等的用法
    查看>>
    os.system 在 Python 中不起作用
    查看>>
    OS2ATC2017:阿里研究员林昊畅谈操作系统创新与挑战
    查看>>
    OSCACHE介绍
    查看>>
    SQL--合计函数(Aggregate functions):avg,count,first,last,max,min,sum
    查看>>
    OSChina 周五乱弹 ——吹牛扯淡的耽误你们学习进步了
    查看>>
    SQL--mysql索引
    查看>>
    OSChina 周四乱弹 ——程序员为啥要买苹果手机啊?
    查看>>