`
jinnianshilongnian
  • 浏览: 21513877 次
  • 性别: Icon_minigender_1
博客专栏
5c8dac6a-21dc-3466-8abb-057664ab39c7
跟我学spring3
浏览量:2420500
D659df3e-4ad7-3b12-8b9a-1e94abd75ac3
Spring杂谈
浏览量:3010256
43989fe4-8b6b-3109-aaec-379d27dd4090
跟开涛学SpringMVC...
浏览量:5640606
1df97887-a9e1-3328-b6da-091f51f886a1
Servlet3.1规范翻...
浏览量:260219
4f347843-a078-36c1-977f-797c7fc123fc
springmvc杂谈
浏览量:1597953
22722232-95c1-34f2-b8e1-d059493d3d98
hibernate杂谈
浏览量:250370
45b32b6f-7468-3077-be40-00a5853c9a48
跟我学Shiro
浏览量:5860614
Group-logo
跟我学Nginx+Lua开...
浏览量:702889
5041f67a-12b2-30ba-814d-b55f466529d5
亿级流量网站架构核心技术
浏览量:785757
社区版块
存档分类
最新评论

【第五章】Spring表达式语言 之 5.3 SpEL语法 ——跟我学spring3

阅读更多

 

5.3  SpEL语法

5.3.1  基本表达式

一、字面量表达式: SpEL支持的字面量包括:字符串、数字类型(int、long、float、double)、布尔类型、null类型。

类型

示例

字符串

String str1 = parser.parseExpression("'Hello World!'").getValue(String.class);

String str2 = parser.parseExpression("\"Hello World!\"").getValue(String.class);

数字类型

int int1 = parser.parseExpression("1").getValue(Integer.class);

long long1 = parser.parseExpression("-1L").getValue(long.class);

float float1 = parser.parseExpression("1.1").getValue(Float.class);

double double1 = parser.parseExpression("1.1E+2").getValue(double.class);

int hex1 = parser.parseExpression("0xa").getValue(Integer.class);

long hex2 = parser.parseExpression("0xaL").getValue(long.class);

布尔类型

boolean true1 = parser.parseExpression("true").getValue(boolean.class);

boolean false1 = parser.parseExpression("false").getValue(boolean.class);

null类型

Object null1 = parser.parseExpression("null").getValue(Object.class);

 

二、算数运算表达式: SpEL支持加(+)、减(-)、乘(*)、除(/)、求余(%)、幂(^)运算。

类型

示例

加减乘除

int result1 = parser.parseExpression("1+2-3*4/2").getValue(Integer.class);//-3

求余

int result2 = parser.parseExpression("4%3").getValue(Integer.class);//1

幂运算

int result3 = parser.parseExpression("2^3").getValue(Integer.class);//8

SpEL还提供求余(MOD)和除(DIV)而外两个运算符,与“%”和“/”等价,不区分大小写。

 

三、关系表达式:等于(==)、不等于(!=)、大于(>)、大于等于(>=)、小于(<)、小于等于(<=),区间(between)运算,如“parser.parseExpression("1>2").getValue(boolean.class);”将返回false;而“parser.parseExpression("1 between {1, 2}").getValue(boolean.class);”将返回true。

       between运算符右边操作数必须是列表类型,且只能包含2个元素。第一个元素为开始,第二个元素为结束,区间运算是包含边界值的,即 xxx>=list.get(0) && xxx<=list.get(1)。

       SpEL同样提供了等价的“EQ” 、“NE”、 “GT”、“GE”、 “LT” 、“LE”来表示等于、不等于、大于、大于等于、小于、小于等于,不区分大小写。

 

四、逻辑表达式:且(and)、或(or)、非(!或NOT)。

 

java代码:
  1. String expression1 = "2>1 and (!true or !false)";  
  2. boolean result1 = parser.parseExpression(expression1).getValue(boolean.class);  
  3. Assert.assertEquals(true, result1);  
  4.    
  5. String expression2 = "2>1 and (NOT true or NOT false)";  
  6. boolean result2 = parser.parseExpression(expression2).getValue(boolean.class);  
  7. Assert.assertEquals(true, result2);  

 

注:逻辑运算符不支持 Java中的 && 和 || 

 

五、字符串连接及截取表达式:使用“+”进行字符串连接,使用“'String'[0] [index]”来截取一个字符,目前只支持截取一个,如“'Hello ' + 'World!'”得到“Hello World!”;而“'Hello World!'[0]”将返回“H”。

 

六、三目运算及Elivis运算表达式:

三目运算符 “表达式1?表达式2:表达式3用于构造三目运算表达式,如“2>1?true:false”将返回true;

Elivis运算符“表达式1?:表达式2从Groovy语言引入用于简化三目运算符的,当表达式1为非null时则返回表达式1,当表达式1为null时则返回表达式2,简化了三目运算符方式“表达式1? 表达式1:表达式2”,如“null?:false”将返回false,而“true?:false”将返回true;

 

七、正则表达式:使用“str matches regex,如“'123' matches '\\d{3}'”将返回true;

 

八、括号优先级表达式:使用“(表达式)”构造,括号里的具有高优先级。

 

5.3.3  类相关表达式

一、类类型表达式:使用“T(Type)”来表示java.lang.Class实例,“Type”必须是类全限定名,“java.lang”包除外,即该包下的类可以不指定包名;使用类类型表达式还可以进行访问类静态方法及类静态字段。

        具体使用方法如下:

 

java代码:
  1. @Test  
  2. public void testClassTypeExpression() {  
  3.     ExpressionParser parser = new SpelExpressionParser();  
  4.     //java.lang包类访问  
  5.     Class<String> result1 = parser.parseExpression("T(String)").getValue(Class.class);  
  6.     Assert.assertEquals(String.class, result1);  
  7.     //其他包类访问  
  8.     String expression2 = "T(cn.javass.spring.chapter5.SpELTest)";  
  9.     Class<String> result2 = parser.parseExpression(expression2).getValue(Class.class);    Assert.assertEquals(SpELTest.class, result2);  
  10.     //类静态字段访问  
  11.     int result3=parser.parseExpression("T(Integer).MAX_VALUE").getValue(int.class);  
  12.     Assert.assertEquals(Integer.MAX_VALUE, result3);  
  13.     //类静态方法调用  
  14.     int result4 = parser.parseExpression("T(Integer).parseInt('1')").getValue(int.class);  
  15.     Assert.assertEquals(1, result4);  
  16. }  

 

       对于java.lang包里的可以直接使用“T(String)”访问;其他包必须是类全限定名;可以进行静态字段访问如“T(Integer).MAX_VALUE”;也可以进行静态方法访问如“T(Integer).parseInt('1')”。

 

二、类实例化:类实例化同样使用java关键字“new”,类名必须是全限定名,但java.lang包内的类型除外,如String、Integer。

 

java代码:
  1. @Test  
  2. public void testConstructorExpression() {  
  3.     ExpressionParser parser = new SpelExpressionParser();  
  4.     String result1 = parser.parseExpression("new String('haha')").getValue(String.class);  
  5.     Assert.assertEquals("haha", result1);  
  6.     Date result2 = parser.parseExpression("new java.util.Date()").getValue(Date.class);  
  7.     Assert.assertNotNull(result2);  
  8. }  

 

       实例化完全跟Java内方式一样。

 

三、instanceof表达式:SpEL支持instanceof运算符,跟Java内使用同义;如“'haha' instanceof T(String)”将返回true。

 

四、变量定义及引用:变量定义通过EvaluationContext接口的setVariable(variableName, value)方法定义;在表达式中使用“#variableName”引用;除了引用自定义变量,SpE还允许引用根对象及当前上下文对象,使用“#root”引用根对象,使用“#this”引用当前上下文对象;

 

java代码:
  1.       
  2. @Test  
  3. public void testVariableExpression() {  
  4.     ExpressionParser parser = new SpelExpressionParser();  
  5.     EvaluationContext context = new StandardEvaluationContext();  
  6.     context.setVariable("variable""haha");  
  7.     context.setVariable("variable""haha");  
  8.     String result1 = parser.parseExpression("#variable").getValue(context, String.class);  
  9.     Assert.assertEquals("haha", result1);  
  10.    
  11.     context = new StandardEvaluationContext("haha");  
  12.     String result2 = parser.parseExpression("#root").getValue(context, String.class);  
  13.     Assert.assertEquals("haha", result2);  
  14.     String result3 = parser.parseExpression("#this").getValue(context, String.class);  
  15.     Assert.assertEquals("haha", result3);  
  16. }  

 

       使用“#variable”来引用在EvaluationContext定义的变量;除了可以引用自定义变量,还可以使用“#root”引用根对象,“#this”引用当前上下文对象,此处“#this”即根对象。

 

五、自定义函数:目前只支持类静态方法注册为自定义函数;SpEL使用StandardEvaluationContext的registerFunction方法进行注册自定义函数,其实完全可以使用setVariable代替,两者其实本质是一样的;

 

java代码:
  1. @Test  
  2. public void testFunctionExpression() throws SecurityException, NoSuchMethodException {  
  3.     ExpressionParser parser = new SpelExpressionParser();  
  4.     StandardEvaluationContext context = new StandardEvaluationContext();  
  5.     Method parseInt = Integer.class.getDeclaredMethod("parseInt", String.class);  
  6.     context.registerFunction("parseInt", parseInt);  
  7.     context.setVariable("parseInt2", parseInt);  
  8.     String expression1 = "#parseInt('3') == #parseInt2('3')";  
  9.     boolean result1 = parser.parseExpression(expression1).getValue(context, boolean.class);  
  10.     Assert.assertEquals(true, result1);         
  11. }  
  12.    

       此处可以看出“registerFunction”和“setVariable”都可以注册自定义函数,但是两个方法的含义不一样,推荐使用“registerFunction”方法注册自定义函数。

 

六、赋值表达式:SpEL即允许给自定义变量赋值,也允许给跟对象赋值,直接使用“#variableName=value”即可赋值:

 

java代码:
  1. @Test  
  2. public void testAssignExpression() {  
  3.     ExpressionParser parser = new SpelExpressionParser();  
  4.     //1.给root对象赋值  
  5.     EvaluationContext context = new StandardEvaluationContext("aaaa");  
  6.     String result1 = parser.parseExpression("#root='aaaaa'").getValue(context, String.class);  
  7.     Assert.assertEquals("aaaaa", result1);  
  8.     String result2 = parser.parseExpression("#this='aaaa'").getValue(context, String.class);  
  9.     Assert.assertEquals("aaaa", result2);  
  10.    
  11.     //2.给自定义变量赋值  
  12.     context.setVariable("#variable""variable");  
  13.     String result3 = parser.parseExpression("#variable=#root").getValue(context, String.class);  
  14.     Assert.assertEquals("aaaa", result3);  
  15. }  

       使用“#root='aaaaa'”给根对象赋值,使用“"#this='aaaa'”给当前上下文对象赋值,使用“#variable=#root”给自定义变量赋值,很简单。

 

七、对象属性存取及安全导航表达式:对象属性获取非常简单,即使用如“a.property.property”这种点缀式获取,SpEL对于属性名首字母是不区分大小写的;SpEL还引入了Groovy语言中的安全导航运算符“(对象|属性)?.属性”,用来避免但“?.”前边的表达式为null时抛出空指针异常,而是返回null;修改对象属性值则可以通过赋值表达式或Expression接口的setValue方法修改。

 

java代码:
  1. ExpressionParser parser = new SpelExpressionParser();  
  2. //1.访问root对象属性  
  3. Date date = new Date();  
  4. StandardEvaluationContext context = new StandardEvaluationContext(date);  
  5. int result1 = parser.parseExpression("Year").getValue(context, int.class);  
  6. Assert.assertEquals(date.getYear(), result1);  
  7. int result2 = parser.parseExpression("year").getValue(context, int.class);  
  8. Assert.assertEquals(date.getYear(), result2);         

 

       对于当前上下文对象属性及方法访问,可以直接使用属性或方法名访问,比如此处根对象date属性“year”,注意此处属性名首字母不区分大小写。

 

 

java代码:
  1.       
  2. //2.安全访问  
  3. context.setRootObject(null);  
  4. Object result3 = parser.parseExpression("#root?.year").getValue(context, Object.class);  
  5. Assert.assertEquals(null, result3);     
  6.    

 

       SpEL引入了Groovy的安全导航运算符,比如此处根对象为null,所以如果访问其属性时肯定抛出空指针异常,而采用“?.”安全访问导航运算符将不抛空指针异常,而是简单的返回null。

 

java代码:
  1. //3.给root对象属性赋值  
  2. context.setRootObject(date);  
  3. int result4 = parser.parseExpression("Year = 4").getValue(context, int.class);  
  4. Assert.assertEquals(4, result4);  
  5. parser.parseExpression("Year").setValue(context, 5);  
  6. int result5 = parser.parseExpression("Year").getValue(context, int.class);  
  7. Assert.assertEquals(5, result5);  
  8.    

       给对象属性赋值可以采用赋值表达式或Expression接口的setValue方法赋值,而且也可以采用点缀方式赋值。

 

八、对象方法调用:对象方法调用更简单,跟Java语法一样;如“'haha'.substring(2,4)”将返回“ha”;而对于根对象可以直接调用方法;

 

java代码:
  1. Date date = new Date();  
  2. StandardEvaluationContext context = new StandardEvaluationContext(date);  
  3. int result2 = parser.parseExpression("getYear()").getValue(context, int.class);  
  4. Assert.assertEquals(date.getYear(), result2);  

 

       比如根对象date方法“getYear”可以直接调用。

 

九、Bean引用:SpEL支持使用“@”符号来引用Bean,在引用Bean时需要使用BeanResolver接口实现来查找Bean,Spring提供BeanFactoryResolver实现;

 

java代码:
  1. @Test  
  2. public void testBeanExpression() {  
  3.     ClassPathXmlApplicationContext ctx = new ClassPathXmlApplicationContext();  
  4.     ctx.refresh();  
  5.     ExpressionParser parser = new SpelExpressionParser();  
  6.     StandardEvaluationContext context = new StandardEvaluationContext();  
  7.     context.setBeanResolver(new BeanFactoryResolver(ctx));  
  8.     Properties result1 = parser.parseExpression("@systemProperties").getValue(context, Properties.class);  
  9.     Assert.assertEquals(System.getProperties(), result1);  
  10. }  

 

       在示例中我们首先初始化了一个IoC容器,ClassPathXmlApplicationContext 实现默认会把“System.getProperties()”注册为“systemProperties”Bean,因此我们使用 “@systemProperties”来引用该Bean。

 

5.3.3  集合相关表达式

一、内联List从Spring3.0.4开始支持内联List,使用{表达式,……}定义内联List,如“{1,2,3}”将返回一个整型的ArrayList,而“{}”将返回空的List,对于字面量表达式列表,SpEL会使用java.util.Collections.unmodifiableList方法将列表设置为不可修改。

 

java代码:
  1. //将返回不可修改的空List  
  2. List<Integer> result2 = parser.parseExpression("{}").getValue(List.class);  

 

 

 

java代码:
  1. //对于字面量列表也将返回不可修改的List  
  2. List<Integer> result1 = parser.parseExpression("{1,2,3}").getValue(List.class);  
  3. Assert.assertEquals(new Integer(1), result1.get(0));  
  4. try {  
  5.     result1.set(02);  
  6.     //不可能执行到这,对于字面量列表不可修改  
  7.     Assert.fail();  
  8. catch (Exception e) {  
  9. }  

 

 

java代码:
  1. //对于列表中只要有一个不是字面量表达式,将只返回原始List,  
  2. //不会进行不可修改处理  
  3. String expression3 = "{{1+2,2+4},{3,4+4}}";  
  4. List<List<Integer>> result3 = parser.parseExpression(expression3).getValue(List.class);  
  5. result3.get(0).set(01);  
  6. Assert.assertEquals(2, result3.size());  

 

 

java代码:
  1. //声明一个大小为2的一维数组并初始化  
  2. int[] result2 = parser.parseExpression("new int[2]{1,2}").getValue(int[].class);  

 

 

java代码:
  1. //定义一维数组但不初始化  
  2. int[] result1 = parser.parseExpression("new int[1]").getValue(int[].class);  

 

 

二、内联数组:和Java 数组定义类似,只是在定义时进行多维数组初始化。

 

 

java代码:
  1.       
  2. //定义多维数组但不初始化  
  3. int[][][] result3 = parser.parseExpression("new int[1][2][3]").getValue(int[][][].class);  

 

 

java代码:
  1. //错误的定义多维数组,多维数组不能初始化  
  2. String expression4 = "new int[1][2][3]{{1}{2}{3}}";  
  3. try {  
  4.     int[][][] result4 = parser.parseExpression(expression4).getValue(int[][][].class);  
  5.     Assert.fail();  
  6. catch (Exception e) {  
  7. }  

 

 

三、集合,字典元素访问:SpEL目前支持所有集合类型和字典类型的元素访问,使用“集合[索引]”访问集合元素,使用“map[key]”访问字典元素;

 

java代码:
  1. //SpEL内联List访问  
  2. int result1 = parser.parseExpression("{1,2,3}[0]").getValue(int.class);  
  3. //即list.get(0)  
  4. Assert.assertEquals(1, result1);  
  5.    

 

 

java代码:
  1. //SpEL目前支持所有集合类型的访问  
  2. Collection<Integer> collection = new HashSet<Integer>();  
  3. collection.add(1);  
  4. collection.add(2);  
  5. EvaluationContext context2 = new StandardEvaluationContext();  
  6. context2.setVariable("collection", collection);  
  7. int result2 = parser.parseExpression("#collection[1]").getValue(context2, int.class);  
  8. //对于任何集合类型通过Iterator来定位元素  
  9. Assert.assertEquals(2, result2);  

 

 

java代码:
  1. //SpEL对Map字典元素访问的支持  
  2. Map<String, Integer> map = new HashMap<String, Integer>();  
  3. map.put("a"1);  
  4. EvaluationContext context3 = new StandardEvaluationContext();  
  5. context3.setVariable("map", map);  
  6. int result3 = parser.parseExpression("#map['a']").getValue(context3, int.class);  
  7. Assert.assertEquals(1, result3);  

 

       注:集合元素访问是通过Iterator遍历来定位元素位置的

 

 

四、列表,字典,数组元素修改:可以使用赋值表达式或Expression接口的setValue方法修改;

 

java代码:
  1. //1.修改数组元素值  
  2. int[] array = new int[] {12};  
  3. EvaluationContext context1 = new StandardEvaluationContext();  
  4. context1.setVariable("array", array);  
  5. int result1 = parser.parseExpression("#array[1] = 3").getValue(context1, int.class);  
  6. Assert.assertEquals(3, result1);  

 

 

java代码:
  1. //2.修改集合值  
  2. Collection<Integer> collection = new ArrayList<Integer>();  
  3. collection.add(1);  
  4. collection.add(2);  
  5. EvaluationContext context2 = new StandardEvaluationContext();  
  6. context2.setVariable("collection", collection);  
  7. int result2 = parser.parseExpression("#collection[1] = 3").getValue(context2, int.class);  
  8. Assert.assertEquals(3, result2);  
  9. parser.parseExpression("#collection[1]").setValue(context2, 4);  
  10. result2 = parser.parseExpression("#collection[1]").getValue(context2, int.class);  
  11. Assert.assertEquals(4, result2);  

 

 

java代码:
  1. //3.修改map元素值  
  2. Map<String, Integer> map = new HashMap<String, Integer>();  
  3. map.put("a"1);  
  4. EvaluationContext context3 = new StandardEvaluationContext();  
  5. context3.setVariable("map", map);  
  6. int result3 = parser.parseExpression("#map['a'] = 2").getValue(context3, int.class);  
  7. Assert.assertEquals(2, result3);  

 

       对数组修改直接对“#array[index]”赋值即可修改元素值,同理适用于集合和字典类型。

 

五、集合投影:在SQL中投影指从表中选择出列,而在SpEL指根据集合中的元素中通过选择来构造另一个集合,该集合和原集合具有相同数量的元素;SpEL使用“(list|map).![投影表达式]”来进行投影运算:

 

java代码:
  1. //1.首先准备测试数据  
  2. Collection<Integer> collection = new ArrayList<Integer>();  
  3. collection.add(4);   collection.add(5);  
  4. Map<String, Integer> map = new HashMap<String, Integer>();  
  5. map.put("a"1);    map.put("b"2);  

 

 

java代码:
  1. //2.测试集合或数组  
  2. EvaluationContext context1 = new StandardEvaluationContext();  
  3. context1.setVariable("collection", collection);  
  4. Collection<Integer> result1 =  
  5. parser.parseExpression("#collection.![#this+1]").getValue(context1, Collection.class);  
  6. Assert.assertEquals(2, result1.size());  
  7. Assert.assertEquals(new Integer(5), result1.iterator().next());  
  8.          

 

       对于集合或数组使用如上表达式进行投影运算,其中投影表达式中“#this”代表每个集合或数组元素,可以使用比如“#this.property”来获取集合元素的属性,其中“#this”可以省略。

 

 

java代码:
  1. //3.测试字典  
  2. EvaluationContext context2 = new StandardEvaluationContext();  
  3. context2.setVariable("map", map);  
  4. List<Integer> result2 =  
  5. parser.parseExpression("#map.![ value+1]").getValue(context2, List.class);  
  6. Assert.assertEquals(2, result2.size());  

 

       SpEL投影运算还支持Map投影,但Map投影最终只能得到List结果,如上所示,对于投影表达式中的“#this”将是Map.Entry,所以可以使用“value”来获取值,使用“key”来获取键。

 

 

六、集合选择:在SQL中指使用select进行选择行数据,而在SpEL指根据原集合通过条件表达式选择出满足条件的元素并构造为新的集合,SpEL使用“(list|map).?[选择表达式]”,其中选择表达式结果必须是boolean类型,如果true则选择的元素将添加到新集合中,false将不添加到新集合中。

 

java代码:
  1. //1.首先准备测试数据  
  2. Collection<Integer> collection = new ArrayList<Integer>();  
  3. collection.add(4);   collection.add(5);  
  4. Map<String, Integer> map = new HashMap<String, Integer>();  
  5. map.put("a"1);    map.put("b"2);  

 

 

java代码:
  1. //2.集合或数组测试  
  2. EvaluationContext context1 = new StandardEvaluationContext();  
  3. context1.setVariable("collection", collection);  
  4. Collection<Integer> result1 =  
  5. parser.parseExpression("#collection.?[#this>4]").getValue(context1, Collection.class);  
  6. Assert.assertEquals(1, result1.size());  
  7. Assert.assertEquals(new Integer(5), result1.iterator().next());  

 

       对于集合或数组选择,如“#collection.?[#this>4]”将选择出集合元素值大于4的所有元素。选择表达式必须返回布尔类型,使用“#this”表示当前元素。

 

 

java代码:
  1. //3.字典测试  
  2. EvaluationContext context2 = new StandardEvaluationContext();  
  3. context2.setVariable("map", map);  
  4. Map<String, Integer> result2 =  
  5. parser.parseExpression("#map.?[#this.key != 'a']").getValue(context2, Map.class);  
  6. Assert.assertEquals(1, result2.size());  
  7.    
  8. List<Integer> result3 =  
  9.  parser.parseExpression("#map.?[key != 'a'].![value+1]").getValue(context2, List.class);  
  10. Assert.assertEquals(new Integer(3), result3.iterator().next());  

 

       对于字典选择,如“#map.?[#this.key != 'a']”将选择键值不等于”a”的,其中选择表达式中“#this”是Map.Entry类型,而最终结果还是Map,这点和投影不同;集合选择和投影可以一起使用,如“#map.?[key != 'a'].![value+1]”将首先选择键值不等于”a”的,然后在选出的Map中再进行“value+1”的投影。

 

5.3.4  表达式模板

       模板表达式就是由字面量与一个或多个表达式块组成。每个表达式块由“前缀+表达式+后缀”形式组成,如“${1+2}”即表达式块。在前边我们已经介绍了使用ParserContext接口实现来定义表达式是否是模板及前缀和后缀定义。在此就不多介绍了,如“Error ${#v0} ${#v1}”表达式表示由字面量“Error ”、模板表达式“#v0”、模板表达式“#v1”组成,其中v0和v1表示自定义变量,需要在上下文定义。

 

 

原创内容 转自请注明私塾在线【http://sishuok.com/forum/blogPost/list/0/2463.html

 

15
1
分享到:
评论
15 楼 jinnianshilongnian 2013-07-18  
liangzhu 写道
int[] result2 = parser.parseExpression("new int[2]{1,2}").getValue(int[].class); 
这个明显是一维数组初始化。

int[][][] result3 = parser.parseExpression(expression3).getValue(int[][][].class);
这个expression3如果是"{{1+2,2+4},{3,4+4}}"的话那也是二维吧,而且按你下面的说法不能初始化这个式子也有问题。

再有,String expression4 = "new int[1][2][3]{{1}{2}{3}}";  这个声明是三维数组,但初始化部分也是二维数组。


再有,String expression4 = "new int[1][2][3]{{1}{2}{3}}";  这个声明是三维数组,但初始化部分也是二维数组。 

这个本来就是错误的初始化


第二个问题 是复制源代码 漏了一部分
14 楼 jinnianshilongnian 2013-07-18  
liangzhu 写道
int[] result2 = parser.parseExpression("new int[2]{1,2}").getValue(int[].class); 
这个明显是一维数组初始化。

int[][][] result3 = parser.parseExpression(expression3).getValue(int[][][].class);
这个expression3如果是"{{1+2,2+4},{3,4+4}}"的话那也是二维吧,而且按你下面的说法不能初始化这个式子也有问题。

再有,String expression4 = "new int[1][2][3]{{1}{2}{3}}";  这个声明是三维数组,但初始化部分也是二维数组。



确实写错了,我修正下
13 楼 liangzhu 2013-07-18  
int[] result2 = parser.parseExpression("new int[2]{1,2}").getValue(int[].class); 
这个明显是一维数组初始化。

int[][][] result3 = parser.parseExpression(expression3).getValue(int[][][].class);
这个expression3如果是"{{1+2,2+4},{3,4+4}}"的话那也是二维吧,而且按你下面的说法不能初始化这个式子也有问题。

再有,String expression4 = "new int[1][2][3]{{1}{2}{3}}";  这个声明是三维数组,但初始化部分也是二维数组。
12 楼 jinnianshilongnian 2013-07-18  
liangzhu 写道
//声明二维数组并初始化 
int[] result2 = parser.parseExpression("new int[2]{1,2}").getValue(int[].class); 

//定义多维数组但不初始化 
int[][][] result3 = parser.parseExpression(expression3).getValue(int[][][].class); 

这两处不对吧


为什么不对?
11 楼 liangzhu 2013-07-18  
//声明二维数组并初始化 
int[] result2 = parser.parseExpression("new int[2]{1,2}").getValue(int[].class); 

//定义多维数组但不初始化 
int[][][] result3 = parser.parseExpression(expression3).getValue(int[][][].class); 

这两处不对吧
10 楼 jinnianshilongnian 2013-01-22  
superscorpio 写道
jinnianshilongnian 写道
superscorpio 写道
正准备用表达式,不过想试试mvel。博主有没有什么建议?

用在spring中吗? 主要干什么?

如果涉及到模型的类型转换、格式化、验证 建议还是用spel,这个是spring内部支持的。


我们这里有一个挺复杂的查询,好几十个条件,支持的运算符有几种,而且以后很可能扩展。我觉得自己写实现量太大且容易出错,所以打算用解析表达式的方法来处理。

感觉spel的一个好处是可以在上下文中使用容器管理的bean,主要功能跟其他表达式语言差不多。spel借鉴groovy,和投影的部分挺不错。

你需要的明显是一种dsl;而且最主要功能是if-else;所以spel不太适合你,在这方面它有点弱(毕竟目的是表达式语言);
当然你也可以考虑其他的脚步语言;如javascript;BeanShell;
9 楼 superscorpio 2013-01-21  
jinnianshilongnian 写道
superscorpio 写道
正准备用表达式,不过想试试mvel。博主有没有什么建议?

用在spring中吗? 主要干什么?

如果涉及到模型的类型转换、格式化、验证 建议还是用spel,这个是spring内部支持的。


我们这里有一个挺复杂的查询,好几十个条件,支持的运算符有几种,而且以后很可能扩展。我觉得自己写实现量太大且容易出错,所以打算用解析表达式的方法来处理。

感觉spel的一个好处是可以在上下文中使用容器管理的bean,主要功能跟其他表达式语言差不多。spel借鉴groovy,和投影的部分挺不错。
8 楼 jinnianshilongnian 2013-01-21  
superscorpio 写道
正准备用表达式,不过想试试mvel。博主有没有什么建议?

用在spring中吗? 主要干什么?

如果涉及到模型的类型转换、格式化、验证 建议还是用spel,这个是spring内部支持的。
7 楼 superscorpio 2013-01-21  
正准备用表达式,不过想试试mvel。博主有没有什么建议?
6 楼 jinnianshilongnian 2012-11-06  
freezingsky 写道
这一块的内容应该在平常比较少用到。但是对于一些比如需要由用户进行配置的地方就肯定用得上。不过,那时采用的是bsh.

还有一种选择是 javascript 
5 楼 freezingsky 2012-11-06  
这一块的内容应该在平常比较少用到。但是对于一些比如需要由用户进行配置的地方就肯定用得上。不过,那时采用的是bsh.
4 楼 jinnianshilongnian 2012-04-16  
kidalive 写道
jinnianshilongnian 写道
kimifdw 写道
Spring的表达式在项目中用的多么?

目前我还没有遇到过

那你还讲..哈哈.不过做为课程来说是需要讲的..嗯嗯.


我不用 不代表别人不用  。我使用的场景比较小! 而且SpEL现在是spring比较核心的模块
3 楼 kidalive 2012-04-16  
jinnianshilongnian 写道
kimifdw 写道
Spring的表达式在项目中用的多么?

目前我还没有遇到过

那你还讲..哈哈.不过做为课程来说是需要讲的..嗯嗯.
2 楼 jinnianshilongnian 2012-04-05  
kimifdw 写道
Spring的表达式在项目中用的多么?

目前我还没有遇到过
1 楼 kimifdw 2012-04-05  
Spring的表达式在项目中用的多么?

相关推荐

    Java-美妆神域_3rm1m18i_221-wx.zip

    Java-美妆神域_3rm1m18i_221-wx.zip

    51单片机的温度监测与控制(温控风扇)

    51单片机的温度监测与控制(温控风扇)

    电赛案例,C++简单的智能家居系统,其中包含了温度监测、光照控制和报警系

    电赛案例,C++简单的智能家居系统,其中包含了温度监测、光照控制和报警系统。该系统可以: 监控室内温度:当温度超过设定阈值时,触发警报。 自动调节光照:根据光线传感器的值自动调节LED灯的亮度。 入侵检测:通过红外传感器检测入侵,并触发警报。

    圣诞树 html版 可修改祝福语

    圣诞树 html版 可修改祝福语。 记事本或vscode编辑html文件:ctrl+F寻找”myLabels“关键词,定位到该处即可修改祝福语

    基于python编写的selenium自动化测试框架,采用PO模式,页面元素采用yaml进行管理资料齐全+详细文档+高分项目+源码.zip

    【资源说明】 基于python编写的selenium自动化测试框架,采用PO模式,页面元素采用yaml进行管理资料齐全+详细文档+高分项目+源码.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    屏幕截图 2024-12-21 170434.png

    屏幕截图 2024-12-21 170434

    基于SpringBoot的学生信息管理系统源码

    基于SpringBoot的学生信息管理系统(前后端源码+数据库+文档+运行截图) 学生信息管理 班级信息管理 教师信息管理 课程信息管理 选课信息管理 考勤信息管理 请假信息管理 成绩信息管理 基于SpringBoot的学生信息管理系统(前后端源码+数据库+文档+运行截图) 学生信息管理 班级信息管理 教师信息管理 课程信息管理 选课信息管理 考勤信息管理 请假信息管理 成绩信息管理基于SpringBoot的学生信息管理系统(前后端源码+数据库+文档+运行截图) 学生信息管理 班级信息管理 教师信息管理 课程信息管理 选课信息管理 考勤信息管理 请假信息管理 成绩信息管理基于SpringBoot的学生信息管理系统(前后端源码+数据库+文档+运行截图) 学生信息管理 班级信息管理 教师信息管理 课程信息管理 选课信息管理 考勤信息管理 请假信息管理 成绩信息管理基于SpringBoot的学生信息管理系统(前后端源码+数据库+文档+运行截图) 学生信息管理 班级信息管理 教师信息管理 课程信息管理 选课信息管理 考勤信息管理

    径向基函数内核 – 机器学习python案例脚本,内核在将数据转换为更高维空间方面发挥着重要作用

    径向基函数内核 – 机器学习 内核在将数据转换为更高维空间方面发挥着重要作用,使算法能够学习复杂的模式和关系。在众多的内核函数中,径向基函数(RBF)内核作为一种多功能且强大的工具脱颖而出。在本文中,我们深入探讨了RBF内核的复杂性,探讨了它的数学公式、直观理解、实际应用及其在各种机器学习算法中的重要性。

    工具变量-中国省级数字经济发展水平面板数据(2012-2022).xlsx

    详细介绍及样例数据:https://blog.csdn.net/samLi0620/article/details/144636765

    51单片机控制的智能小车.7z

    51单片机控制的智能小车.7z

    基于卷积神经网络的数字手势识别安卓APP,识别数字手势0-10详细文档+全部资料+优秀项目+源码.zip

    【资源说明】 基于卷积神经网络的数字手势识别安卓APP,识别数字手势0-10详细文档+全部资料+优秀项目+源码.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

    pymssql-2.1.4.dev5-cp37-cp37m-win-amd64.whl pymssql-2.1.4.dev5-cp37-cp37m-win32.whl

    python 使用sqlserver必须要这个问题,没办法,只能满世界的找地方下载,终于让我下载到了,现在分享给大家使用

    四川采矿场生产安全事故管理制度.docx

    四川采矿场生产安全事故管理制度

    简约灰粉共存版_8.0.53.apk

    简约灰粉共存版_8.0.53.apk

    ECharts散点图-全国主要城市空气质量(百度地图).rar

    ECharts散点图-全国主要城市空气质量(百度地图)

    四川采矿场安全检查管理规定.docx

    四川采矿场安全检查管理规定

    JSP基于WEB网上论坛设计与实现(源代码+论文+开题报告+答辩PPT+外文翻译)(2024kt).7z

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于计算机科学与技术等相关专业,更为适合;

    空中俯视物体检测9-YOLOv5数据集合集.rar

    空中俯视物体检测9-YOLOv5数据集合集.rar使用YOLO算法从图像中检测对象-V2 2023-05-11 2:51 PM ============================= *与您的团队在计算机视觉项目上合作 *收集和组织图像 *了解和搜索非结构化图像数据 *注释,创建数据集 *导出,训练和部署计算机视觉模型 *使用主动学习随着时间的推移改善数据集 对于最先进的计算机视觉培训笔记本,您可以与此数据集一起使用 该数据集包括1015张图像。 以YOLO V5 PYTORCH格式注释检测对象 - 图像。 将以下预处理应用于每个图像: *像素数据的自动取向(带有Exif-Arientation剥离) *调整大小为640x640(拉伸) 没有应用图像增强技术。

    会使用到的js文件词云图

    词云图

    Python&OpenCV手势识别系统(完整源码&自定义UI操作界面&视频教程)

    Python高分毕设——Python&Opencv手势识别系统(完整源码&自定义UI操作界面&视频教程) Python高分毕设——Python&Opencv手势识别系统(完整源码&自定义UI操作界面&视频教程) 使用了OpenCV的视频采集, 图像色域转换, 颜色通道分割, 高斯滤波, OSTU自动阈值, 凸点检测, 边缘检测, 余弦定理计算手势等功能. 准备工作 安装 Python-OpenCV 库 pip install opencv-python -i https://mirrors.ustc.edu.cn/pypi/web/simple 利用 -i 为pip指令镜像源, 这里使用电子科技大学的源, 速度比官方源更快. 安装 Numpy 科学计算库 pip install numpy -i https://mirrors.ustc.edu.cn/pypi/web/simple 安装 PyAutogui 库 pip install pyautogui -i https://mirrors.ustc.edu.cn/pypi/web/simple 代码实现 import nu

Global site tag (gtag.js) - Google Analytics