如何解决在不使用命名空间std的情况下无法编译的程序;
我遇到了编译器错误:
g++ main.cpp -o exec -Wall -std=c++17 -Wextra -pedantic -O2 -Wshadow -fsanitize=undefined
main.cpp: In instantiation of ‘std::__cxx11::string to_string(A) [with A = int; std::__cxx11::string = std::__cxx11::basic_string<char>]’:
main.cpp:68:25: required from ‘void debug_out(Head,Tail ...) [with Head = int; Tail = {}]’
main.cpp:79:3: required from here
main.cpp:43:3: error: ‘begin’ was not declared in this scope
for (const auto &x : v) {
^~~
main.cpp:43:3: note: suggested alternative:
In file included from /usr/include/x86_64-linux-gnu/c++/7/bits/stdc++.h:95:0,from main.cpp:1:
/usr/include/c++/7/valarray:1211:5: note: ‘std::begin’
begin(const valarray<_Tp>& __va)
^~~~~
main.cpp:43:3: error: ‘end’ was not declared in this scope
for (const auto &x : v) {
^~~
main.cpp:43:3: note: suggested alternative:
In file included from /usr/include/x86_64-linux-gnu/c++/7/bits/stdc++.h:95:0,from main.cpp:1:
/usr/include/c++/7/valarray:1231:5: note: ‘std::end’
end(const valarray<_Tp>& __va)
^~~
Makefile:7: recipe for target 'c++' failed
make: *** [c++] Error 1
使用命名空间std;代码编译良好。 我想知道为什么不使用命名空间std;不能编译代码。
我看错了给定的文件,但是我害怕通过触摸编译器文件来犯错。 我感觉好像缺少了std ::某处,但我不太了解编译器文件上怎么可能有错误,我也不认为我的代码中会丢失它。
这是我用于编程比赛的代码。
#include <bits/stdc++.h>
template <typename A,typename B>
std::string to_string(std::pair<A,B> p);
template <typename A,typename B,typename C>
std::string to_string(std::tuple<A,B,C> p);
template <typename A,typename C,typename D>
std::string to_string(std::tuple<A,C,D> p);
std::string to_string(const std::string& s) {
return '"' + s + '"';
}
std::string to_string(const char* s) {
return to_string((std::string) s);
}
std::string to_string(bool b) {
return (b ? "true" : "false");
}
std::string to_string(std::vector<bool> v) {
bool first = true;
std::string res = "{";
for (int i = 0; i < static_cast<int>(v.size()); i++) {
if (!first) {
res += ",";
}
first = false;
res += to_string(v[i]);
}
res += "}";
return res;
}
template <std::size_t N>
std::string to_string(std::bitset<N> v) {
std::string res = "";
for (std::size_t i = 0; i < N; i++) {
res += static_cast<char>('0' + v[i]);
}
return res;
}
template <typename A>
std::string to_string(A v) {
bool first = true;
std::string res = "{";
for (const auto &x : v) {
if (!first) {
res += ",";
}
first = false;
res += to_string(x);
}
res += "}";
return res;
}
template <typename A,B> p) {
return "(" + to_string(p.first) + "," + to_string(p.second) + ")";
}
template <typename A,C> p) {
return "(" + to_string(std::get<0>(p)) + "," + to_string(std::get<1>(p)) + "," + to_string(std::get<2>(p)) + ")";
}
template <typename A,D> p) {
return "(" + to_string(std::get<0>(p)) + "," + to_string(std::get<2>(p)) + "," + to_string(std::get<3>(p)) + ")";
}
void debug_out() { std::cerr << std::endl; }
template <typename Head,typename... Tail>
void debug_out(Head H,Tail... T) {
std::cerr << to_string(H) << ",";
debug_out(T...);
}
#define LOCAL
#ifdef LOCAL
#define debug(...) std::cerr << "[" << #__VA_ARGS__ << "]: ",debug_out(__VA_ARGS__)
#else
#define debug(...) 42
#endif
int main(){
debug(13);
}
解决方法
template <typename A> std::string to_string(A v)
将匹配所有所有类型,不仅是可以迭代的容器。其中包括to_string(13)
。
using namespace std;
似乎有效的原因是,int
参数的std::to_string
会更好地匹配,并且将用于替代有缺陷的实现。 / p>
您正在使用for(auto& x : v)
,其中v是模板参数,这意味着v可以是int
或在for循环中内部没有使用begin()
运算符的任何类型。您可能需要重新考虑将事物转换为字符串的方式。
编辑:对于标准类型,您可以使用std::to_string();
和#include <string>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。