c++与pair进行变换得到分段错误

发布于 2024-08-24 04:06:11 字数 843 浏览 8 评论 0原文

这段代码的工作原理:

class Test
{
public:
  Test(string name) : _name(name) {};
  bool operator()() { cout << "hello " << _name << endl; return true; }
  string name() { return _name; }
private:
  string _name;
};

pair<string, bool>
inline execute_test(Test* t) {
  return pair<string, bool>(t->name(), (*t)());
}

int main()
{
  vector<Test*> tests;
  vector<pair<string, bool> > results;
  tests.push_back(new Test("Test1"));
  tests.push_back(new Test("Test2"));

  for (unsigned int i=0; i < tests.size(); ++i)
      results.push_back(execute_test(tests[i]));

}

现在我想使用 trasform 而不是 for cicle:

transform(tests.begin(), tests.end(),
          results.begin(),
          execute_test);

但我遇到了分段错误。问题出在哪里?

This code works:

class Test
{
public:
  Test(string name) : _name(name) {};
  bool operator()() { cout << "hello " << _name << endl; return true; }
  string name() { return _name; }
private:
  string _name;
};

pair<string, bool>
inline execute_test(Test* t) {
  return pair<string, bool>(t->name(), (*t)());
}

int main()
{
  vector<Test*> tests;
  vector<pair<string, bool> > results;
  tests.push_back(new Test("Test1"));
  tests.push_back(new Test("Test2"));

  for (unsigned int i=0; i < tests.size(); ++i)
      results.push_back(execute_test(tests[i]));

}

now I want to use trasform instead of the for cicle:

transform(tests.begin(), tests.end(),
          results.begin(),
          execute_test);

but I got a Segmentation Fault. Where is the problem?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

预谋 2024-08-31 04:06:11

这是因为 transform 期望 results 对象分配所需的内存,即它期望 results.size() 至少与 <代码>tests.size()。如果您想对结果执行push_back操作,那么您应该使用std::back_inserter(results)作为第三个参数。否则,当 transform 使用您传递的 * 输出迭代器时,它将是无效的内存位置,并会导致分段错误。

That is because transform is expecting results object to have the required memory allocated i.e. it is expecting results.size() is atleast as big as tests.size(). If you want to push_back operation to be performed on the results then you should use std::back_inserter(results) as the third argument. Otherwise, when transform uses the * output iterator you passed, it will be a invalid memory location and will result in a segmentation fault.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文