error LNK2019: unresolved external symbol _WinMain@16 referenced in function ___tmainCRTStartup

C++Visual StudioVisual C++

C++ Problem Overview


While I am running the simple code as below I have two errors as following:

#include <iostream>
#include <string>
using namespace::std;

template <class Type>
class Stack
{
public:
    Stack (int max):stack(new Type[max]), top(-1), maxsize(max){}
    ~Stack (void) {delete []stack;}
    void Push (Type &val);
    void Pop (void) {if (top>=0) --top;}
    Type& Top (void) {return stack[top];}
    //friend ostream& operator<< (ostream&, Stack&);
private:
    Type *stack;
    int top;
    const int maxSize;
};

template <class Type>
void Stack <Type>:: Push (Type &val)
{
    if (top+1<maxsize)
        stack [++top]=val;
}

Errors: >MSVCRTD.lib(crtexew.obj) : error LNK2019: unresolved external symbol _WinMain@16 referenced in function ___tmainCRTStartup

What Should I do?

C++ Solutions


Solution 1 - C++

Thats a linker problem.

Try to change Properties -> Linker -> System -> SubSystem (in Visual Studio).

from Windows (/SUBSYSTEM:WINDOWS) to Console (/SUBSYSTEM:CONSOLE)

This one helped me

Solution 2 - C++

As the others mentioned you can change the SubSystem to Console and the error will go away.

Or if you want to keep the Windows subsystem you can just hint at what your entry point is, because you haven't defined ___tmainCRTStartup. You can do this by adding the following to Properties -> Linker -> Command line:

> /ENTRY:"mainCRTStartup"

This way you get rid of the console window.

Solution 3 - C++

If you are having this problem and are using Qt - you need to link qtmain.lib or qtmaind.lib

Solution 4 - C++

Besides changing it to Console (/SUBSYSTEM:CONSOLE) as others have said, you may need to change the entry point in Properties -> Linker -> Advanced -> Entry Point. Set it to mainCRTStartup.

It seems that Visual Studio might be searching for the WinMain function instead of main, if you don't specify otherwise.

Solution 5 - C++

Include <tchar.h> which has the line:

#define _tWinMain wWinMain

Solution 6 - C++

If you use Unicode Character Set, but the entry wasn't set, you can specify /ENTRY:"wWinMainCRTStartup"

Solution 7 - C++

If you actually want to use _tWinMain() instead of main() make sure your project relevant configuration have

  1. Linker-> System -> SubSystem => Windows(/SUBSYSTEM:WINDOWS)

  2. C/C++ -> Preprocessor -> Preprocessor Definitions => Replace _CONSOLE with _WINDOWS

  3. In the c/cpp file where _tWinMain() is defined, add:

    #include <Windows.h> #include <tchar.h>

Solution 8 - C++

i don't see the main function.

please make sure that it has main function.

example :

int main(int argc, TCHAR *argv[]){

}

hope that it works well. :)

Solution 9 - C++

If your project is Dll, then the case might be that linker wants to build a console program. Open the project properties. Select the General settings. Select configuration type Dynamic Library there(.dll).

Solution 10 - C++

I'm not sure where to post this answer of mine but I think it's the right place. I came across this very error today and switching the subsystems didn't change a thing.

Changing the 64bit lib files to 32bit (x86) did the trick for me, I hope it will help someone out there !

Solution 11 - C++

Your tried to turn that source file into an executable, which obviously isn't possible, because the mandatory entry point, the main function, isn't defined. Add a file main.cpp and define a main function. If you're working on the commandline (which I doubt), you can add /c to only compile and not link. This will produce an object file only, which needs to be linked into either a static or shared lib or an application (in which case you'll need an oject file with main defined).

_WinMain is Microsoft's name for main when linking.

Also: you're not running the code yet, you are compiling (and linking) it. C++ is not an interpreted language.

Solution 12 - C++

If you are using CMake, you can also get this error when you set SET(GUI_TYPE WIN32) on a console application.

Solution 13 - C++

The erudite suggestions mentioned above will solve the problem in 99.99% of the cases. It was my luck that they did not. In my case it turned out I was including a header file from a different Windows project. Sure enough, at the very bottom of that file I found the directive:

#pragma comment(linker, "/subsystem:Windows")

Needless to say, removing this line solved my problem.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionNAIEMView Question on Stackoverflow
Solution 1 - C++BohdanView Answer on Stackoverflow
Solution 2 - C++Morten KristensenView Answer on Stackoverflow
Solution 3 - C++David CasperView Answer on Stackoverflow
Solution 4 - C++mathiasfkView Answer on Stackoverflow
Solution 5 - C++ZakiView Answer on Stackoverflow
Solution 6 - C++PetroniusView Answer on Stackoverflow
Solution 7 - C++AlexView Answer on Stackoverflow
Solution 8 - C++jefry da gucciView Answer on Stackoverflow
Solution 9 - C++dream_worldView Answer on Stackoverflow
Solution 10 - C++Another JoeView Answer on Stackoverflow
Solution 11 - C++rubenvbView Answer on Stackoverflow
Solution 12 - C++Nicolas HolthausView Answer on Stackoverflow
Solution 13 - C++Moshe RubinView Answer on Stackoverflow