servlet关于service()的实现

**

servlet关于service()的实现

**
很自然的,我们知道服务器接收到了浏览器请求后将创建servlet对象(关于其生命周期,可以看文结尾链接),然后通过xml映射文件配置,将调用service()方法进行业务实现,那么,是怎么调用service()方法的呢?
首先,明确一点,方法的调用必须经过对象的调用,那么,对象自然而然就是服务器创建的servlet对象,那么,我们创建的功能类,是怎么new出这个对象的呢?这个很简单,实现servlet接口,就能够重写出五种方法,其中就有我们需要的service()方法;
由此,我们就可以达到创建servlet对象的目的。
在这里插入图片描述以实现登陆功能为例;
但这样有没有发现另外四个方法一般是不是我们不会用?那不对啊,不符合我们java的敏捷高效,好,伟大牛x的大佬们想出了办法,由此诞生了三种达到目的的方式;
第一种就是最原始的,不再重复;

最优秀的,第三种,四层架构,我来说说我对这个的理解,
在这里插入图片描述功能类继承
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
Httpservlet抽象类源码,我调整了下顺序,等下讲;
在这里插入图片描述
在这里插入图片描述genenicservlet抽象类源码
好了,素材有了,咱来捋一捋;
何为四层架构,首先看要达到的目的是什么:屏蔽功能类多余方法,让功能类专注于service的实现;那么我们可以想到一个很有特点的类:抽象类;它的特点是什么:

  1. 可以同时包含n个抽象方法与m个普通方法(其中n,m均可为o),
  2. 不可被实例化
    现在我们来想一点额外的东西:为什么实现接口要重写所有方法?
    因为接口中的所有方法都是抽象的,这样我们普通类实现所有方法时,就必须重写;因为普通类能有抽象方法吗?不能嘛。。但谁可以?抽象类啊,可以同时包含n个抽象方法与普通方法,所以我们创建第二个层:genenicservlet抽象类来实现servlet接口;
    在这里插入图片描述并且只保留service()方法,是不是就屏蔽掉了其他多余的方法?
    在这里插入图片描述
    然后我们在想一个问题,如果功能类直接继承,是不是会继承到抽象方法?也就是成了抽象类,那不行,看下上面抽象类第二个特点:不可被实例化;那岂不是gg?
    于是我们迎来了第三个层:Httpservlet抽象类;
    在这里插入图片描述然后在这个类中重写service()方法,最后功能层直接继承,就不会成为抽象类了;
    而且需要补充的几点:
    ???为什么功能类里的方法传参变了
    在这里插入图片描述很简单,看Httpservlet抽象类源码在这里插入图片描述其中instanceof的作用是判断对象在内存中实际是不是该类型,基本用于强制转换;
    这个方法就改变了传参类型了;
    ???为什么不直接第二层实现,而要搞到第三层
    。。。我也不知道。。希望有大佬能够解答。。。不过感觉和装饰器设计模式有关系,还有就是这样的设计能够在第二三层提供大量的方法,也就可以更高效的达到目的了;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值