Linux cmake使用入门
cmake安装本人的机器为ubuntu 10.04,在连网的情况下直接在终端输入:root@zsh-linux:~#apt-get install cmake 安装完毕之后可以在/var/cache/apt/archives看到安装的.deb文件 或者在cmake官网下载cmake for linux 此时有个注意点是建议下载 cmake-2.8.4.tar.gz ...
cmake安装
本人的机器为ubuntu 10.04,在连网的情况下直接在终端输入:
root@zsh-linux:~#apt-get install cmake
安装完毕之后可以在/var/cache/apt/archives看到安装的.deb文件
或者在cmake官网下载cmake for linux
此时有个注意点是建议下载 cmake-2.8.4.tar.gz 而不是cmake-2.8.4-Linux-i386.tar.gz
下载完成后解压
root@zsh-linux:/opt#tar -zxvf cmake-2.8.4.tar.gz
root@zsh-linux:/opt# cd cmake-2.8.4
root@zsh-linux:/opt/cmake-2.8.4#
root@zsh-linux:/opt/cmake-2.8.4# ./bootstrap
root@zsh-linux:/opt/cmake-2.8.4# make
root@zsh-linux:/opt/cmake-2.8.4# make install
安装完毕后查看是否安装成功:
root@zsh-linux:/opt/cmake-2.8.4# cmake --version
cmake version 2.8.4
有以上信息表示安装cmake成功。
cmake 的使用
(1)创建一个工程目录文件夹,然后创建一个hello.c
#include<stdio.h>
int main()
{
printf(“hello,this is my first using cmake project/n”);
return 0;
}
(2)然后创建一个build目录(用于编译生成的相应文件),与hello.c目录同级
(3)编写CMakeLists.txt内容如下:(于hello.c目录同级)
cmake_minimum_required(VERSION 2.8)
PROJECT(cmake_test)
SET(SRC_LIST main.c)
INCLUDE_DIRECTORIES(/usr/include/glib)
MESSAGE(STATUS "This is BINARY dir "${HELLO_BINARY_DIR})
MESSAGE(STATUS "This is SOURCE dir "${HELLO_SOURCE_DIR})
ADD_EXECUTABLE(hello ${SRC_LIST})
(4)进入build目录输入 cmake ..
root@zsh-linux:/home/cmake_test/build# cmake ..
若编译成功在build目录下会生成相应文件,其中有个makefile文件
有可能会出现问题:
CMAKE_CXX_COMPILER-NOTFOUND" was not found
解决方法:
root@zsh-linux:/home/cmake_test/build# apt-get install g++
(可选)cmake -D CMAKE_CXX_COMPLIER=”g++”CMAKE -D CMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX:PATH=”/usr/local”
(5)输入make 命令执行成功后在build目录下会看到可执行的hello
(6)./hello
输出 hello,this is my first usingcmake project。
注:这只适用于简单的工程,若复杂的工程项目请参考www.cmake.org
你觉得makefile看着就头痛,如果当工程越来越大,你越来越手足无措,如果你厌倦了在编译的时候打上一大堆命令,那么你有必要花十分钟来看一下下面的内容。
一、HelloWorld
首先创建一个test1文件夹,里面创建一个main.c文件,内容如下:
#include <stdio.h>
int main()
{
printf("Hello World!\n");
return 0;
}
再创建一个CMakeLists.txt
PROJECT (HELLO)
SET(SRC_LIST main.c)
ADD_EXECUTABLE(hello ${SRC_LIST})
第一行:设置项目名称;
第二行:将SRC_LIST值设置为main.c
第三行:生成可执行文件 hello。 ${} 是引用某个值。
Terminal中cd进入到test1目录,创建一个build目录用于外部构建(编译所产生的文件都生成在build目录),依次执行下面三条命令:
cmake ..
make
./hello
得到的结果如下:
如果要引用内部库的话,比如是关于SDL和opengl的程序,需要在CMakeLists.txt中添加
TARGET_LINK_LIBRARIES(hello SDL)
TARGET_LINK_LIBRARIES(hello GLU)
对应终端的编译命令就是:
-lSDL -lGLU
若不是引用内部库,则需要将相应目录添加进来,用到的是INCLUDE_DIRECTORIES命令。
二、库的构建与安装
这次我们的目标是:
1,建立一个静态库和动态库,提供 HelloFunc 函数供其他程序编程使用,HelloFunc 向终端输出
Hello World 字符串。
2,安装头文件与共享库。
目录安排如下:
build-用于外部编译;
libhello-hello库的源文件;
src-主程序
首先看libhello里的文件:
/*filename:hello.h*/
#ifndef DBZHANG_HELLO_
#define DBZHANG_HELLO_
void hello(const char* name);
#endif //DBZHANG_HELLO_
/*filename:hello.c*/
#include <stdio.h>
#include "hello.h"
void hello(const char * name)
{
printf ("Hello %s!\n", name);
}
CMakeLists.txt
cmake_minimum_required(VERSION 2.8)
set(LIB_SRC hello.c)
add_library(libhello STATIC ${LIB_SRC})
set(LIBRARY_OUTPUT_PATH ${PROJECT_BINARY_DIR}/lib)
set_target_properties(libhello PROPERTIES OUTPUT_NAME "hello")
install(TARGETS libhello
LIBRARY DESTINATION lib
ARCHIVE DESTINATION lib)
install(FILES hello.h DESTINATION include/hello)
src文件夹
/*filename:main.c*/
#include "hello.h"
int main()
{
hello("Jack");
return 0;
}
CMakeLists.txt
cmake_minimum_required(VERSION 2.8)
include_directories(${PROJECT_SOURCE_DIR}/libhello)
set(APP_SRC main.c)
set(EXECUTABLE_OUTPUT_PATH ${PROJECT_BINARY_DIR}/bin)
add_executable(main ${APP_SRC})
target_link_libraries(main libhello)
最外面的CMakeLists.txt
project(HELLO)
add_subdirectory(src)
add_subdirectory(libhello)
解释:
除build目录外每一个目录都要建立一个CMakeLists.txt.
生成库的语句:add_library(libhello STATIC ${LIB_SRC})
这条语句是建立静态库,若要建立动态库的话将STATIC改成SHARED.
install命令负责库的安装。
make一下,结果就像这样:
再sudo make install.
安装好库之后,我们在想使用hello方法的时候,只要添加头文件#include就可以了,编译的时候
g++ main .c -o main -lhello
就可以引用我们编译好的库了。
更多推荐
所有评论(0)