Kompilieren ich den kleinstmöglichen Testproblem geschrieben haben:Mingw g ++ nicht off_t erkennt, wenn sie mit C++ 11
#include <sys/types.h>
int main(int argc, char** argv) {
off_t l = 0;
return 0;
}
Die folgenden Werke: g++ test.cpp
Aber wenn ich versuche, mit c + zu kompilieren +11 ich:
c: \ test> g ++ -std = C++ 11 test.cpp
test.cpp: In function 'int main(int, char**)':
test.cpp:5:2: error: 'off_t' was not declared in this scope
test.cpp:5:8: error: expected ';' before 'l'
test.cpp:6:9: error: 'l' was not declared in this scope
Jeder kann erklären, warum das passiert? Der Grund dafür ist, dass ich versuche, die zlib-Bibliothek in meinem C++ 11-Code zu verwenden. Die Bibliothek zlib.h verwendet off_t viel.
Mein Compiler Version ist: gcc 4.7.2
Using built-in specs.
COLLECT_GCC=g++
COLLECT_LTO_WRAPPER=c:/mingw/bin/../libexec/gcc/mingw32/4.7.2/lto-wrapper.exe
Target: mingw32
Configured with: ../gcc-4.7.2/configure --enable-languages=c,c++,ada,fortran,objc,obj-c++ --disable-sjlj-exceptions --with-dwarf2 --enable-shared --enable-libgomp --disable-win32-registry --enable-libstdcxx-debug --disable-build-poststage1-with-cxx --enable-version-specific-runtime-libs -build=mingw32 --prefix=/mingw
Thread model: win32
gcc version 4.7.2 (GCC)
wenn ich vergleichen: 'g ++ -E test.cpp> test.c' &' g ++ -std = C++ 11 -E test.cpp> test.c' Ich kann sehen, dass ohne C++ 11 habe ich 'typedef lang _off_t; ' ' typedef _off_t off_t; ' und mit std = C++ 11 Ich habe nur' typedef long _off_t; ' – odedsh
Ok, also ist es wegen __STRICT_ANSI__ definiert, wenn ich die -std = C++ 11 benutze Ich kann es von hier aus herausfinden – odedsh