博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Word AddIn编译出现LINK2001 _main
阅读量:6203 次
发布时间:2019-06-21

本文共 2225 字,大约阅读时间需要 7 分钟。

 
 
链接错误"unresolved external symbol _main"

Article last modified on 2002-3-2

------------------------------------------------------------

The information in this article applies to:

  - Microsoft ATL 2.X

------------------------------------------------------------

现象:

当你编译一个ATL工程的Release版时,你得到了下面这个链接错误:

   LIBCMT.LIB(crt0.obj) : error LNK2001: unresolved external symbol _main

如下图所示:

 

    而Debug版本的编连却顺利通过。

 

原因与解决方法:

出错原因:

如果你在工程中使用了CRT函数,而这些函数又需要CRT启动代码,就会出现这种链接错误。默认情况下,Release配置的Preprocessor definitions中定义了_ATL_MIN_CRT,它将CRT启动代码从你的EXE或DLL剔出去了。

 

 

背景知识:

1:

ATL支持把一个服务器编连优化成最小尺寸或者依赖性最小。我们可以定义三个预处理器符号来影响服务器的优化。

_ATL_MIN_CRT             服务器不链接标准的C/C++运行库

_ATL_DLL                  服务器动态链接工具函数库atl.dll

_ATL_STATIC_REGISTRY    服务器静态链接对组件注册的支持

如果定义了预处理器符号_ATL_MIN_CRT,那么我们的服务器不链接C/C++运行库,并且ATL提供了函数malloc、realloc、new和delete的一个实现。当定义了这个符号时,我们不能调用任何其他的C/C++运行库的函数。否则,就会受到这样的待遇:

LIBCMT.LIB(crt0.obj) : error LNK2001: unresolved external symbol _main

ATL向导生成的ATL工程为所有的Release版本的编连定义了_ATL_MIN_CRT,但是没有为Debug版本定义这个符号。

Debug配置没有定义这三个符号中的任何一个。

RelMinSize配置定义了_ATL_MIN_CRT和_ATL_DLL。

RelMinDependency配置定义了_ATL_MIN_CRT和_ATL_STATIC_REGISTRY。

 

2:

C Run-Time Library (without iostream)

Characteristics

Option

Defined

LIBC.LIB

a statically linked library for single-threaded programs

(Single threaded, static link)

/ML

 

LIBCMT.LIB

a statically linked library that supports multithreaded programs

(Multithreaded, static link)

/MT

_MT

MSVCRT.LIB

Multithreaded, dynamic link (import library for MSVCRT.DLL)

/MD

_MT, _DLL

 

解决方法:

 

下面方法中的任何一个都可以纠正这个错误:

Ø         去除_ATL_MIN_CRT这个预处理符号;

Ø         打开stdafx.cpp,注释掉#include <atlimpl.cpp>这句话,然后编译,即可;

Ø         在工程的配置对话框的Link页面上,"ignore libraries"编辑框中输入Libcmt.lib,然后编译,如下图所示:

 

你将会得到几个“unresolved external”的错误,如下所示。

 

        这个列表就是你用到的CRT的函数。

Look for things that you think may be pulling in the startup code and remove them if you can.Instead, use their Win32 equivalents. For example, use lstrcmp() instead of strcmp(). Known functions that require CRT startup code are some of the string and floating point functions.

其他:

我的VC IDE是6.0版本和SP5,如果用ATL COM AppWizard创建Service (EXE)工程。在这种情况下,它的RelMinDependency版本的配置中就没有定义_ATL_MIN_CRT符号!这和微软声称的“Service EXE Created with ATL COM AppWizard Doesn't Build in Release Mode”不一样,可能这是一个已经被FIX了的Bug。

转载于:https://www.cnblogs.com/Dennis-mi/p/3449137.html

你可能感兴趣的文章
是什么导致了上瘾?
查看>>
cSS3 伪类:nth-child 的使用方法
查看>>
Java 8 字符串日期排序
查看>>
跳跃表 SkipList【数据结构】原理及实现
查看>>
J2EE整合Maven开发,Tomcat正常启动,访问链接报404错误
查看>>
python搭建httpserver
查看>>
win7旗舰版安装SQL2005失败,COM+目录警告如何解决
查看>>
ReentrantLock
查看>>
c# 第12节 分支语句if、switch、三位运算符
查看>>
表单验证实例
查看>>
清除上网痕迹
查看>>
Javascript基类对象原型中有数组的情况
查看>>
ASP.NET MVC5 网站开发实践(一)
查看>>
.Net那点事儿系列:System.IO之windows文件操作
查看>>
linux: 用户组, 文件权限详解
查看>>
js/jquery 实时监听输入框值变化的完美方案:oninput & onpropertychange
查看>>
Add Two Numbers
查看>>
使用AspNetPager分页控件对动态查询的结果进行Url分页
查看>>
ECSHOP2.7.3删除后台左侧菜单中的云服务中心
查看>>
3月31日工作日志
查看>>