jni system.out和printf行为

 2023-01-21    256  

问题描述

我正在编写一个程序,该程序使用JNI与简单的C程序接口.我创建了以下程序:

public static void main(String[] args) {
    Hello h = new Hello();
    System.out.println("before");
    int number = h.sayHello();
    System.out.println(number);
    System.out.println("after");
}

jni system.out和printf行为

JNIEXPORT int JNICALL Java_Hello_sayHello (JNIEnv *env, jobject obj) {
     printf("Hello JNI\n");
     return 10;
}

令我惊讶的是,这个程序返回:

before
10
after
Hello JNI

对我来说,这很奇怪,因为很明显,C程序是在”之前”和”后”语句之间执行的(打印了第10个语句).但是,为什么printf语句被调用时未执行.它是否以某种方式被JVM阻止,因为仅允许一个程序同时写入输出?有没有办法纠正此行为?

推荐答案

是.您需要致电flush.

在C中,那就是 fflush call –

printf("Hello JNI\n");
fflush(stdout);
return 10;

在Java中,那就是 flush 在流 –

System.out.println("before");
System.out.flush();

以上所述是小编给大家介绍的jni system.out和printf行为,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对77isp云服务器技术网的支持!

原文链接:https://77isp.com/post/26204.html

=========================================

https://77isp.com/ 为 “云服务器技术网” 唯一官方服务平台,请勿相信其他任何渠道。