使用Java实现一个JS脚本引擎

使用Java实现JS脚本引擎
项目地址 https://github.com/GitHub-Laz...
生成语法树 并输出格式化代码 示例代码

class Test{ public static void main(String[] args){ Top.init(); DocNode doc = Top.compile("leta=1+2,b=3,c=\"string\",d=a*(b+c/2),func=function(){}; "); System.out.println(doc); } }

输出
let a = 1 + 2, b = 3, c = "string", d = a * (b + c / 2), func = function () {}

运行脚本 【使用Java实现一个JS脚本引擎】以下示例为运行快排算法(运行环境线程隔离)
js脚本
function sort(arr, i, j) { if (i >= j) { return; } let p = i, q = j; let temp = arr[p]; while (p < q) { while (p < q && arr[q] >= temp) { q-=1; } arr[p] = arr[q]; while (p < q && arr[p] <= temp) { p+=1; } arr[q] = arr[p]; } arr[q] = temp; sort(arr, i, q - 1); sort(arr, q + 1, j); }let arr = [234, 57, 12, 123, 346, 1234, 2]; sort(arr, 0, arr.length - 1);

示例代码
class Test{ public static void main(String[] args){ Top.init(); Top.eval("function sort(arr, i, j) {\n" + "if (i >= j) {\n" + "return; \n" + "}\n" + "let p = i, q = j; \n" + "let temp = arr[p]; \n" + "while (p < q) {\n" + "while (p < q && arr[q] >= temp) {\n" + "q-=1; \n" + "}\n" + "arr[p] = arr[q]; \n" + "while (p < q && arr[p] <= temp) {\n" + "p+=1; \n" + "}\n" + "arr[q] = arr[p]; \n" + "}\n" + "arr[q] = temp; \n" + "sort(arr, i, q - 1); \n" + "sort(arr, q + 1, j); \n" + "}\n" + "\n" + "let arr = [234, 57, 12, 123, 346, 1234, 2]; \n" + "\n" + "sort(arr, 0, arr.length - 1); "); Top.loop(); System.out.println(Top.getThreadLocalTop().getMainContexts().getContexts().peek().toSimpleString()); } }

输出
arr: [2, 12, 57, 123, 234, 346, 1234] sort: [object Object]

    推荐阅读