试图编译大量 .c 文件
(1) 文件编译正常,使用cc
cc -Wall -Wextra -Wunreachable-code -ggdb -O0 *.c
(2) 然后,我需要从最终输出中制作一个静态库,以便在 c++ 程序中使用。所以我这样做:
ar cru liborientdb-c.a *.o
(3) 工作正常。但是,当我编译包含第 1 行中的库的 C++ 程序 testme.cpp 时
(line 1 of testme.cpp)
#include "liborientdb-c.a"
编译步骤:
cc testme.cpp
我收到此错误:
liborientdb-c.a:117:22: error: stray '\3' in program
liborientdb-c.a:117:263: warning: null character(s) ignored [enabled by default]
liborientdb-c.a:117:22: error: stray '\17' in program
liborientdb-c.a:117:265: warning: null character(s) ignored [enabled by default]
liborientdb-c.a:117:283: warning: null character(s) ignored [enabled by default]
liborientdb-c.a:117:22: error: stray '\22' in program
liborientdb-c.a:117:287: warning: null character(s) ignored [enabled by default]
liborientdb-c.a:117:22: error: stray '\1' in program
liborientdb-c.a:117:289: warning: null character(s) ignored [enabled by default]
liborientdb-c.a:117:22: error: stray '\362' in program
....
因此,按照此处其他一些帖子的建议,我相信错误可能是由于编码混乱造成的。
所以我使用了'od -c'并尝试追踪“八进制流”在哪里搞砸了。使用“od -c”后我的一个 .o 文件的输出看起来很糟糕,所以我认为这可能是原因。
例如。
0000000 177 E L F 002 001 001 \0 \0 \0 \0 \0 \0 \0 \0 \0
0000020 001 \0 > \0 001 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0 \0
0000040 \0 \0 \0 \0 \0 \0 \0 \0 ` ( \0 \0 \0 \0 \0 \0
0000060 \0 \0 \0 \0 @ \0 \0 \0 \0 \0 @ \0 026 \0 023 \0
0000100 U H 211 ? H 203 ? 020 H 211 } ? H 211 u ?
0000120 H 213 E ? H 213 \0 H 213 @ \b H 205 ? t 023
0000140 H 213 E ? H 213 \0 H 213 @ \b H 211 ? ? \0
我该如何解决这个问题?我实际上遵循了这里的建议并在我的 lib 源文件上运行
recode UTF8..ISO-8859-15 *.c
响应是文件保持不变(最后修改日期仍然是旧的)。然后我打开我的 .c 文件,发现它们是 UTF-8 格式的,这显然是 ASCII 的一个子集。所以这似乎没有问题。
但是 .o 文件仍然看起来很奇怪。
如何进行 ???