打字猴:1.700483429e+09
1700483429 设计模式之禅 [:1700454089]
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 ]  [ 下一页 ]