目录
2.3.2 使用placeholders::_x同样可以达到同样效果
1 为什么需要std::ref
根据【C++】stdref和stdcref_std::ref和std::cref-CSDN博客
等消息来源的描述,需要std::ref的场景主要是如下三种:
假如std::thread需要调用一个函数,且这个函数的输入参数是引用的话,则std::thread对这个参数的调用必须用ref修饰。
假如sid::bind需要调用一个函数,且这个函数的输入参数是引用的话,则std::bind对这个参数的调用必须用ref修饰。
stl库调用,比如for_each的输入参数里也可以有一个函数指针。假如这个函数的输入参数是一个引用,则函数指针也要用std::ref修饰。
下面通过几个实例来验证以上描述的真伪。代码运行的环境是vs2019
2 std::ref使用示例
2.1 std::thread调用
2.1.1 不使用std::ref,编译失败
// cref.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//
#include <iostream>
#include <functional>
#include <algorithm>
#include <vector>
#include <thread>
void func(int & a)
{
std::cout << "func before modifying a,b,c : a = " << a <<std::endl;
a *= 2;
}
int main()
{
std::cout << "Hello World!\n";
int a = 10;
std::thread thrd(&func, a);
thrd.join();
std::cout << "after modifying "<<a;
std::cin.get();
return 0;
}
2.1.2 使用std::ref修饰输入变量
2.2 stl库调用(以for_each 为例)
可见,只要函数(func)的输入参数是引用,不论用不用std::ref,效果都一样。
2.3 std::bind
2.3.1 使用std::ref
可见,变量a没有使用ref修饰,所以func函数对其不起作用;变量b,c用ref修饰,所以func函数起改变了它们的取值。
2.3.2 使用placeholders::_x同样可以达到同样效果
输入变量同样发生变化。
3 结论
假如std::thread需要调用一个函数,且这个函数的输入参数是引用的话,则std::thread对这个参数的调用必须用ref修饰。
假如sid::bind需要调用一个函数,且这个函数的输入参数是引用的话,则std::bind对这个参数的调用必须用ref修饰。然而,在调用这个函数时,也可以用placeholders::_x来代替该输入参数,效果是一样的。
stl库调用,对for_each做了测试,发现使用和不使用std::ref的效果一样