如何正确使用std::transform和std::mem_fn?
How to use std::transform and std::mem_fn correctly?
我实现了一个 C++ 程序,它创建了三个不同的 Person 对象。这些对象被共享并存储在一个向量中。
函数 getVector()
接受 const std::vector<std::shared_ptr<Person>>&
作为输入,returns 接受 std::vector<Person*>
。结果向量中的每个元素对应于输入向量中的相应元素。
该函数使用 std::transform
和 std::mem_fn
。
该函数的实现(以及对 std::cout
的相应调用)不起作用。我认为我以错误的方式(错误的参数等)将 std::transform
与 std::mem_fn
一起使用。
我不知道如何使功能 getVector()
工作。
到目前为止,这是我的源代码:
main.cpp
#include <string>
#include <vector>
#include <memory>
#include <sstream>
#include <iostream>
#include <algorithm>
#include <functional>
struct Person
{
std::string first_name;
std::string last_name;
int age;
Person* getPerson(const std::shared_ptr<Person>& person)
{
Person* p = person.get();
return std::move(p);
}
// Overloaded << operator.
friend std::ostream& operator<<(std::ostream& os, const Person& person)
{
os << person.first_name << ", " << person.last_name << ", " << person.age << "\n";
return os;
}
friend std::string to_string(const Person& obj)
{
std::ostringstream ss;
ss << obj;
return ss.str();
}
};
std::vector<Person*> getVector(const std::vector<std::shared_ptr<Person>>& people);
int main(void)
{
Person person01;
person01.first_name = "Ashley";
person01.last_name = "Graham";
person01.age = 23;
Person person02;
person02.first_name = "Ada";
person02.last_name = "Wong";
person02.age = 45;
Person person03;
person03.first_name = "Leon S.";
person03.last_name = "Kennedy";
person03.age = 26;
std::shared_ptr<Person> ps01 = std::make_shared<Person>(person01);
std::shared_ptr<Person> ps02 = std::make_shared<Person>(person02);
std::shared_ptr<Person> ps03 = std::make_shared<Person>(person03);
std::vector<std::shared_ptr<Person>> peoples;
peoples.emplace_back(std::move(ps01));
peoples.emplace_back(std::move(ps02));
peoples.emplace_back(std::move(ps03));
std::cout << "\nContent of input vector:\n";
std::cout << "====================================\n";
for (auto p : peoples)
{
std::cout << *p;
}
std::cout << "\n";
std::cout << "Calling function 'getVector()'...\n";
std::vector<Person*> result = getVector(peoples);
std::cout << "\nContent of result-vector:\n";
std::cout << "====================================\n";
for (auto r : result)
{
std::cout << *r;
}
std::cout << "\n";
return 0;
}
// std::transform with std::mem_fn.
std::vector<Person*> getVector(const std::vector<std::shared_ptr<Person>>& people)
{
Person* person;
std::shared_ptr<Person> p;
std::vector<Person*> result;
std::transform(people.begin(), people.end(), std::back_inserter(result),
std::bind1st(std::mem_fn(&Person::getPerson), &p));
return result;
}
以下是 g++ 编译器的说明:
g++ -std=c++11 -Wall -Wextra main.cpp -o main
只需使用 lambda。它使代码更容易理解,你可以去掉 GetPerson
函数。这样做会使您的转换调用看起来像
std::transform(people.begin(),
people.end(),
std::back_inserter(result),
[](const auto& elem){ return elem.get(); });
我实现了一个 C++ 程序,它创建了三个不同的 Person 对象。这些对象被共享并存储在一个向量中。
函数 getVector()
接受 const std::vector<std::shared_ptr<Person>>&
作为输入,returns 接受 std::vector<Person*>
。结果向量中的每个元素对应于输入向量中的相应元素。
该函数使用 std::transform
和 std::mem_fn
。
该函数的实现(以及对 std::cout
的相应调用)不起作用。我认为我以错误的方式(错误的参数等)将 std::transform
与 std::mem_fn
一起使用。
我不知道如何使功能 getVector()
工作。
到目前为止,这是我的源代码:
main.cpp
#include <string>
#include <vector>
#include <memory>
#include <sstream>
#include <iostream>
#include <algorithm>
#include <functional>
struct Person
{
std::string first_name;
std::string last_name;
int age;
Person* getPerson(const std::shared_ptr<Person>& person)
{
Person* p = person.get();
return std::move(p);
}
// Overloaded << operator.
friend std::ostream& operator<<(std::ostream& os, const Person& person)
{
os << person.first_name << ", " << person.last_name << ", " << person.age << "\n";
return os;
}
friend std::string to_string(const Person& obj)
{
std::ostringstream ss;
ss << obj;
return ss.str();
}
};
std::vector<Person*> getVector(const std::vector<std::shared_ptr<Person>>& people);
int main(void)
{
Person person01;
person01.first_name = "Ashley";
person01.last_name = "Graham";
person01.age = 23;
Person person02;
person02.first_name = "Ada";
person02.last_name = "Wong";
person02.age = 45;
Person person03;
person03.first_name = "Leon S.";
person03.last_name = "Kennedy";
person03.age = 26;
std::shared_ptr<Person> ps01 = std::make_shared<Person>(person01);
std::shared_ptr<Person> ps02 = std::make_shared<Person>(person02);
std::shared_ptr<Person> ps03 = std::make_shared<Person>(person03);
std::vector<std::shared_ptr<Person>> peoples;
peoples.emplace_back(std::move(ps01));
peoples.emplace_back(std::move(ps02));
peoples.emplace_back(std::move(ps03));
std::cout << "\nContent of input vector:\n";
std::cout << "====================================\n";
for (auto p : peoples)
{
std::cout << *p;
}
std::cout << "\n";
std::cout << "Calling function 'getVector()'...\n";
std::vector<Person*> result = getVector(peoples);
std::cout << "\nContent of result-vector:\n";
std::cout << "====================================\n";
for (auto r : result)
{
std::cout << *r;
}
std::cout << "\n";
return 0;
}
// std::transform with std::mem_fn.
std::vector<Person*> getVector(const std::vector<std::shared_ptr<Person>>& people)
{
Person* person;
std::shared_ptr<Person> p;
std::vector<Person*> result;
std::transform(people.begin(), people.end(), std::back_inserter(result),
std::bind1st(std::mem_fn(&Person::getPerson), &p));
return result;
}
以下是 g++ 编译器的说明:
g++ -std=c++11 -Wall -Wextra main.cpp -o main
只需使用 lambda。它使代码更容易理解,你可以去掉 GetPerson
函数。这样做会使您的转换调用看起来像
std::transform(people.begin(),
people.end(),
std::back_inserter(result),
[](const auto& elem){ return elem.get(); });