Android Studio 中的 CMake 3.4.1 版本 message打印日志以及输出位置

一、CMake 命令 message
CMake 如果要像用户展示消息需要可以使用 message() API,类似与 Android 中的 Log 输出。

message([<mode>] "message to display" ...)

关键字,可以指定消息的类型:

(none)         = 重要消息
STATUS         = 附带消息
WARNING        = CMake警告,继续处理
AUTHOR_WARNING = CMake警告(dev),继续处理
SEND_ERROR     = CMake错误,继续处理,但跳过生成
FATAL_ERROR    = CMake错误,停止处理和生成
DEPRECATION    = 如果分别启用了变量CMAKE_ERROR_DEPRECATED或CMAKE_WARN_DEPRECATED,则CMake弃用错误或警告,否则无消息

二、使用示例
简单演示上面前三种,打印一些变量值:

message("CMAKE_SOURCE_DIR = ${CMAKE_SOURCE_DIR}")
message(STATUS "PROJECT_SOURCE_DIR = ${PROJECT_SOURCE_DIR}")
message(WARNING "CMAKE_BINARY_DIR = ${CMAKE_BINARY_DIR}")
//添加日志打印出来
message("AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA>>>")
message("当前CMake的路径是:${CMAKE_SOURCE_DIR}")

演示效果如下图所示
在这里插入图片描述三、输出内容 CMake 会保存到文本中
输出内容 CMake 会保存到文本中,包括前面的 3.4.1 版本,目录是:

E:\wangqi\work\dongnao\MyVideoPlayer\app\.cxx\cmake\debug\arm64-v8a\build_output.txt

在这里插入图片描述

JNI(Java Native Interface)是一种允许Java代码与本地代码(如C或C++)交互的编程桥梁。在Android Studio使用JNI可以调用本地代码来实现一些高性能的功能或访问底层系统资源。 要在Android Studio使用JNI,首先需要创建一个JNI接口文件(.h),该文件将定义Java和本地代码之间的函数接口。然后,使用ndk-build工具或CMake配置来构建本地代码库。 下面是一个简单的步骤来使用JNI: 1. 在Android Studio项目,创建一个名为"jni"的文件夹,并在其创建一个名为"native-lib.cpp"的C++源文件。 2. 在native-lib.cpp实现自己的本地函数,可以通过JNI调用这些函数。 ```cpp #include <jni.h> extern "C" JNIEXPORT jstring JNICALL Java_com_example_myapp_MainActivity_getMessageFromJNI(JNIEnv* env, jobject /* this */) { return env->NewStringUTF("Hello from JNI!"); } ``` 3. 在项目的build.gradle文件,添加NDK配置。 ```groovy android { // ... defaultConfig { // ... externalNativeBuild { cmake { cppFlags "" } } } // ... externalNativeBuild { cmake { path "CMakeLists.txt" } } } ``` 4. 在项目根目录下创建一个名为"CMakeLists.txt"的文件,并设置构建本地代码的相关设置。 ```cmake cmake_minimum_required(VERSION 3.4.1) add_library(native-lib SHARED native-lib.cpp) find_library(log-lib log) target_link_libraries(native-lib ${log-lib}) ``` 5. 在MainActivity.java,加载本地库并调用本地函数。 ```java public class MainActivity extends AppCompatActivity { static { System.loadLibrary("native-lib"); } // ... public native String getMessageFromJNI(); // ... @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 调用本地函数 String message = getMessageFromJNI(); Log.d("JNI", message); } } ``` 这样就可以在Android Studio使用JNI来调用本地代码了。需要注意的是,使用JNI需要熟悉C/C++编程,并且需要手动管理Java和本地代码之间的内存和类型转换。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值