1700483430
37.1 规格模式的实现
1700483431
1700483432
不知道诸位有没有使用C#3.5做过开发,它有一个非常重要的新特性——LINQ(Language INtegrated Query,语言集成查询),它提供了类似于SQL语法的遍历、筛选等功能,能完成对对象的查询,就像通过SQL语句查询数据库一样,例如这样的一个程序片段:
1700483433
1700483434
Dim DataList As String()={“abc”,“def”,“ght”}
1700483435
1700483436
Dim Result=From T As String In DataList Where T=“abc”
1700483437
1700483438
这句话的意思就是从一个数组中查找出值为abc的元素,返回结果为IEnumerable,枚举器类型。注意看第二句话,它使用了类似SQL的Select语法结构,from、where关键字都有了,而且还支持类似的Orderby、Groupby功能,很强大,有兴趣的读者可以查阅有关资料。那在Java世界中是否也存在这样的辅助框架呢?有,JoSQL、Quaere都可以提供类似的LINQ语言,读者可以到网上研究一下其JavaDoc,同样非常简单,功能强大。
1700483439
1700483440
我们今天要讲的主题与LINQ有很大关系,它是实现LINQ的核心。想想SQL语句中什么是最复杂的,是where后面的查询条件,看看自己写的SQL语句基本上都是一长串的条件判断,中间一堆的and、or、not逻辑符。我们今天的任务就是要实现条件语句的解析,该部分实现了,基本上LINQ语法已经实现了一大半。
1700483441
1700483442
我们以一个案例来讲解该技术,在内存中有10个User对象,根据不同的条件查找出用户,比如姓名包含某个字符、年龄小于多少岁等条件,类似这样的SQL:
1700483443
1700483444
Select*From User where name like ‘%国庆%’
1700483445
1700483446
查找出姓名中包含“国庆”两个字的用户,这在关系型数据库中很容易实现,但是在对象群中怎么实现这样的查询呢?好,看似很简单,先设计一个用户类,然后提供一个用户查找工具类,类图非常容易,如图37-1所示。
1700483447
1700483448
1700483449
1700483450
1700483451
图37-1 简单用户查询类图
1700483452
1700483453
很简单的类图,有一个用户类,同时提供了一个操作用户的辅助类,我们先来看User类,如代码清单37-1所示。
1700483454
1700483455
代码清单37-1 用户类
1700483456
1700483457
public class User{
1700483458
1700483459
//姓名
1700483460
1700483461
private String name;
1700483462
1700483463
//年龄
1700483464
1700483465
private int age;
1700483466
1700483467
public User(String_name,int_age){
1700483468
1700483469
this.name=_name;
1700483470
1700483471
this.age=_age;
1700483472
1700483473
}
1700483474
1700483475
public String getName(){
1700483476
1700483477
return name;
1700483478
[
上一页 ]
[ :1.700483429e+09 ]
[
下一页 ]