MySQL cmake教程_CMake快速使用教程

如果你觉得makefile看着就头痛,如果当工程越来越大,你越来越手足无措,如果你厌倦了在编译的时候打上一大堆命令,那么你有必要花十分钟来看一下下面的内容。

一、HelloWorld

首先创建一个test1文件夹,里面创建一个main.c文件,内容如下:

#include

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

得到的结果如下:

3901b764195db311f06c5ebf6377fe38.png

如果要引用内部库的话,比如是关于SDL和opengl的程序,需要在CMakeLists.txt中添加

TARGET_LINK_LIBRARIES(hello SDL)

TARGET_LINK_LIBRARIES(hello GLU)

对应终端的编译命令就是:

-lSDL -lGLU

若不是引用内部库,则需要将相应目录添加进来,用到的是INCLUDE_DIRECTORIES命令。

二、库的构建与安装

这次我们的目标是:

1,建立一个静态库和动态库,提供 HelloFunc 函数供其他程序编程使用,HelloFunc 向终端输出

Hello World 字符串。

2,安装头文件与共享库。

目录安排如下:

93e2d4be66c3fba5599b115ea1f8ea06.png

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

#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一下,结果就像这样:

25ca6d7746978a9ed634de553655763f.png

再sudo make install.

7895a0aea777c9878050823d597d1da6.png

安装好库之后,我们在想使用hello方法的时候,只要添加头文件#include就可以了,编译的时候

g++ main .c -o main -lhello

就可以引用我们编译好的库了。

CMake 的详细介绍:请点这里

CMake 的下载地址:请点这里

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值