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");
}
和
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/ 为 “云服务器技术网” 唯一官方服务平台,请勿相信其他任何渠道。
数据库技术 2022-03-28
网站技术 2022-11-26
网站技术 2023-01-07
网站技术 2022-11-17
Windows相关 2022-02-23
网站技术 2023-01-14
Windows相关 2022-02-16
Windows相关 2022-02-16
Linux相关 2022-02-27
数据库技术 2022-02-20
抠敌 2023年10月23日
嚼餐 2023年10月23日
男忌 2023年10月22日
瓮仆 2023年10月22日
簿偌 2023年10月22日
扫码二维码
获取最新动态