error PRJ0002 : 错误的结果 1 (从“E:/Program Files/Microsoft Visual Studio 9.0/VC/bin/cl.exe”返回)

本文记录了一个VS2005项目在VS2008中编译时遇到的编译器崩溃问题及解决办法。问题出现在使用swprintf函数时,由于/Wp64选项的存在导致编译器无法正确处理某些格式化字符串。

代码:
swprintf(hwndParam,L"Tetris.exe %x",m_hWnd);
原因:swprintf+/Wp64

参考:http://blog.youkuaiyun.com/baodi_z/article/details/5836891

有个VS2005的VC++工程可以正常编译,转换到VS2008下编译,编译器出错崩溃了,错误提示大概如下:

error PRJ0002 : 错误的结果 1 (从“C:/Program Files/Microsoft Visual Studio 9.0/VC/bin/cl.exe”返回)

 

刚开始很莫名其妙,后来追踪到编译器崩溃前编译的最后一个源文件,

经过逐一注释文件中的代码段,终于发现,只要出现下面这样的语句,就可以令VS2008的C++编译器崩溃:

fprintf(fp,"%s %d/n","cl.exe会崩溃");   //缺少对应的整型参数导致编译器cl.exe崩溃

 

我的测试貌似就是这样的,上面函数多加一个参数他就不会崩溃,额,这个真的很神奇,应该算是编译器的bug吧

 

【补记】

经过最新测试发现:原来是VC8(VS2005)的项目默认属性有开/Wp64 (检测64位可移植性问题),

在VC9(VS2008)下面,如果仍然打开/Wp64编译选项,那么遇到上述这种代码编译器就会崩溃,

如果在项目属性里禁止"检测64位可移植性问题"(/Wp64 )这个选项,则编译就可以正常通过,编译器不会崩溃。不过代码写的也有问题,优先改代码。


ps:20140210再次遇到该错误


c:/users/administrator/.platformio/packages/toolchain-xtensa-esp32s3/bin/../lib/gcc/xtensa-esp32s3-elf/8.4.0/../../../../xtensa-esp32s3-elf/bin/ld.exe: .pio/build/esp32s3/src/spi_slave_server.cpp.o: in function `dumpBuffers(char const*, unsigned char const*, unsigned int, unsigned int)': E:\esp32\esp32_spi_slave_transfer_Prj (4)/src/helper.h:8: multiple definition of `dumpBuffers(char const*, unsigned char const*, unsigned int, unsigned int)'; .pio/build/esp32s3/src/spi_master_server.cpp.o:E:\esp32\esp32_spi_slave_transfer_Prj (4)/src/helper.h:8: first defined here c:/users/administrator/.platformio/packages/toolchain-xtensa-esp32s3/bin/../lib/gcc/xtensa-esp32s3-elf/8.4.0/../../../../xtensa-esp32s3-elf/bin/ld.exe: .pio/build/esp32s3/src/spi_slave_server.cpp.o: in function `verifyAndDumpDifference(char const*, unsigned char const*, unsigned int, char const*, unsigned char const*, unsigned int)': E:\esp32\esp32_spi_slave_transfer_Prj (4)/src/helper.h:25: multiple definition of `verifyAndDumpDifference(char const*, unsigned char const*, unsigned int, char const*, unsigned char const*, unsigned int)'; .pio/build/esp32s3/src/spi_master_server.cpp.o:E:\esp32\esp32_spi_slave_transfer_Prj (4)/src/helper.h:25: first defined here c:/users/administrator/.platformio/packages/toolchain-xtensa-esp32s3/bin/../lib/gcc/xtensa-esp32s3-elf/8.4.0/../../../../xtensa-esp32s3-elf/bin/ld.exe: .pio/build/esp32s3/src/spi_slave_server.cpp.o: in function `initializeBuffers(unsigned char*, unsigned char*, unsigned int, unsigned int)': E:\esp32\esp32_spi_slave_transfer_Prj (4)/src/helper.h:59: multiple definition of `initializeBuffers(unsigned char*, unsigned char*, unsigned int, unsigned int)'; .pio/build/esp32s3/src/spi_master_server.cpp.o:E:\esp32\esp32_spi_slave_transfer_Prj (4)/src/helper.h:59: first defined here c:/users/administrator/.platformio/packages/toolchain-xtensa-esp32s3/bin/../lib/gcc/xtensa-esp32s3-elf/8.4.0/../../../../xtensa-esp32s3-elf/bin/ld.exe: .pio/build/esp32s3/src/spi_slave_server.cpp.o: in function `arduino::esp32::spi::slave::spi_slave_task(void*)': E:\esp32\esp32_spi_slave_transfer_Prj (4)/.pio/libdeps/esp32s3/ESP32SPISlave/ESP32SPISlave.h:116: multiple definition of `arduino::esp32::spi::slave::spi_slave_task(void*)'; .pio/build/esp32s3/src/spi_master_server.cpp.o:E:\esp32\esp32_spi_slave_transfer_Prj (4)/.pio/libdeps/esp32s3/ESP32SPISlave/ESP32SPISlave.h:116: first defined here c:/users/administrator/.platformio/packages/toolchain-xtensa-esp32s3/bin/../lib/gcc/xtensa-esp32s3-elf/8.4.0/../../../../xtensa-esp32s3-elf/bin/ld.exe: .pio/build/esp32s3/src/spi_slave_server.cpp.o: in function `arduino::esp32::spi::slave::spi_slave_post_setup_cb(spi_slave_transaction_t*)': E:\esp32\esp32_spi_slave_transfer_Prj (4)/.pio/libdeps/esp32s3/ESP32SPISlave/ESP32SPISlave.h:100: multiple definition of `arduino::esp32::spi::slave::spi_slave_post_setup_cb(spi_slave_transaction_t*)'; .pio/build/esp32s3/src/spi_master_server.cpp.o:E:\esp32\esp32_spi_slave_transfer_Prj (4)/.pio/libdeps/esp32s3/ESP32SPISlave/ESP32SPISlave.h:100: first defined here c:/users/administrator/.platformio/packages/toolchain-xtensa-esp32s3/bin/../lib/gcc/xtensa-esp32s3-elf/8.4.0/../../../../xtensa-esp32s3-elf/bin/ld.exe: .pio/build/esp32s3/src/spi_slave_server.cpp.o: in function `arduino::esp32::spi::slave::spi_slave_post_trans_cb(spi_slave_transaction_t*)': E:\esp32\esp32_spi_slave_transfer_Prj (4)/.pio/libdeps/esp32s3/ESP32SPISlave/ESP32SPISlave.h:108: multiple definition of `arduino::esp32::spi::slave::spi_slave_post_trans_cb(spi_slave_transaction_t*)'; .pio/build/esp32s3/src/spi_master_server.cpp.o:E:\esp32\esp32_spi_slave_transfer_Prj (4)/.pio/libdeps/esp32s3/ESP32SPISlave/ESP32SPISlave.h:108: first defined here c:/users/administrator/.platformio/packages/toolchain-xtensa-esp32s3/bin/../lib/gcc/xtensa-esp32s3-elf/8.4.0/../../../../xtensa-esp32s3-elf/bin/ld.exe: .pio/build/esp32s3/src/spi_master_server.cpp.o:(.literal._Z20spi_master_read_datav+0x20): undefined reference to `printf_log_hex(char*, unsigned char*, unsigned int)' c:/users/administrator/.platformio/packages/toolchain-xtensa-esp32s3/bin/../lib/gcc/xtensa-esp32s3-elf/8.4.0/../../../../xtensa-esp32s3-elf/bin/ld.exe: .pio/build/esp32s3/src/spi_master_server.cpp.o: in function `spi_master_read_data()': E:\esp32\esp32_spi_slave_transfer_Prj (4)/src/spi_master_server.cpp:46: undefined reference to `printf_log_hex(char*, unsigned char*, unsigned int)' c:/users/administrator/.platformio/packages/toolchain-xtensa-esp32s3/bin/../lib/gcc/xtensa-esp32s3-elf/8.4.0/../../../../xtensa-esp32s3-elf/bin/ld.exe: E:\esp32\esp32_spi_slave_transfer_Prj (4)/src/spi_master_server.cpp:54: undefined reference to `printf_log_hex(char*, unsigned char*, unsigned int)' c:/users/administrator/.platformio/packages/toolchain-xtensa-esp32s3/bin/../lib/gcc/xtensa-esp32s3-elf/8.4.0/../../../../xtensa-esp32s3-elf/bin/ld.exe: .pio/build/esp32s3/src/spi_master_server.cpp.o: in function `spi_master_write_data(unsigned char*, unsigned short)': E:\esp32\esp32_spi_slave_transfer_Prj (4)/src/spi_master_server.cpp:76: undefined reference to `printf_log_hex(char*, unsigned char*, unsigned int)' collect2.exe: error: ld returned 1 exit status *** [.pio\build\esp32s3\firmware.elf] Error 1
最新发布
09-25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值