1. CMake 系列 – 从零构建动态库和静态库

1. CMake 系列 – 从零构建动态库和静态库

1. 文件目录结构

首先创建如下目录结构

└── lib
    ├── build # ├── CMakeLists.txt └── src # ├── add.c └── add.h 

从上面的结构,可以看出博主想实现一个具备简单加法的库。

build:存放cmake生成的makefile文件,make编译生成的中间文件。

CMakeLists.txt:使用cmake语法编写相关指令,用于生成makefile

src:库文件的源代码

2. 库文件源代码

add.h

#ifndef _ADD_H #define _ADD_H int add(const int a, const int b); #endif

add.c

#include "add.h" int add(const int a, const int b) { return a+b; } 

3. 编译生成库文件

CMakeLists.txt

# 指定cmake最小版本 cmake_minimum_required(VERSION 2.6) project(add) message("Project Name: " ${PROJECT_NAME}) #设置编译参数 set(CMAKE_C_FLAGS "-g -Wall") #设置库文件文件输出目录 set(LIBRARY_OUTPUT_PATH ${PROJECT_SOURCE_DIR}/lib) #递归获取目录下所有的C文件 file(GLOB_RECURSE c_files ${PROJECT_SOURCE_DIR}/src/*.c) #生成动态库和静态库 add_library(add_lib_shared SHARED ${c_files}) add_library(add_lib_static STATIC ${c_files}) #将动态库和静态库的名字设置为 add set_target_properties(add_lib_shared PROPERTIES OUTPUT_NAME "add") set_target_properties(add_lib_static PROPERTIES OUTPUT_NAME "add") #设置动态库版本 set_target_properties(add_lib_shared PROPERTIES VERSION 1.0 SOVERSION 1)

编译

$ cd build $ cmake .. $ make $ cd .. $ tree lib

效果如下

lib ├── libadd.a ├── libadd.so -> libadd.so.1 ├── libadd.so.1 -> libadd.so.1.0 └── libadd.so.1.0 
出处:https://www.cnblogs.com/standardzero/p/10781227.html
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/119546.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • MySql数据库explain用法示例_mysql explain用法详解

    MySql数据库explain用法示例_mysql explain用法详解explain显示了mysql如何使用索引来处理select语句以及连接表。可以帮助选择更好的索引和写出更优化的查询语句。使用方法,在select语句前加上explain就可以了,如:explainselect*fromstatuses_statuswhereid=11;创建测试表:CREATETABLEpeople(idintauto_incrementprimarykey…

    2022年10月24日
    0
  • SparkStreaming的介绍及原理

    SparkStreaming的介绍及原理一、SparkStreaming的介绍1.离线和流处理的区别1)离线处理是针对一个批次,这个批次一般情况下都比较大流处理对应的数据是连续不断产生,处理时间间隔非常短的数据2)离线处理程序,因为数据是有限的(bounded),所以会终止流数据因为是连续不断的产生,所以数据是无限的(unbounded)由于数据的特征,一般离线处理比较缓慢,流数据处理相对较快流处理:…

    2022年6月20日
    36
  • Windows系统日志分析_windows系统事件日志

    Windows系统日志分析_windows系统事件日志Windows操作系统的日志分析Windows日志简介Windows操作系统在其运行的生命周期中会记录其大量的日志信息,这些日志信息包括:Windows事件日志,Windows服务器角色日志,FTP日志,邮件服务日志,MSSQLServer数据库日志等。主要记录行为当前的日期、时间、用户、计算机、信息来源、事件、类型、分类等信息。用户可以通过它来检查错误发生的原因,处理应急事件,提供溯源,这些日志信息在取证和溯源中扮演着重要的角色。Windows日志事件类型Windows操作系统日志分析Wi

    2022年9月7日
    0
  • HA高可用集群(双机热备)

    HA高可用集群(双机热备)

    2021年9月13日
    144
  • 2021年7月总结

    2021年7月总结

    2022年2月19日
    35
  • Java IO流处理 面试题汇总

    Java IO流处理 面试题汇总说明:本节内容来源于网络汇总输入输出流是相对于内存而言的!1、面试题汇总(1)java中有几种类型的流?字符流和字节流。字节流继承inputStream和OutputStream,字符流继承自InputSteamReader和OutputStreamWriter。(2)谈谈JavaIO里面的常见类,字节流,字符流、接口、实现类、方法阻塞答:输入流就…

    2022年6月14日
    24

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号