在 C++11 中使用 reference_wrapper 而不是标准指针访问 class 成员
Accessing class members using reference_wrapper instead of standard pointers in C++11
我正在尝试构建一个 unordered_map
到 vector
变量,它们是我的 class 的成员。我可以使用标准指针 *
来做到这一点,但这需要使用 (*x)
来访问向量。我想知道 std::reference_wrapper
是否会更干净,但无法正常工作。
#include <unordered_map>
#include <iostream>
#include <vector>
#include <functional>
class model_class {
private:
static constexpr auto MaxHerds = 1 ;
static constexpr int MaxInitValues = 5 ;
static constexpr int MaxAnimals = 2 ;
std::vector< double > MamCellsF ;
std::vector< std::vector< double > > InitCond ;
public:
std::unordered_map< std::string , std::reference_wrapper< std::vector< double > > > vector;
std::unordered_map< std::string , std::vector< std::vector< double > >* > array;
model_class ( ) :
// initialise vectors
MamCellsF( MaxHerds , 0.07 ) ,
InitCond( MaxAnimals , std::vector< double > ( MaxInitValues , 0.7 ) )
{
// point to variables from model
vector.insert({"MamCellsF", std::ref(MamCellsF)});
array["InitCond"] = &InitCond;
// assign to vectors
MamCellsF = { 0.001 , 0.002 } ; // warning: automatic resizing
InitCond = { { 1.0 , 550 , 3.5 , 1 , 4 } ,
{ 2.0 , 625 , 3.5 , 5 , 4 } } ;
}
void print_values(){
// access the vectors
double a = vector["MamCellsF"].get()[1]; // error: "no matching function call to `std::reference_wrapper<std::vector<double>>::reference_wrapper()"
double b = (*array["InitCond"])[0][1];
std::cout << a << std::endl;
std::cout << b << std::endl;
}
};
void test()
{
model_class model;
model.print_values();
}
vector["MamCellsF"]
returns 对地图中值的引用。因此,如果没有,则必须首先构建它。它使用默认构造函数,但 std::reference_wrapper
不是默认可构造的,因此出现错误。
我认为 STL 容器对于不可默认构造的 T 是安全的,但它们的操作可能会受到限制。所以我不推荐。
我正在尝试构建一个 unordered_map
到 vector
变量,它们是我的 class 的成员。我可以使用标准指针 *
来做到这一点,但这需要使用 (*x)
来访问向量。我想知道 std::reference_wrapper
是否会更干净,但无法正常工作。
#include <unordered_map>
#include <iostream>
#include <vector>
#include <functional>
class model_class {
private:
static constexpr auto MaxHerds = 1 ;
static constexpr int MaxInitValues = 5 ;
static constexpr int MaxAnimals = 2 ;
std::vector< double > MamCellsF ;
std::vector< std::vector< double > > InitCond ;
public:
std::unordered_map< std::string , std::reference_wrapper< std::vector< double > > > vector;
std::unordered_map< std::string , std::vector< std::vector< double > >* > array;
model_class ( ) :
// initialise vectors
MamCellsF( MaxHerds , 0.07 ) ,
InitCond( MaxAnimals , std::vector< double > ( MaxInitValues , 0.7 ) )
{
// point to variables from model
vector.insert({"MamCellsF", std::ref(MamCellsF)});
array["InitCond"] = &InitCond;
// assign to vectors
MamCellsF = { 0.001 , 0.002 } ; // warning: automatic resizing
InitCond = { { 1.0 , 550 , 3.5 , 1 , 4 } ,
{ 2.0 , 625 , 3.5 , 5 , 4 } } ;
}
void print_values(){
// access the vectors
double a = vector["MamCellsF"].get()[1]; // error: "no matching function call to `std::reference_wrapper<std::vector<double>>::reference_wrapper()"
double b = (*array["InitCond"])[0][1];
std::cout << a << std::endl;
std::cout << b << std::endl;
}
};
void test()
{
model_class model;
model.print_values();
}
vector["MamCellsF"]
returns 对地图中值的引用。因此,如果没有,则必须首先构建它。它使用默认构造函数,但 std::reference_wrapper
不是默认可构造的,因此出现错误。
我认为 STL 容器对于不可默认构造的 T 是安全的,但它们的操作可能会受到限制。所以我不推荐。