0

0

c++如何与Java交互 c++ JNI入门教程【指南】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-04 13:41:23

|

962人浏览过

|

来源于php中文网

原创

Java通过JNI调用C++的规范流程是:声明native方法→生成头文件→C++按签名实现→编译为动态库→Java加载调用;需注意extern "C"、函数命名、字符串API使用及架构匹配。

c++如何与java交互 c++ jni入门教程【指南】

Java 通过 JNI(Java Native Interface)机制调用 C++ 代码,这是官方支持、稳定可靠的方式。核心思路是:Java 声明 native 方法 → 编译生成头文件 → C++ 实现该方法 → 编译为动态库 → Java 加载并调用。

一、Java 端准备:声明 native 方法并生成头文件

写一个 Java 类,用 native 关键字声明要由 C++ 实现的方法,并确保类已编译:

public class Calculator {
    static {
        System.loadLibrary("calculator"); // 加载名为 libcalculator.so(Linux)或 calculator.dll(Windows)的本地库
    }
    public native int add(int a, int b);
    public native String sayHello(String name);
}

进入该 .class 文件所在目录,运行命令生成 JNI 头文件:

javac Calculator.java
javah -jni Calculator

会生成 Calculator.h,其中包含类似 JNIEXPORT jint JNICALL Java_Calculator_add 的函数签名——这就是你要在 C++ 中实现的函数名,不能拼错。

立即学习Java免费学习笔记(深入)”;

二、C++ 端实现:包含头文件,按签名编写函数

新建 calculator.cpp,包含必要的头文件,并严格按生成的函数名和参数类型实现:

#include 
#include 

extern "C" { // 防止 C++ 名字修饰,确保函数符号可被 Java 正确找到

JNIEXPORT jint JNICALL Java_Calculator_add(JNIEnv *env, jobject obj, jint a, jint b) {
    return a + b;
}

JNIEXPORT jstring JNICALL Java_Calculator_sayHello(JNIEnv *env, jobject obj, jstring name) {
    const char *str = env->GetStringUTFChars(name, nullptr);
    std::string hello = "Hello, " + std::string(str);
    env->ReleaseStringUTFChars(name, str); // 必须释放,否则内存泄漏
    return env->NewStringUTF(hello.c_str());
}

}

注意要点:

  • 必须用 extern "C" 包裹函数,否则链接失败
  • 函数名、参数顺序、返回类型必须与 .h 文件完全一致
  • 字符串操作要用 env 提供的 API(如 GetStringUTFChars / NewStringUTF),不能直接用 C++ string 转换
  • jobject 参数代表调用该方法的 Java 对象(若为 static 方法可忽略)

三、编译为动态库:匹配平台与 JDK 架构

根据操作系统选择对应命令,确保使用的 javacjavah 来自同一 JDK,且编译器架构(x86/x64)一致:

叮当好记-AI音视频转图文
叮当好记-AI音视频转图文

AI音视频转录与总结,内容学习效率 x10!

下载

Linux(生成 libcalculator.so):

g++ -shared -fPIC -I${JAVA_HOME}/include -I${JAVA_HOME}/include/linux \
    calculator.cpp -o libcalculator.so

macOS(生成 libcalculator.dylib):

g++ -shared -fPIC -I${JAVA_HOME}/include -I${JAVA_HOME}/include/darwin \
    calculator.cpp -o libcalculator.dylib

Windows(生成 calculator.dll,需 MinGW 或 MSVC):

g++ -shared -I"%JAVA_HOME%\include" -I"%JAVA_HOME%\include\win32" \
    calculator.cpp -o calculator.dll

关键点:

  • -I 指向 JDK 的 include 及子目录(如 linux/win32/darwin),否则找不到 jni.h
  • 必须加 -shared(Linux/macOS)或对应 DLL 编译选项(Windows)
  • 输出库名要与 System.loadLibrary("xxx") 中的名字一致(不带前缀 lib/后缀 .so/.dll)

四、运行与调试常见问题

将生成的动态库放在 Java 运行时能加载到的位置(如当前目录、LD_LIBRARY_PATH、java.library.path 指定路径),然后运行:

java Calculator

典型报错及对策:

  • UnsatisfiedLinkError: no xxx in java.library.path → 库文件名不对、路径未配置、或系统位数(32/64)与 JVM 不匹配
  • UnsatisfiedLinkError: ... wrong ELF class(Linux)→ 编译目标架构与 JVM 不一致(如用 32 位 g++ 编译,却用 64 位 java 运行)
  • 程序崩溃或乱码 → 字符串未正确释放(GetStringUTFChars 后没 Release)、空指针未判空、JNIEnv 在线程间误用(每个线程需独立 Attach/Detach)

进阶提示:JNI 函数调用开销较大,高频场景建议批量传参;复杂对象交互可用 JNI 提供的 GetObjectField / SetObjectField 等 API;生产环境推荐结合 JNA(更轻量)或 GraalVM(AOT 直接互调)替代部分 JNI 场景。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

826

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

731

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

732

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

396

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16904

2023.08.03

从零到实战:Python 编程系统入门专题
从零到实战:Python 编程系统入门专题

本专题面向零编程基础及初学者,系统讲解 Python 编程语言的核心知识与实战技巧。内容涵盖 Python 基础语法、数据结构、函数与模块、常用标准库、简单算法思维,以及真实应用场景下的小项目实战。通过循序渐进的学习路径,帮助读者快速建立编程思维,掌握 Python 在数据处理、自动化脚本及日常开发中的实际应用能力,为后续深入学习 Web 开发、数据分析或人工智能打下坚实基础。

2

2026.01.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.6万人学习

Git 教程
Git 教程

共21课时 | 2.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号