C++ ACE 编译注意事项
2011-11-23 09:53
246 查看
转载
http://wfpb.blogbus.com/logs/5597170.html
文件ace\config.h 定义了ACE_HAS_MFC ,这个是控制你的dll是否为MFC Dll用,我编译的是win32的Dll,所以这个编译我定义为#define ACE_HAS_MFC 0,否则会报error lnk2005: _dllmain@12 already defined in dllmain 的错误
文件ace\config-win32-common.h 文件中有各个编译选项的使用说明。
当初我安装ACE时,失败了几次,后来按照这个来,才完全成功。
如果大家有人使用VC助手的话,安装完后打开VC编写程序时,编译器最下面VX会不停的加载头文件,因为它要达到能够提示完成函数原形的功能,所以他要全部加载,但是每次都如此,会比较烦,你可以点击VX的option里设置一下directory,增加你的ace文件夹到里面,这样就OK了,终于可以爽爽的用了。
整理方法如下:
一. Windows下for MSVC的安装与配置
我们用的是ACE-5.4+TAO-1.4+CIAO-0.4.zip,Windows下解压缩该压缩包到目标路径(设为D:\软件安装\编程学习软件\ACE_wrappers ),
创建文件:$ACE_ROOT/ace/config.h,增加一行:
#i nclude "ace/config-win32.h"
如果是在Windows 9x/Me下,需要在$ACE_ROOT/ace/config.h中#i nclude语句前加入:
#define ACE_HAS_WINNT4 0
如果想使用standard C++ header,需要在$ACE_ROOT/ace/config.h中#i nclude语句前加入:
#define ACE_HAS_STANDARD_CPP_LIBRARY 1
如果想把MFC作为静态库链接到ACE(If you prefer to link MFC as a static library into ACE),
则需要在$ACE_ROOT/ace/config.h中#i nclude语句前加入:
#define ACE_HAS_MFC 1
如果想生成ACE静态库或在工程中使用ACE静态库,都需要定义以下宏:
ACE_AS_STATIC_LIBS
打开工程,D:\软件安装\编程学习软件\ACE_wrappers\ace.dsw,编译生成以下库:
ace.dll/ace.lib (DLL release)
aced.dll/aced.lib(DLL debug)
acemfc.dll/acemfc.lib (MFC DLL release)
acemfcd.dll/acemfcd.lib(MFC DLL debug)
aces.lib (Static library release)
acesd.lib (Static library debug)
这些库可分别实现了Debug/Release, MFC/Non-MFC, Static/Dynamic library.
其中前四个的dll在D:\软件安装\编程学习软件\ACE_wrappers\lib目录下, 所有对应的.lib库文件在D:\软件安装\编程学习软件\ACE_wrappers\ace下。
ACE是网络通讯中间件,如果机器没有装网卡,就仿真一个,比如可以从控制面板选装MS Loopback Adapter。
接下来我们创建一个新的工程,如果机器上装了不同版本的ACE,需要针对某个版本配置,方法如下:
1. 配置C/C++ tab
(1) Code Generation category中应选择合适的选项:
Multithreaded和Multithreaded DLL是for Release版的
Debug Multithreaded和Debug Multithreaded DLL是for Debug版的
(2) $(ACE_ROOT)路径的配置:
如果需要针对不同版本ACE灵活配置的话,则需要设置Preprocessor category中"Additional include directories"
这一项,指明特定版本ACE所在的路径,比如D:\软件安装\编程学习软件\ACE_wrappers
2. 链接到特定版本的ACE库。
(1) 在Project/Setting/Link的Input category下 "Additional library path"中增加特定版本的ACE库文件路径,
比如D:\软件安装\编程学习软件\ACE_wrappers\ace,然后将D:\软件安装\编程学习软件\ACE_wrappers\lib目录下对应的dll拷贝到工程文件所在路径下,或者在环境
变量PATH中加入D:\软件安装\编程学习软件\ACE_wrappers\lib。
(2) 在Project/Setting/Link的Input category下"Object/library modules" 中指定需要包含的ACE库(*.lib)
如果只装了一个ACE,可采用对所有工程都生效的缺省配置,方法如下:
1. 添加环境变量:
ACE_ROOT: D:\软件安装\编程学习软件\ACE_wrappers
PATH 中加入:D:\软件安装\编程学习软件\ACE_wrappers\lib
2. 设置VS的路径:
Include files包含:D:\软件安装\编程学习软件\ACE_wrappers
library files包含:D:\软件安装\编程学习软件\ACE_wrappers\ace
此后,就可以在工程中指定需要包含的ACE库(*.lib)后正常使用了。
二. Linux下的安装与配置
1.安装
以用户aceuser为例
(1)下载ACE-5.4+TAO-1.4+CIAO-0.4.tar.gz(其它版本的也一样)
(2)解压之
#cd /home/aceuser/ace
#tar -xzvf ACE-5.4+TAO-1.4+CIAO-0.4.tar.gz
(3)
#vi /home/aceuser/.bashrc
加入下面两行:
export ACE_ROOT=/home/aceuser/ace/ACE_wrappers
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ACE_ROOT/ace
并使这些环境变量生效(运行source 或者重新登陆)。
(4)
#cd /home/aceuser/ace/ACE_wrappers/ace/
#cp ./config-linux.h ./config.h
#cd ../include/makeinclude/
#ln -s ./platform_linux.GNU ./platform_macros.GNU
(5)编译
#cd /home/aceuser/ace/ACE_wrappers/ace/
#make
对于ACE-5.4+TAO-1.4+CIAO-0.4这个版本,不能ACE-5.4+TAO-1.4+CIAO-0.4.zip这个压缩包,否则会出现如下错误:
ln -s libACE.so.5.4.0 libACE.so
chmod a+rx libACE.so.5.4.0
: command not foundpers/lib/ace_components: line 10
'/home/aceuser/ace/ACE_wrappers/lib/ace_components: line 31: syntax error near unexpected token 'in
'/home/aceuser/ace/ACE_wrappers/lib/ace_components: line 31: ' case $1 in
make[1]: ***[ACE_COMONENTS] Error 2
make[1]: Leaving directory '/home/aceuser/ace/ACE_wrappers/ace'
make: ***[all] Error 2
如果换成ACE-5.4+TAO-1.4+CIAO-0.4.tar.gz就没有任何问题了
编译时也可以根据自己的需要设置编译选项
#make [options]
下面是option的描述:
Option Description
debug=1|0 Enable or disable debugging in the built library or program. Default is enabled (1).
optimize=1|0 Turn compiler optimization on or off. Default is off (0).
buildbits=bits Explicitly select, for example, 32-bit or 64-bit build target. Default is the compiler's default for the build machine. This option works for AIX, Solaris, and HP-UX.
exceptions=1|0 Enable or disable exception handling. Default is platform specific but usually enabled (1).
inline=1|0 Enable or disable inlining of many of ACE's methods. Default is platform specific but usually enabled (1).
templates=model Specify how templates are instantiated. Most common values for model are automatic, the default for compilers that support it well, and explicit, requiring source code directives to explicitly instantiate needed templates (see Section 1.6.1).
static_libs=1|0 Build and use static libraries. Default is to not build static libraries (0).
2.使用
下面介绍如何从零开始建立一个使用ACE的工程。并使之run起来
(1)编写使用了ACE的代码
(2)编写Makefile
lib = hello_ace
FILES = Piece2 Piece3
SRC= $(addsuffix .cpp,$(FILES))
OBJ= $(addsuffix .o,$(FILES))
BUILD = $(Vlib)
#---------------------------------------------------------
# Include macros and targets
#---------------------------------------------------------
include $(ACE_ROOT)/include/makeinclude/wrapper_macros.GNU
include $(ACE_ROOT)/include/makeinclude/macros.GNU
include $(ACE_ROOT)/include/makeinclude/rules.common.GNU
include $(ACE_ROOT)/include/makeinclude/rules.nonested.GNU
include $(ACE_ROOT)/include/makeinclude/rules.bin.GNU
include $(ACE_ROOT)/include/makeinclude/rules.local.GNU
以上的Makefile包含3个cpp文件hello_ace.cpp、Piece2.cpp和Piece3.cpp
(3)编译
#make
如果程序没有任何问题,现在程序应该就可以运行了。
http://wfpb.blogbus.com/logs/5597170.html
文件ace\config.h 定义了ACE_HAS_MFC ,这个是控制你的dll是否为MFC Dll用,我编译的是win32的Dll,所以这个编译我定义为#define ACE_HAS_MFC 0,否则会报error lnk2005: _dllmain@12 already defined in dllmain 的错误
文件ace\config-win32-common.h 文件中有各个编译选项的使用说明。
当初我安装ACE时,失败了几次,后来按照这个来,才完全成功。
如果大家有人使用VC助手的话,安装完后打开VC编写程序时,编译器最下面VX会不停的加载头文件,因为它要达到能够提示完成函数原形的功能,所以他要全部加载,但是每次都如此,会比较烦,你可以点击VX的option里设置一下directory,增加你的ace文件夹到里面,这样就OK了,终于可以爽爽的用了。
整理方法如下:
一. Windows下for MSVC的安装与配置
我们用的是ACE-5.4+TAO-1.4+CIAO-0.4.zip,Windows下解压缩该压缩包到目标路径(设为D:\软件安装\编程学习软件\ACE_wrappers ),
创建文件:$ACE_ROOT/ace/config.h,增加一行:
#i nclude "ace/config-win32.h"
如果是在Windows 9x/Me下,需要在$ACE_ROOT/ace/config.h中#i nclude语句前加入:
#define ACE_HAS_WINNT4 0
如果想使用standard C++ header,需要在$ACE_ROOT/ace/config.h中#i nclude语句前加入:
#define ACE_HAS_STANDARD_CPP_LIBRARY 1
如果想把MFC作为静态库链接到ACE(If you prefer to link MFC as a static library into ACE),
则需要在$ACE_ROOT/ace/config.h中#i nclude语句前加入:
#define ACE_HAS_MFC 1
如果想生成ACE静态库或在工程中使用ACE静态库,都需要定义以下宏:
ACE_AS_STATIC_LIBS
打开工程,D:\软件安装\编程学习软件\ACE_wrappers\ace.dsw,编译生成以下库:
ace.dll/ace.lib (DLL release)
aced.dll/aced.lib(DLL debug)
acemfc.dll/acemfc.lib (MFC DLL release)
acemfcd.dll/acemfcd.lib(MFC DLL debug)
aces.lib (Static library release)
acesd.lib (Static library debug)
这些库可分别实现了Debug/Release, MFC/Non-MFC, Static/Dynamic library.
其中前四个的dll在D:\软件安装\编程学习软件\ACE_wrappers\lib目录下, 所有对应的.lib库文件在D:\软件安装\编程学习软件\ACE_wrappers\ace下。
ACE是网络通讯中间件,如果机器没有装网卡,就仿真一个,比如可以从控制面板选装MS Loopback Adapter。
接下来我们创建一个新的工程,如果机器上装了不同版本的ACE,需要针对某个版本配置,方法如下:
1. 配置C/C++ tab
(1) Code Generation category中应选择合适的选项:
Multithreaded和Multithreaded DLL是for Release版的
Debug Multithreaded和Debug Multithreaded DLL是for Debug版的
(2) $(ACE_ROOT)路径的配置:
如果需要针对不同版本ACE灵活配置的话,则需要设置Preprocessor category中"Additional include directories"
这一项,指明特定版本ACE所在的路径,比如D:\软件安装\编程学习软件\ACE_wrappers
2. 链接到特定版本的ACE库。
(1) 在Project/Setting/Link的Input category下 "Additional library path"中增加特定版本的ACE库文件路径,
比如D:\软件安装\编程学习软件\ACE_wrappers\ace,然后将D:\软件安装\编程学习软件\ACE_wrappers\lib目录下对应的dll拷贝到工程文件所在路径下,或者在环境
变量PATH中加入D:\软件安装\编程学习软件\ACE_wrappers\lib。
(2) 在Project/Setting/Link的Input category下"Object/library modules" 中指定需要包含的ACE库(*.lib)
如果只装了一个ACE,可采用对所有工程都生效的缺省配置,方法如下:
1. 添加环境变量:
ACE_ROOT: D:\软件安装\编程学习软件\ACE_wrappers
PATH 中加入:D:\软件安装\编程学习软件\ACE_wrappers\lib
2. 设置VS的路径:
Include files包含:D:\软件安装\编程学习软件\ACE_wrappers
library files包含:D:\软件安装\编程学习软件\ACE_wrappers\ace
此后,就可以在工程中指定需要包含的ACE库(*.lib)后正常使用了。
二. Linux下的安装与配置
1.安装
以用户aceuser为例
(1)下载ACE-5.4+TAO-1.4+CIAO-0.4.tar.gz(其它版本的也一样)
(2)解压之
#cd /home/aceuser/ace
#tar -xzvf ACE-5.4+TAO-1.4+CIAO-0.4.tar.gz
(3)
#vi /home/aceuser/.bashrc
加入下面两行:
export ACE_ROOT=/home/aceuser/ace/ACE_wrappers
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ACE_ROOT/ace
并使这些环境变量生效(运行source 或者重新登陆)。
(4)
#cd /home/aceuser/ace/ACE_wrappers/ace/
#cp ./config-linux.h ./config.h
#cd ../include/makeinclude/
#ln -s ./platform_linux.GNU ./platform_macros.GNU
(5)编译
#cd /home/aceuser/ace/ACE_wrappers/ace/
#make
对于ACE-5.4+TAO-1.4+CIAO-0.4这个版本,不能ACE-5.4+TAO-1.4+CIAO-0.4.zip这个压缩包,否则会出现如下错误:
ln -s libACE.so.5.4.0 libACE.so
chmod a+rx libACE.so.5.4.0
: command not foundpers/lib/ace_components: line 10
'/home/aceuser/ace/ACE_wrappers/lib/ace_components: line 31: syntax error near unexpected token 'in
'/home/aceuser/ace/ACE_wrappers/lib/ace_components: line 31: ' case $1 in
make[1]: ***[ACE_COMONENTS] Error 2
make[1]: Leaving directory '/home/aceuser/ace/ACE_wrappers/ace'
make: ***[all] Error 2
如果换成ACE-5.4+TAO-1.4+CIAO-0.4.tar.gz就没有任何问题了
编译时也可以根据自己的需要设置编译选项
#make [options]
下面是option的描述:
Option Description
debug=1|0 Enable or disable debugging in the built library or program. Default is enabled (1).
optimize=1|0 Turn compiler optimization on or off. Default is off (0).
buildbits=bits Explicitly select, for example, 32-bit or 64-bit build target. Default is the compiler's default for the build machine. This option works for AIX, Solaris, and HP-UX.
exceptions=1|0 Enable or disable exception handling. Default is platform specific but usually enabled (1).
inline=1|0 Enable or disable inlining of many of ACE's methods. Default is platform specific but usually enabled (1).
templates=model Specify how templates are instantiated. Most common values for model are automatic, the default for compilers that support it well, and explicit, requiring source code directives to explicitly instantiate needed templates (see Section 1.6.1).
static_libs=1|0 Build and use static libraries. Default is to not build static libraries (0).
2.使用
下面介绍如何从零开始建立一个使用ACE的工程。并使之run起来
(1)编写使用了ACE的代码
(2)编写Makefile
lib = hello_ace
FILES = Piece2 Piece3
SRC= $(addsuffix .cpp,$(FILES))
OBJ= $(addsuffix .o,$(FILES))
BUILD = $(Vlib)
#---------------------------------------------------------
# Include macros and targets
#---------------------------------------------------------
include $(ACE_ROOT)/include/makeinclude/wrapper_macros.GNU
include $(ACE_ROOT)/include/makeinclude/macros.GNU
include $(ACE_ROOT)/include/makeinclude/rules.common.GNU
include $(ACE_ROOT)/include/makeinclude/rules.nonested.GNU
include $(ACE_ROOT)/include/makeinclude/rules.bin.GNU
include $(ACE_ROOT)/include/makeinclude/rules.local.GNU
以上的Makefile包含3个cpp文件hello_ace.cpp、Piece2.cpp和Piece3.cpp
(3)编译
#make
如果程序没有任何问题,现在程序应该就可以运行了。
相关文章推荐
- .NET工程中以 C 和 C++ 两种方式编译时,函数调用注意事项
- ACE服务端编程1:使用VS2010编译ACE6.0及从ACE5.6升级的注意事项
- c++ 中“”和NULL的注意事项
- 如何交叉编译应用程序,技巧,注意事项
- C++强制类型转换const_cast()注意事项
- Linux内核模块编译注意事项
- C++ 构造函数中使用new时注意事项
- C++异常注意事项
- .NET下编译C++代码时出现"error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int"错误的解决方法。
- [C++学习笔记]虚函数用法及注意事项
- C/C++程序设计注意事项(一)
- Qt5.8.0编译MySQL驱动注意事项
- C++输入输出注意事项总结
- 使用c++中string类的注意事项
- vs2010下使用nmake编译库的注意事项
- C++常用第三方库及使用注意事项
- pthread-win32库编译及使用方法注意事项
- crosstool-ng搭建交叉编译环境注意事项
- Linux/CentOS 升级C基本运行库CLIBC的注意事项(当想解决GLIBC_2.x找不到的编译问题)
- Mac OS X 平台上编译WebCore 注意事项