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

前面做好了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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值