【问题标题】:fstream linking error in g++ with -std=gnu++0xg ++中的fstream链接错误与-std = gnu ++ 0x
【发布时间】:2009-07-22 12:56:14
【问题描述】:

我在 windows 上使用 tdm-mingw g++ 4.4.0 中的 -std=gnu++0x 参数构建了一个应用程序。

它使用了一个 ofstream 对象,当我构建时,它给出了以下链接错误:

c:\opt\Noddler/main_func.cpp:43: undefined reference to `std::basic_ofstream<char, std::char_traits<char> >::basic_ofstream(std::string const&, std::_Ios_Openmode)'

使用默认的旧标准时,它可以正确构建。

这是唯一的错误,尝试与 -lstdc++ 链接没有帮助。以前有人经历过吗?我可以得到任何建议吗?

编辑: 我正在创建一个这样的 ofstream 对象:

std::string filename = string("noddler\\") + callobj.get_ucid() + "_" + callobj.gram_counter() + ".grxml";
ofstream grxml_file(string("C:\\CWorld\\Server\\Grammar\\") + filename);
...
grxml_file.close();

编译正常,但没有链接。

【问题讨论】:

  • 请贴出导致此错误的代码。

标签: c++ g++ c++11 tdm-mingw


【解决方案1】:

我猜你有这样的代码:

string fname = "foo.txt";
ifstream ifs( fname );

尝试将其更改为:

ifstream ifs( fname.c_str() );

如果您使用的头文件与您链接的库有些不协调,则可能会发生这种情况。如果这不起作用,请发布导致问题的代码。

【讨论】:

  • 即使该更改确实 起作用,但就目前而言,这并不是一个非常令人满意的解决方案。这等于说,为了在 C++0X 模式下构建,你不应该使用新的 C++0X 特性。实际的解决方案可能包括在g++ 上设置命令开关,或者将文件放在正确的位置。
  • 我认为任何针对提议的 C++0X 标准构建真正解决方案的人都是错误的。无论如何都要针对这些东西构建探索性代码,但要针对现有标准和切实支持这些标准的实施来构建真正的代码。
  • 这是什么 C++0x 新特性?
  • 解决了,尼尔。谢谢。顺便说一句,我只是在构建探索性代码,但到现在为止,我们可以预期大部分功能都会在标准中完成,对吧?会不会比现在有太多变化?
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2012-05-15
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2010-12-25
相关资源
最近更新 更多