Linux虚拟机 CMakeLists.txt:x86 与 ARM 双架构编译脚本

简易 CMakeLists.txt

复制代码
cmake_minimum_required (VERSION 3.5)
project (HelloWorld)

# 生成编译数据库(帮助编辑器理解代码)
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)

# -Werror -Wreturn-type -Wextra
set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -std=c++14")

# 根据构建类型 自动选择 优化级别,-g:生成调试信息
if(CMAKE_BUILD_TYPE STREQUAL "Release")
    set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -O2")
else()
    set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -O0 -g")
endif()

include_directories(${PROJECT_SOURCE_DIR}/include)

set (source_dir "${PROJECT_SOURCE_DIR}/src/")
file (GLOB source_files "${source_dir}/*.cpp")

add_executable (${PROJECT_NAME} ${source_files})

# 打印编译器信息(便于调试)
message(STATUS "C Compiler: ${CMAKE_C_COMPILER}")
message(STATUS "CXX Compiler: ${CMAKE_CXX_COMPILER}")

脚本 build-x86.sh ,生成 x86 C/C++ 可执行程序

复制代码
#!/bin/bash

# x86架构 构建目录
BUILD_DIR=build_x86

# 清理并构建
rm -rf ${BUILD_DIR}
mkdir ${BUILD_DIR}
cd ${BUILD_DIR}

# 使用系统x86编译器, 模式: Debug/Release
cmake .. \
    -DCMAKE_C_COMPILER=/usr/bin/gcc \
    -DCMAKE_CXX_COMPILER=/usr/bin/g++ \
    -DCMAKE_BUILD_TYPE=Release

make -j$(nproc)

脚本 build-arm.sh,生成 ARM C/C++ 可执行程序

复制代码
#!/bin/bash
ARM_GCC=/usr/local/arm/gcc-linaro-4.9.4-2017.01-x86_64_arm-linux-gnueabihf/bin/arm-linux-gnueabihf-gcc
ARM_GXX=/usr/local/arm/gcc-linaro-4.9.4-2017.01-x86_64_arm-linux-gnueabihf/bin/arm-linux-gnueabihf-g++

# 检查 arm 编译器是否存在
if [ ! -f "$ARM_GCC" ]; then
    echo "Error: ARM C compiler not found: $ARM_GCC"
    exit 1
fi

if [ ! -f "$ARM_GXX" ]; then
    echo "Error: ARM C++ compiler not found: $ARM_GXX"
    exit 1
fi

# ARM架构 构建目录
BUILD_DIR=build_arm
# 清理并构建
rm -rf ${BUILD_DIR}
mkdir ${BUILD_DIR}
cd ${BUILD_DIR}

# 使用 ARM 交叉编译器, 模式: Debug/Release
cmake .. \
    -DCMAKE_C_COMPILER=$ARM_GCC \
    -DCMAKE_CXX_COMPILER=$ARM_GXX \
    -DCMAKE_C_COMPILER_FORCED=ON \
    -DCMAKE_CXX_COMPILER_FORCED=ON \
    -DCMAKE_BUILD_TYPE=Release

make -j$(nproc)
复制代码
# 安装 tree
sudo apt install tree
复制代码
# 显示目录结构
tree -L 2 --dirsfirst

几行代码的小文件,为什么编译后的可执行文件 变大数倍?我的 include 测试笔记:

复制代码
# 只预处理,不编译
g++ -E src/Main.cpp -I include

# 统计行数
g++ -E src/Main.cpp -I include | wc -l
# 你会看到几万行!

# 查看最后几行
g++ -E src/Main.cpp -I include | tail -20
复制代码
# 原始文件行数
cat src/Main.cpp | wc -l
复制代码
# 预处理后行数(包含 iostream)
g++ -E src/Main.cpp -I include | wc -l

查看编译后的汇编代码

复制代码
# 生成汇编文件(.s 文件)
g++ -S src/Main.cpp -I include -o Main.s

# 查看汇编代码
cat Main.s

代码:

复制代码
int fun(int a, int b)
{
    int ret;
    ret = a * b;
    return ret;
}

代码优化:

复制代码
int fun(int a, int b)
{
    return a * b;
}
相关推荐
卷无止境16 小时前
C++ 的Eigen 库全解析
c++
卷无止境16 小时前
现代 C++特性大盘点:一门脱胎换骨的老语言
c++·后端
郝学胜_神的一滴18 小时前
CMake 27:缓存变量的特性、语法、类型与实操全解
c++·cmake
Web3探索者1 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo2 天前
Linux系统中网线与USB网络共享冲突
linux
荣--2 天前
在 strip 二进制 + 基址随机化的栈里做崩溃去重 —— 三阶段算法与一行 Crash Flag
嵌入式·崩溃分析·栈指纹·去重算法
博客18003 天前
酷宝的使用方法,超好用的免费界面库,C++、MFC可用
c++·mfc·界面库·库来帮·酷宝
释然小师弟3 天前
Android开发十年:反思与回顾
android·后端·嵌入式
郝学胜_神的一滴3 天前
CMake 026:属性体系精讲、四大作用域全解 & 实战代码落地
c++·cmake
Sokach10153 天前
Linux Shell 脚本从零到能用:一个新手的一天学习总结
linux