Java表达式求值引擎Aviator(二)
wptr33 2025-01-21 21:57 60 浏览
环境:Java8 + Aviator5.2.5
请先阅读《Java表达式求值引擎Aviator(一)》
使用示例
示例8:
三元运算符
public class TernaryOperatorExample {
public static void main(String[] args) {
Map<String, Object> env = new HashMap<String, Object>();
env.put("num", 100) ;
String result = (String) AviatorEvaluator.execute("num > 998 ? 'yes':'no'", env);
System.out.println(result);
}
}
Aviator 的三元表达式对于两个分支的结果类型并不要求一致,可以是任何类型,这一点与 java不同。
示例9:
正则表达式匹配
public class RegularExpressionExample {
public static void main(String[] args) {
String email = "3487929**@qq.com";
Map<String, Object> env = new HashMap<String, Object>();
env.put("email", email);
String username = (String) AviatorEvaluator.execute("email=~/([\\w0-8]+)@\\w+[\\.\\w+]+/ ? $1:'unknow'", env);
System.out.println(username);
}
}
email 与正则表达式//([\\w0-8]+@\\w+[\\.\\w+]+)/通过=~操作符来匹配,结果为一个 Boolean 类型,因此可以用于三元表达式判断,匹配成功的时候返回$1,指代正则表达式的分组 1,也就是用户名,否则返回 unknown。这个例子将打印3487929**这个用户名。
Aviator 在表达式级别支持正则表达式,通过//括起来的字符序列构成一个正则表达式,正则表达式可以用于匹配(作为=~的右操作数)、比较大小,匹配仅能与字符串进行匹配。匹配成功后,Aviator 会自动将匹配成功的分组放入$num 的变量中,其中$0 指代整个匹配的字符串,而$1 表示第一个分组,以此类推。
Aviator 的正则表达式规则跟 Java 完全一样,因为内部其实就是使用 java.util.regex.Pattern 做编译的。
示例10:
变量的语法糖
Aviator 有个方便用户使用变量的语法糖衣,当你要访问变量 a 中的某个属性 b,那么你可以通过 a.b 访问到,更进一步,a.b.c 将访问变量 a 的 b 属性中的 c 属性值,推广开来也就是说Aviator 可以将变量声明为嵌套访问的形式。
public class Person {
private String name ;
private Integer age ;
public Person(String name, Integer age) {
super();
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
}
public class VariableExample {
public static void main(String[] args) {
Person person = new Person("张三", 20) ;
Map<String, Object> env = new HashMap<String, Object>();
env.put("person", person);
String result = (String) AviatorEvaluator.execute("'[Person name = ' + person.name + ' age = ' + person.age + ']'", env);
System.out.println(result);
}
}
对象的多层嵌套也是支持的。
示例11:
nil 对象
nil 是 Aviator 内置的常量,类似 java 中的 null,表示空的值。nil 跟 null 不同的在于,在 java中 null 只能使用在==、!=的比较运算符,而 nil 还可以使用>、>=、<、<=等比较运算符。Aviator 规定,任何对象都比 nil 大除了 nil 本身。用户传入的变量如果为 null,将自动以 nil 替代。
public class NilExample {
public static void main(String[] args) {
Object res1 = AviatorEvaluator.execute("nil == nil");
Object res2 = AviatorEvaluator.execute(" 3> nil");
Object res3 = AviatorEvaluator.execute(" true!= nil");
Object res4 = AviatorEvaluator.execute(" ' '>nil ");
Object res5 = AviatorEvaluator.execute(" a==nil ");
System.out.println("res1 = " + res1 + "\tres2 = " + res2 + "\tres3 = " + res3 + "\tres4 = " + res4 + "\tres5 = " + res5 ) ;
}
}
示例12:
日期比较
Aviator 并不支持日期类型,如果要比较日期,你需要将日期写字符串的形式,并且要求是形如"yyyy-MM-dd HH:mm:ss:SS"(只能是这种形式的)的字符串,否则都将报错。 字符串跟 java.util.Date 比较的时候将自动转换为 Date 对象进行比较。
public class DateExample {
public static void main(String[] args) throws Exception {
Map<String, Object> env = new HashMap<String, Object>();
Date date = new Date();
String dateStr = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss:SS").format(date);
env.put("date", date);
env.put("dateStr", dateStr);
Boolean result = (Boolean) AviatorEvaluator.execute("date == dateStr", env);
System.out.println(result);
result = (Boolean) AviatorEvaluator.execute("date > '2021-12-20 00:00:00:00' ", env);
System.out.println(result);
result = (Boolean) AviatorEvaluator.execute("date < '2200-12-20 00:00:00:00' ", env);
System.out.println(result);
result = (Boolean) AviatorEvaluator.execute("date == date ", env);
System.out.println(result);
}
}
示例13:
大数计算和精度
从 2.3.0 版本开始,aviator 开始支持大数字计算和特定精度的计算,本质上就是支持java.math.BigInteger 和 java.math.BigDecimal 两种类型,这两种类型在 aviator 中简称为 big int 和 decimal 类型。
类似“99999999999999999999999999999999”这样的数字在 Java 语言里是没办法编译通过的,因为它超过了 Long 类型的范围,只能用 BigInteger 来封装。但是 aviator 通过包装,可以直接支持这种大整数的计算
public class BigNumberExample {
public static void main(String[] args) {
System.out.println(AviatorEvaluator.execute("99999999999999999999999999999999+99999999999999999999999999999999"));
}
}
示例14:
强大的 seq 库
aviator 拥有强大的操作集合和数组的 seq 库。整个库风格类似函数式编程中的高阶函数。在aviator 中,数组以及 java.util.Collection 下的子类都称为 seq,可以直接利用 seq 库进行遍历、过滤和聚合等操作。
public class SeqExample {
public static void main(String[] args) {
Map<String, Object> env = new HashMap<String, Object>();
ArrayList<Integer> list = new ArrayList<Integer>();
list.add(3);
list.add(100);
list.add(-100);
list.add(10);
env.put("list", list);
// 统计总数
System.out.println(AviatorEvaluator.execute("count(list)", env)) ; // 4
// 求和;resuce 函数接收三个参数,第一个是 seq,第二个是聚合的函数,如+、 等,第三个是聚合的初始值。
System.out.println(AviatorEvaluator.execute("reduce(list,+,0)", env)) ; // 13
// 这个例子过滤出 list 中所有大于 0 的元素并返回集合。seq.gt 函数用于生成一个谓词,表示大于某个值。
System.out.println(AviatorEvaluator.execute("filter(list,seq.gt(0))", env)) ; // [3, 100, 10]
// 判断在不在集合中
System.out.println(AviatorEvaluator.execute("include(list,100)", env)) ; // true
System.out.println(AviatorEvaluator.execute("include(list,99)", env)) ; // false
// 排序
System.out.println(AviatorEvaluator.execute("sort(list)", env)) ; // [-100, 3, 10, 100]
// 遍历集合
System.out.println(AviatorEvaluator.execute("map(list,println)", env)) ;
}
}
示例15:
两种运行模式
默认 AviatorEvaluator 以执行速度优先:
AviatorEvaluator.setOptimize(AviatorEvaluator.EVAL);
你可以修改为编译速度优先,这样不会做编译优化:
AviatorEvaluator.setOptimize(AviatorEvaluator.COMPILE);
调试信息
// 输出到文件
AviatorEvaluator.setTraceOutputStream(new FileOutputStream(new File("d:\\aviator.log")));
示例16:
强大的内置函数
示例17:
常量和变量
完毕!!!
给个关注+转发呗谢谢
SpringBoot2 整合 OAuth2 资源认证(保护)
SpringCloud Alibaba 之 Nacos 服务
相关推荐
- MySQL进阶五之自动读写分离mysql-proxy
-
自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...
- 3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
-
引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...
- 一文由浅入深带你完全掌握MySQL的锁机制原理与应用
-
本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...
- 验证Mysql中联合索引的最左匹配原则
-
后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...
- MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)
-
目录1.索引基础...
- 你会看 MySQL 的执行计划(EXPLAIN)吗?
-
SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...
- MySQL 从入门到精通(四)之索引结构
-
索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...
- mysql总结——面试中最常问到的知识点
-
mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...
- mysql总结——面试中最常问到的知识点(2)
-
首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...
- MySQL基础全知全解!超详细无废话!轻松上手~
-
本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...
- 深入剖析 MySQL 中的锁机制原理_mysql 锁详解
-
在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...
- Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析
-
引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...
- MySQL基础篇:DQL数据查询操作_mysql 查
-
一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...
- MySql:索引的基本使用_mysql索引的使用和原理
-
一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
Java面试必考问题:什么是乐观锁与悲观锁
-
如何将AI助手接入微信(打开ai手机助手)
-
SparkSQL——DataFrame的创建与使用
-
redission YYDS spring boot redission 使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)