c++11 std::ref使用场景

C++本身有引用(&),为什么C++11又引入了std::ref?

主要是考虑函数式编程(如std::bind)在使用时,是对参数直接拷贝,而不是引用。如下例子:

#include <functional>
#include <iostream>

void f(int& n1, int& n2, const int& n3)
{
    std::cout << "In function: " << n1 << ‘ ‘ << n2 << ‘ ‘ << n3 << ‘\n‘;
    ++n1; // increments the copy of n1 stored in the function object
    ++n2; // increments the main()‘s n2
    // ++n3; // compile error
}

int main()
{
    int n1 = 1, n2 = 2, n3 = 3;
    std::function<void()> bound_f = std::bind(f, n1, std::ref(n2), std::cref(n3));
    n1 = 10;
    n2 = 11;
    n3 = 12;
    std::cout << "Before function: " << n1 << ‘ ‘ << n2 << ‘ ‘ << n3 << ‘\n‘;
    bound_f();
    std::cout << "After function: " << n1 << ‘ ‘ << n2 << ‘ ‘ << n3 << ‘\n‘;
}

Output:

Output:
Before function: 10 11 12
In function: 1 11 12
After function: 10 12 12

上述代码在执行std::bind后,在函数f()中n1的值仍然是1,n2和n3改成了修改的值。说明std::bind使用的是参数的拷贝而不是引用。具体为什么std::bind不使用引用,可能确实有一些需求,使得C++11的设计者认为默认应该采用拷贝,如果使用者有需求,加上std::ref即可。

原文地址:https://www.cnblogs.com/moodlxs/p/10111609.html

时间: 2024-08-29 21:55:42

c++11 std::ref使用场景的相关文章

c++11 std::ref std::cref

参考: C++已经有了引用操作符&为什么C++11还要引入std:ref std::ref和std::cref使用 &是类型说明符,而std::ref是一个函数,返回std::reference_wrapper(类似于指针) 为什么需要std::ref?(std::cref类似) 主要是考虑到c++11中的函数式编程,例如:std::bind std::bind在使用时,是对参数直接拷贝,而不是引用 发现这个问题的契机是在使用thread的标准库时 #include<iostream

深入浅出 c++11 std::async

c++11中增加了线程,使得我们可以非常方便的创建线程,它的基本用法是这样的: void f(int n); std::thread t(f, n + 1); t.join(); 但是线程毕竟是属于比较低层次的东西,有时候使用有些不便,比如我希望获取线程函数的返回结果的时候,我就不能直接通过 thread.join()得到结果,这时就必须定义一个变量,在线程函数中去给这个变量赋值,然后join,最后得到结果,这个过程是比较繁琐的. c++11还提供了异步接口std::async,通过这个异步接口

std::ref() 与 &amp;

引言 之前因为调整样式把博客园的样式毁了,所以一直在自己的另一个博客上更新,有兴趣的可以去观望一下:http://blog.yunlambert.top/最近还是把博客园拾起来吧..... 最近看到一个多线程代码如下: typedef unsigned long long ULL; void accumulator_function(const std::vector<int> &v, ULL &acm, unsigned int beginIndex, unsigned in

Redis能干啥?细看11种Web应用场景

2011-07-25 10:38 贾隆 51CTO.com 字号:T | T Redis的一个很大好处就是可以不用整个转入到这个数据库,而是可以沿用之前的MySQL等数据库,而仅在一些特定的应用场景通过Redis的特性提高效率.本文列出了11个这样的Web应用场景,如显示最新的项目列表.删除和过滤.排行榜等相关需求. AD: [51CTO精选译文]在“怎样让Redis在你的系统中发挥作用”一文中,Salvatore 'antirez’ Sanfilippo告诉我们如何利用Redis独有的数据结构

C++11 std::chrono库详解

所谓的详解只不过是参考www.cplusplus.com的说明整理了一下,因为没发现别人有详细讲解. chrono是一个time library, 源于boost,现在已经是C++标准.话说今年似乎又要出新标准了,好期待啊! 要使用chrono库,需要#include<chrono>,其所有实现均在std::chrono namespace下.注意标准库里面的每个命名空间代表了一个独立的概念.所以下文中的概念均以命名空间的名字表示! chrono是一个模版库,使用简单,功能强大,只需要理解三个

C++11 std::function用法(c++常问问题十七)

C++11 std::function用法 直接上代码: 例子1:std::function的感觉就像是函数指针那样有木有 #include <iostream> #include <functional> #include <map> using namespace std; // 普通函数 int add(int i, int j) { return i + j; } //lambda表达式 auto mod = [](int i, int j){return i

c++11 std::next 与auto 使用

auto 定义变量时放在变量前,无需知道具体变量类型,系统可自行推断类型,减少编程工作,特别是在模板使用时,使用更方便. 下面简单例子: 1 auto a=1; 2 auto b='a'; 3 auto s="abdc"; 4 auto c;//这样使用时错误的,系统无法自动推断出变量类型 5 //下面为迭代指针使用,很方便 6 vector<int> vec; 7 auto it=vec.begin(); 模板使用例子: 1 template<typename In

Redis 11种Web应用场景举例

在"怎样让redis在你的系统中发挥作用"一文中,salvatore 'antirez' sanfilippo告诉我们如何利用redis独有的数据结构处理能力来解决一些常见问题.一些redis原语命令比如lpush.ltrim和lrem等等能够用来帮助开发者完成需要的任务--这些任务在传统的数据库存储中非常困难或缓慢.这是一篇非常有用并且实际的文章.那么要如何在你的框架中完成这些任务呢? 下面列出11种web应用场景,在这些场景下可以充分的利用redis的特性,大大提高效率. 1.在主

C++11 std::unique_lock与std::lock_guard区别及多线程应用实例

C++11 std::unique_lock与std::lock_guard区别及多线程应用实例 C++多线程编程中通常会对共享的数据进行写保护,以防止多线程在对共享数据成员进行读写时造成资源争抢导致程序出现未定义的行为.通常的做法是在修改共享数据成员的时候进行加锁--mutex.在使用锁的时候通常是在对共享数据进行修改之前进行lock操作,在写完之后再进行unlock操作,进场会出现由于疏忽导致由于lock之后在离开共享成员操作区域时忘记unlock,导致死锁. 针对以上的问题,C++11中引