亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java動態(tài)腳本Groovy

 更新時間:2021年12月14日 10:51:06   作者:南國以南i  
本文介紹了Java動態(tài)腳本Groovy,Groovy是用于Java虛擬機的一種敏捷的動態(tài)語言,它是一種成熟的面向?qū)ο缶幊陶Z言,既可以用于面向?qū)ο缶幊蹋挚梢杂米骷兇獾哪_本語言。使用該種語言不必編寫過多的代碼,同時又具有閉包和動態(tài)語言中的其他特性,需要的朋友可以參考一下

1.Groovy特性

可將java代碼在Groovy腳本動態(tài)編碼、代碼被修改達到不重啟服務(wù)的目的(類似于熱部署)

2.核心涉及

  • ClassLoader:就是類的裝載器,它使JVM可以動態(tài)的載入Java類,JVM并不需要知道從什么地方(本地文件、網(wǎng)絡(luò)等)載入Java類,這些都由ClassLoader完成。
  • GroovyClassLoader:動態(tài)地加載一個腳本并執(zhí)行它的行為。GroovyClassLoader是一個定制的類裝載器,負(fù)責(zé)解釋加載Java類中用到的Groovy類。

3.Java與Groovy轉(zhuǎn)換

第一步:引入Groovy依賴

   <!--Groovy腳本依賴-->
        <dependency>
            <groupId>org.codehaus.groovy</groupId>
            <artifactId>groovy</artifactId>
            <version>2.5.14</version>
        </dependency>

第二步:創(chuàng)建interface接口聲明方法

public interface CallAnalysis {
     default void load() {
    }
}

第三步:在resources目錄下創(chuàng)建.groovy文件

package groovy

import com.example.groovy.testgroovy.task.CallAnalysis
import groovy.util.logging.Slf4j

@Slf4j
class CallAnalysisImpl implements CallAnalysis{

    @Override
    void load() {
        log.info("我被Groovy腳本加載...")
    }
}

第四步:創(chuàng)建Groovy腳本裝載類,動態(tài)解析腳本為Class

package com.example.groovy.testgroovy.task;

import groovy.lang.GroovyClassLoader;

public class GroovyUtils {

    private final static ClassLoader classLoader = GroovyUtils.class.getClassLoader();//獲取當(dāng)前類裝載器
    //ClassLoader:就是類的裝載器,它使JVM可以動態(tài)的載入Java類,JVM并不需要知道從什么地方(本地文件、網(wǎng)絡(luò)等)載入Java類,這些都由ClassLoader完成。

    public final static GroovyClassLoader groovyClassLoader = new GroovyClassLoader(classLoader);
    //GroovyClassLoader:負(fù)責(zé)在運行時編譯groovy源代碼為Class的工作,從而使Groovy實現(xiàn)了將groovy源代碼動態(tài)加載為Class的功能。

    /**
     * .
     * 獲取實例化對象
     * @param script groovy腳本內(nèi)容
     * @param <T>
     * @return
     * @throws IllegalAccessException
     * @throws InstantiationException
     */
    public static <T> T instanceTaskGroovyScript(String script) throws IllegalAccessException, InstantiationException {
        Class taskClz = groovyClassLoader.parseClass(script);
        T instance = (T) taskClz.newInstance();
        return instance;
    }
}

第五步:讀取腳本內(nèi)容,執(zhí)行腳本

package com.example.groovy.testgroovy.task;

import lombok.extern.slf4j.Slf4j;
import org.apache.commons.io.FileUtils;
import org.springframework.stereotype.Component;

import java.io.File;
import java.io.IOException;


@Slf4j
@Component
public class CallAnalysisGroovyTask {


    /**
     * .
     * 讀取腳本內(nèi)容
     *
     * @return
     */
    public static String getGroovy() {
        String context = "";
        try {
            String path = "E:\\IDEAFile\\testgroovy\\src\\main\\resources\\groovy\\CallAnalysisImpl.groovy";
            context = FileUtils.readFileToString(new File(path));//將腳本內(nèi)容轉(zhuǎn)為字符串
        } catch (IOException e) {
            log.error("file is not found[{}]", e);
        }
        return context;
    }

    /**
     * .
     * 執(zhí)行g(shù)roovy腳本
     *
     * @param script
     */
    public static void execGroovy(String script) {
        try {
            CallAnalysis objClass = GroovyUtils.instanceTaskGroovyScript(script);//獲取實例對象
            objClass.load();//調(diào)用腳本方法
        } catch (Exception t) {
            log.error("execGroovy file {} error", script);
        }
    }

    /**
     * .
     * main方法
     * @param args
     */
    public static void main(String[] args) {
        System.out.println("==================");
        CallAnalysisGroovyTask task = new CallAnalysisGroovyTask();
        String script = task.getGroovy();//獲取腳本
        execGroovy(script);//實例化腳本,執(zhí)行方法
        System.out.println("==================");
    }
}

4.Groovy特性驗證

利用Groovy腳本特性,不重啟服務(wù),實時修改數(shù)據(jù)

第一步:將之前Groovy腳本數(shù)據(jù)修改。存于數(shù)據(jù)庫表中,動態(tài)加載腳本

@Slf4j
class CallAnalysisImpl implements CallAnalysis {

    private int anInt = 10;
    private int bnInt = 10;

    @Override
    void load() {
        log.info("當(dāng)前類:[{}]", this.getClass().getName())
        log.info("我被Groovy腳本加載...")
        log.info("計算結(jié)果:[{}]", (anInt + bnInt))
    }
}


第二步:數(shù)據(jù)庫表中:添加、查詢Groovy腳本,動態(tài)加載執(zhí)行

 /**
     * .
     * 讀取腳本,進行入庫操作
     *
     * @return
     */
    @GetMapping("/saveScript")
    public String saveScript() {
        String scriptStr = callAnalysisGroovyTask.getGroovy();
        Script script = new Script();//實體類對象
        script.setScript(scriptStr);//腳本內(nèi)容
        script.setRuleId("1");//規(guī)則id
        script.setScriptName("演示一");//腳本名稱
        service.save(script);
        return "添加成功";
    }


    /**
     * .
     * 從數(shù)據(jù)庫表中,動態(tài)獲取腳本
     *
     * @param ruleId 規(guī)則id
     * @return 腳本內(nèi)容
     */
    @GetMapping("/groovy")
    public String groovy(final String ruleId) {
        Script scr = scriptService.findScriptByRuleId(ruleId);//根據(jù)規(guī)則id查詢
        String scriptStr = scr.getScript();
        callAnalysisGroovyTask.execGroovy(scriptStr);
        return scriptStr;
    }


添加結(jié)果:

?查詢結(jié)果、控制臺執(zhí)行結(jié)果:

第三步:多次修改表數(shù)據(jù)值,查看執(zhí)行結(jié)果

5.總語

目的達成,可見在不重啟服務(wù)時,多次修改數(shù)據(jù),腳本內(nèi)容都會被動態(tài)加載。此處只是簡單舉例驗證,可自行擴展

到此這篇關(guān)于Java動態(tài)腳本Groovy的文章就介紹到這了,更多相關(guān)Java動態(tài)腳本Groovy內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論