前面做好了C++端程序的简单日志输出,接下来到启动的JAVA程序输出日志了。为了尽量的精简,所以不考虑使用log4j,使用java自带的IO流输出。
一,对原来的工程进行改造:
public class HelloWorld {
public static void main(String[] args) {
try {
//可以设置系统参数改变日志输出位置
String jvmStdFile = System.getProperty("jvmlog",".\\LoadJVMDemoJ.log");
File file = new File(jvmStdFile);
if(!file.exists()){
file.getParentFile().mkdirs();
file.createNewFile();
}
//采用流式输出,格式使用UTF-8格式,避免一些乱码
FileOutputStream fos = new FileOutputStream(jvmStdFile);
System.setOut(new PrintStream(new BufferedOutputStream(fos, 128), true, "UTF-8"));
System.setErr(new PrintStream(new BufferedOutputStream(fos, 128), true, "UTF-8"));
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
LogFactory.log("Hello world");
}
}
二,新建一个LogFactory类对输出的日志进行格式化:
public class LogFactory {
/**
* 输出日志,以后考虑设置日志级别
*/
public static String log(String log){
String logout = setFormatLog(log);
System.out.println(logout);
return logout;
}
/**
* 设置日志的格式:yyy-MM-dd hh-mm-ss SSS
*/
public static String setFormatLog(String log){
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("[yyyy-MM-dd HH:mm:ss.SSS]");
String logDate = sdf.format(date);
return logDate + ":" + log;
}
}
三,传入参数进行输出
1,首先定义传入的参数
//传入参数,如果有
int nParamcount = 2;
const char * params[2] = {"aaaaa","bbbbbb"};
2,将传入对象转换成字符串数组
//定义穿入数组
jobjectArray args;
jclass strClass = env->FindClass("java/lang/String");
if (env->ExceptionCheck() == JNI_TRUE || strClass == NULL) {
env->ExceptionDescribe();
env->ExceptionClear();
outLog("查找字符串累失败", GetLastError());
return false;
}
//转换传入对象成字符串数组
args = env->NewObjectArray(nParamcount, strClass, NULL);
if (args == 0) {
jvm->DestroyJavaVM();
return false;
}
//从参数中取出字符转化成java字符串对象
jstring jstr = NULL;
for (int i = 0; i < nParamcount; i++) {
jstr = env->NewStringUTF(params[i]);
if (jstr == 0) {
jvm->DestroyJavaVM();
return false;
}
//java字符串对象放入数组
env->SetObjectArrayElement(args, i, jstr);
if (env->ExceptionCheck() == JNI_TRUE) {
jvm->DestroyJavaVM();
return false;
}
}
四,调用方法接收参数:
env->CallStaticVoidMethod(mainclass, methedID, args);
//如果C++端未传入参数,使用args会导致C++程序出错,如下处理可以避免报错
LogFactory.log("Hello world" + (args == null||args.length == 0?"":Arrays.asList(args)));