打字猴:1.70043958e+09
1700439580
1700439581 我们来分析一个案例,展现一下脚本语言是如何实现“拥抱变化”的。咱们编写一套模型计算公式,预测下一个工作日的股票走势(如果真有,那巴菲特就羞愧死了),即把国家政策、汇率、利率、地域系数等参数输入到公式中,然后计算出明天这支股票是涨还是跌,该公式是依靠历史数据推断而来的,会根据市场环境逐渐优化调整,也就是逐渐趋向“真理”的过程,在此过程中,公式经常需要修改(这里的修改不仅仅是参数修改,还涉及公式的算法修改),如果把这个公式写到一个类中(或者几个类中),就需要经常发布重启等操作(比如业务中断,需要冒烟测试(Smoke Testing)等),使用脚本语言则可以很好地简化这一过程,我们写一个简单公式来模拟一下,代码如下:
1700439582
1700439583 function formula(var1,var2){
1700439584
1700439585 return var1+var2*factor;
1700439586
1700439587 }
1700439588
1700439589 这就是一个简单的脚本语言函数,可能你会很疑惑:factor(因子)这个变量是从哪儿来的?它是从上下文来的,类似于一个运行的环境变量。该JavaScript保存在C:/model.js中。下一步Java需要调用JavaScript公式,代码如下:
1700439590
1700439591 public static void main(String[]args)throws Exception{
1700439592
1700439593 //获得一个JavaScript的执行引擎
1700439594
1700439595 ScriptEngine engine=new ScriptEngineManager().getEngineByName(“javascript”);
1700439596
1700439597 //建立上下文变量
1700439598
1700439599 Bindings bind=engine.createBindings();
1700439600
1700439601 bind.put(“factor”,1);
1700439602
1700439603 //绑定上下文,作用域是当前引擎范围
1700439604
1700439605 engine.setBindings(bind, ScriptContext.ENGINE_SCOPE);
1700439606
1700439607 Scanner input=new Scanner(System.in);
1700439608
1700439609 while(input.hasNextInt()){
1700439610
1700439611 int first=input.nextInt();
1700439612
1700439613 int sec=input.nextInt();
1700439614
1700439615 System.out.println(“输入参数是:”+first+”,”+sec);
1700439616
1700439617 //执行js代码
1700439618
1700439619 engine.eval(new FileReader(“c:/model.js”));
1700439620
1700439621 //是否可调用方法
1700439622
1700439623 if(engine instanceof Invocable){
1700439624
1700439625 Invocable in=(Invocable)engine;
1700439626
1700439627 //执行js中的函数
1700439628
1700439629 Double result=(Double)in.invokeFunction(“formula”,frst, sec);
[ 上一页 ]  [ :1.70043958e+09 ]  [ 下一页 ]