• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            [轉(zhuǎn)載]VC++常見錯(cuò)誤

            Visual C++ Error Messages

            This page contains a listing of "difficult to diagnose" error messages and possible fixes. I haven't taught a programming class that uses Visual C++ in several years so this list is probably out of date by now.  It was valid for Microsoft Visual C++ version 6.0 service pack 3.

             

            C1001: INTERNAL COMPILER ERROR (compiler file 'msc1.cpp', line 1786) Please choose the Technical Support command on the Visual C++ Help menu, or open the Technical Support help file for more information

            This error results from leaving off the parentheses immediately following the function name in a function header.  To correct the error simply add () to the end of the function name.

             

            C1010: unexpected end of file while looking for precompiled header directive

            If your project is an MFC AppWizard created project then this error results from not #including StdAfx.h as the first include statement (before any other includes, data declarations, or executable program code).

             

            C1083: Cannot open precompiled header file: 'Debug/<Project-Name>.pch': No such file or directory

            This error results from a missing file - the compiled version of StdAfx.cpp. Visual C++ does a poor job of keeping track of this file and frequently "forgets" how to build it. This problem often occurs after restoring a saved workspace from diskette without the Debug directory. To fix the error select StdAfx.cpp from the workspace file list them choose Compile from the Build menu.  If that doesn't work the go to Project -> Settings, select the C/C++ tab, and click the radio button labeled Create Precompiled Headers.

             

            C2001: newline in constant

            This error is usually caused by a string or character constant that is missing its closing ' or " symbol.

            C2065: '<data-member name>' : undeclared identifier

            If this error occurs in one of your member functions then it is generally the result of forgetting the class scope operator in front of the function name in your .cpp file.

             

            C2143: syntax error : missing ';' before 'PCH creation point'

            Check each of the include files to ensure that the closing brace of each class declaration is followed by a semicolon.

             


            C2143: syntax error : missing ';' before '*'

            If this error is followed by two C2501 errors then the problem is an undeclared class name within a pointer declaration.

            For example, the declaration:

            CClass *pObject;

            will generate the above error message followed by a C2501 error message for 'CClass' and another C2501 message for 'pObject'.  The problem is that the compiler isn't recognizing CClass as a valid class/type name.  To correct the problem add a i nclude of the file containing the declaration of CClass (e.g., i nclude CClass.h)

             

            C2447: missing function header (old-style formal list?)

            This error usually results from a missing { or use of a ; instead of a { following the parameter list of a function header.

             

            C2511: '<function-name>' : overloaded member function not found in '<class-name>'

            This error results from a mismatch in the parameter list of a member function declaration (.h file) and definition (.ccp file). Check the forward declaration of the function in the .h file and its definition in the .cpp file and ensure that the number of parameters and the type of each parameter match exactly.

            C2512: '<constructor-function-name>' : no appropriate default constructor available

            This error usually occurs when you implement the constructor function of a derived class and forget to include parameter passing to the base class constructor function.   For example assume that CDerived is derived from CBase and that the CBase constructor function requires one parameter (e.g., int A).  If you define the CDerived constructor function as:

            CDerived::CDerived(int A, int B) { ... }

            the compiler will issue the above error message on the line containing the function header of CDerived::CDerived() because you haven't provided instructions for routing the parameter A to CBase::CBase().  Because you didn't provide instructions the compiler assumes that CBase::CBase() requires no arguments and it complains because no version of CBase::CBase() has been defined that accepts zero arguments.

            If you intended to provide a version of CBase::CBase() that requires no arguments then the error message indicates that you forgot to declare that function in your base class declaration (e.g., in CBase.h).

            If CBase::CBase() does require one or more arguments then you must correct the problem by including explicit instructions for passing parameters from the derived class constructor function to the base class constructor function.  The correction for the example above is:

            CDerived::CDerived(int A, int B) : CBase(A) { ... }

             

            C2556: '<function-name>' : overloaded functions only differ by return type
            C2371: '<function-name>' : redefinition; different basic types

            These errors usually result from a mismatch of function type between a .h and .cpp file. Check the forward declaration of the function in the .h file and its definition in the .cpp file and make the function return type identical in both files.

             

            C2601: '<function-name>' : local function definitions are illegal

            This error results from defining one function inside the body of another function.   It usually means that you omitted one or more } symbols in the function just before the function named in the error message.

            C2653: '<Class-Name>' : is not a class or namespace name

            This error usually results from not having include "StdAfx.h" as the first include statement in your class.cpp file.  It can also occur if your class definition is in a .h file and you forget to include that .h file in another file that refers to the class name.

             

            C2661: '<Class-Name>::<Function-Name>' : no overloaded function takes n parameters

            This error indicates a mismatch between the parameters used in a function call (e.g., from main.cpp) and the declaration of the function.  The function call is passing n parameters and there is no function declaration that uses that number of parameters.

             

            LNK1104: Cannot open file nafxcwd.lib

            This error sometimes occurs when a project uses a class from the MFC but the project settings don't explicitly tell the link editor to look in the MFC libraries. 

            Go to Project --> Settings (Build --> Settings in Visual C++ 4.0). On the General tab check the box that says "Use MFC in a Shared DLL".

             

            LNK1168: cannot open Debug\<Project-Name>.exe for writing

            This error occurs when the link editor attempts to write to a .exe file that is currently in use. The .exe file of an executing program is write protected until the program is terminated. Look at the status bar at the bottom of your screen and find the icon representing your executable application. Open the application and exit from it. Then select Build.

             

            LNK2001: unresolved external symbol __endthreadex
            LNK2001: unresolved external symbol __beginthreadex

            These errors result from using an MFC object or function without telling the link editor to search the MFC libraries.

            Go to Project --> Settings (Build --> Settings in Visual C++ 4.0). On the General tab check the box that says "Use MFC in a Shared DLL".

            LNK2001: unresolved external symbol _main

            Your project doesn't contain a function called main().  The error usually results from forgeting to add main.cpp to the project workspace.

             

            <File>.obj : error LNK2001: unresolved external symbol "public: void __thiscall <Class1>::<Function1>(<Type>)"

            This a generic form of a LNK2001 error where <File>.obj can be any object file in your project and <Class1>::<Function1>(<Type>) can be any function in any class.  Substitute the specific <File>, <Class>, <Function>, and <Type> in your message into the instructions below to diagnose and correct the problem.

            An LNK2001 error means that the link editor is looking for a compiled function and can't find it.  The call to the "missing function" is somewhere in <File>.cpp. Unfortunately, double-clicking on the error message won't take you to the point in <File.cpp> where the function is called but you can search for it with Find or Find In Files.  The function the link editor can't find is a member of <Class>, its name is <Function1>, and its return type is <Type>.

            There are two common reasons for a LNK2001 error:

            1.        The call in <File>.cpp doesn't match the function prototype in <Class>.h and/or the implementation in <Class>.cpp.  The mismatch may be in the function name, return type, or number and/or type of parameters.   Correction strategies include:

            o        Check that the function name is spelled the same (case sensitive) in all three files (File.cpp, Class.h, and Class.cpp).

            o        Check that the function is actually declared and defined within <Class> - perhaps you defined it as a member of a different class or perhaps you tried to call the function (in <File>.cpp) using an object or object pointer of a different class.

            o        Check that the number and type of parameters in the function implementation (in <Class>.cpp) matches the number and type of parameters declared in the function declaration in <Class>.h.

            o        Check that the number and type of parameters in the function call (in <File>.cpp) matches the number and type of parameters declared in the function header in <Class>.cpp.

            2.        The function was never declared or was declared but never defined.  To see if either is the case go to the ClassView window of the Workspace view.  Click the + next to <Class> and find <Function> in the list of member functions.

            o        If <Function> is NOT in the list then it was never declared or defined - add a declaration to the class declaraion in <Class>.h and implement the function in <Class>.cpp.

            If <Function> is in the list then right click on it and select Go To Definition from the pop-up menu.  If you get the error message Cannot find definition (implementation) of this function then the function was declared but never defined (implemented).  Implement the function to

            o        <Class>.cpp.

             

            LNK2005: <some-long-string-of-mostly-garbage> already defined in <name>.lib(<name>.obj)

            This error usually results from including a source code file multiple times. If you recognize any of the names in the message then it probably results from multiple inclusion of one of your own header files. Check to be sure that you've used #ifndef/#define/#endif properly your header files. If you don't recognize the name then it's probably multiple inclusion of a system file (e.g., afxwin.h). Make sure that you haven't explicitly included something in main.cpp that is already included in one of your own header files.   Also check that you haven't included a .cpp file where you should have included a .h file

            posted on 2007-04-15 21:24 ashura 閱讀(2303) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Computer Science

            <2025年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(2)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            国产精品免费福利久久| 久久久久久国产精品美女 | 久久精品草草草| 亚洲精品国产成人99久久| 久久亚洲精品中文字幕三区| 国产福利电影一区二区三区,免费久久久久久久精 | 久久综合伊人77777| 久久精品无码一区二区WWW| 国产精品久久久亚洲| 久久久久无码精品| 久久精品毛片免费观看| 久久精品国产精品亚洲人人| 亚洲女久久久噜噜噜熟女| 久久国产福利免费| 久久综合给合久久狠狠狠97色 | av午夜福利一片免费看久久| 久久久久久久综合日本| 精品熟女少妇av免费久久| 欧美国产精品久久高清| 久久精品国产福利国产秒| 亚洲欧美精品一区久久中文字幕 | 精品国产91久久久久久久a | 久久精品国产免费观看| 免费一级欧美大片久久网| 久久香蕉综合色一综合色88| 少妇高潮惨叫久久久久久| 一极黄色视频久久网站| 国内精品久久久久久久涩爱 | 久久免费线看线看| 国产产无码乱码精品久久鸭| 色婷婷综合久久久中文字幕| 欧美成人免费观看久久| 色综合久久天天综线观看| 久久精品国产99久久久香蕉 | 亚洲AV日韩AV天堂久久| 亚洲va久久久久| 伊色综合久久之综合久久| 亚洲国产天堂久久综合| 亚洲午夜福利精品久久| 久久久高清免费视频| 亚洲国产精品无码久久久蜜芽 |