zoukankan      html  css  js  c++  java
  • vs错误【C1083 C1854 C4727】的若干解决办法

            这几天写程序,无意间把编译中间文件给删了,然后就出现了C1083编译错误。

    xxx.cpp

    ..commenxxx.cpp(2) : fatal error C1083: 无法打开预编译头文件:“Releasexxx.pch”: No such file or directory

            在网上搜索了很久,大致是这么解决的,将【创建/使用编译头】改为“不使用编译头”,或者改成 “创建预编译头(/Yc)”, 然后编译就通过了。


             于是我也招搬了 “不使用编译头” ,结果出现下面的错误:

    xxx.cpp
    ..commenxxx.cpp(2) : fatal error C1083: 无法打开包括文件:“stdafx.h”: No such file or directory

             原因是我的程序文件放了好几个目录,公共目录下自然没有“stdafx.h”,所以就编译错误了。然后我又改为“创建预编译头”,在Debug版本下,貌似对了。Release时,忘了怎么配置的,结果仍然提示  “无法打开预编译头文件 xx.pch”。

            按照网上的说法,我把stdafx.cpp单独编译了一下(在解决方案视图,右键文件->编译,则只对选中文件进行编译),然后再整体编译连接,编译通过了,但是链接又出问题了,提示如下:

    warning C4727: 具有相同时间戳的名为 xxx.pch 的 PCH 已存在于yyy.obj 和 yyy.obj 中。使用第一个 PCH。
    MyDlg2.obj : error LNK2005: ___@@_PchSym_@00@UdliphkzxvUexUszmarUKltKoyKrqKluKpmKqsKltKroKonKluKqoKoleBUivovzhvUnbwotOlyq@ 已经在 MyDlg.obj 中定义

             我晕!然后又改成 “使用预编译头(/Yu)”,当编译正要成功是,悲剧又来了:

    .MyDlg.cpp(4) : fatal error C1854: 无法覆盖在创建对象文件“xxx eleasemydlg.obj”的预编译头过程中形成的信息

            然后我就反复,将【创建/使用编译头】,在这几个选项中切换尝试,但错误始终存在。正在我无奈之极,突然搜到了MSDN中对错误C4727和C1854的解释:


    http://msdn.microsoft.com/zh-cn/library/5a193hd8.aspx

    错误 C1854

    Visual Studio 2010
    无法覆盖在创建对象文件“filename”的预编译头过程中形成的信息

    您对同一文件指定 /Yc(创建预编译头文件)选项后指定了 /Yu(使用预编译头文件)选项。 某些声明(如包括__declspecdllexport 的声明)使此操作无效。


    http://msdn.microsoft.com/zh-cn/library/ms235540.aspx

    编译器警告(等级 1)C4727

    Visual Studio 2010
    在 obj_file_1 和 obj_file_2 中找到具有相同时间戳的名为 pch_file 的 PCH。使用第一个 PCH。

    如果用 /Yc 编译多个 compiland,并且其中的编译器能够用相同的 .pch 时间戳标记所有的 .obj 文件,将发生 C4727。

    要消除此警告,请用 /Yc /c 编译一个源文件(创建 pch),并用 /Yu /c 分别编译其他的源文件(使用 pch),然后再将它们链接到一起。

    因此,如果使用了下面的选项就会生成 C4727:

    cl /clr /GL a.cpp b.cpp c.cpp /Ycstdafx.h

    您可改用下面的选项:

    cl /clr /GL a.cpp /Ycstdafx.h /c

    cl /clr /GL b.cpp c.cpp /Yustdafx.h /link a.obj

    有关更多信息,请参见

            

            MSDN对C4727是这样解决的:

    您可改用下面的选项:

    cl /clr /GL a.cpp /Ycstdafx.h /c

    cl /clr /GL b.cpp c.cpp /Yustdafx.h /link a.obj

            原本以为要手动使用命令含编译所有文件,我想还是算了,因为我的工程有30多个文件,除非写成bat,否则编译还会累死。幸好我不会bat,没有动手去写。我猜想VS功能这么强大,既然报错了,错误应该有解决办法的,不可能让我们手动去编译。在查看工程属性的时候,无意间,点到了stdafx.cpp,豁然开朗!


    然后按照MSDN的那个解觉办法的原理,进行设置,就OK了。对工具和问题原理不熟,害我走这么多的弯路啊。


    总结下,大致四种解决的办法:

    1. 如果无意间,删掉xxx.pch文件,如果编译器报错 “C1083无法打开xxx.pch”,一般只需要清理解决方案,然后rebuild all就可以了。

    2.如果1不管用,将【创建/使用预编译头】改为 “不使用编译头”,然后清理解决方案,rebuild即可。

    3.如果仍然不管用,将【创建/使用预编译头】改为 “创建预编译头”,然后清理解决方案,rebuild即可。

    4.如果上述方法,还不管用。将【创建/使用预编译头】改回 “使用预编译头”,然后将“stdafx.cpp”的属性中【创建/使用预编译头】,改成 "创建预编译头",将其他所有的.cpp文件的预编译属性均该为 “使用预编译头” ,清理解决方案,然后rebuild即可。

    注意:每次更改属性后,都要清理解决方案,如果工程目录下的.pch文件仍然存在,要手动删掉。

    尽量不要使用2、3的方法,应直接使用4的方法,虽然麻烦点,但是值得的,免得后面哪里删错了有出现这鬼错误。


    预编译头是很有用的,不要因为错误而认为他碍眼,也不要因为VC每个源文件前面都要包含stdafx.h而觉得麻烦。下面是别人对这个错误以及对编译头的分析,

    http://hi.baidu.com/andywangcn/blog/item/7d8da5072516fc7003088172.html



  • 相关阅读:
    WinInet中的FTP操作
    CodeIgniter 用户指南 版本 1.7.2
    《Windows Mobile实例开发》电子书提供下载
    程序静默安装的参数总结
    Select a table of certain webpage
    568A
    在IIS 5.1 或IIS6 中配置PHP 的FastCGI模式
    镁天三国育将篇
    镁天三国军事篇
    windows 环境下的 protoc 安装
  • 原文地址:https://www.cnblogs.com/ygxsk/p/7694013.html
Copyright © 2011-2022 走看看