简单的C++加载jvm实现--简单的日志输出--JAVA端程序

来源:互联网 发布:can总线控制伺服编程 编辑:程序博客网 时间:2024/06/05 19:23

前面做好了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);


五,改造java输出内容:
//如果C++端未传入参数,使用args会导致C++程序出错,如下处理可以避免报错LogFactory.log("Hello world" + (args == null||args.length == 0?"":Arrays.asList(args)));


六,输出结果:








0 0