java的委托(java中的委托)

华为云服务器特价优惠火热进行中!

2核2G2兆仅需 38 元;4核4G3兆仅需 79 元。购买时间越长越优惠!更多配置及优惠价格请咨询客服。

合作流程:
1、点击链接注册/关联华为云账号:点击跳转
2、添加客服微信号:cloud7591,确定产品方案、价格方案、服务支持方案等;
3、客服协助购买,并拉微信技术服务群,享受一对一免费技术支持服务;
技术专家在金蝶、华为、腾讯原厂有多年工作经验,并已从事云计算服务8年,可对域名、备案、网站搭建、系统部署、AI人工智能、云资源规划等上云常见问题提供更专业靠谱的服务,对相应产品提供更优惠的报价和方案,欢迎咨询。

本篇文章给大家谈谈java的委托,以及java中的委托对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

微信号:cloud7591
如需了解更多,欢迎添加客服微信咨询。
复制微信号

本文目录一览:

关于java中的委托关系。

在interface只能写方法名而不存在方法名,这里所说的默认行为应该就是指方法体的内容,而"为了绕过这个限制,必须使用委托"这句话的意思我猜是不是说如果要用interface的话就要实现它的方法~~

这什么书啊,也真够烂的说的这么难受

java语言中委托的实现方法

委托是C、OC和C#中的才有,在java中是叫接口(interface )。

实现接口可以使用关键字implements,假设有接口Animal,那么实现接口代码示范如下:

class cat implements Animal

{

   public void shout ()

   {

        int(“喵喵”);

    }

}

java中的委托

委托模式是软件设计模式中的一项基本技巧。在委托模式中,有两个对象参与处理同一个请求,接受请求的对象将请求委托给另一个对象来处理。委托模式是一项基本技巧,许多其他的模式,如状态模式、策略模式、访问者模式本质上是在更特殊的场合采用了委托模式。委托模式使得我们可以用聚合来替代继承,它还使我们可以模拟mixin。

“委托”在C#中是一个语言级特性,而在Java语言中没有直接的对应,但是我们可以通过动态代理来实现委托!代码如下:

import java.lang.reflect.InvocationHandler;

import java.lang.reflect.Method;

import java.lang.reflect.Proxy;

/*

* @author Liusheng

* 实现“委托”模式,用户需要实现InvocationHandler接口;

* 参考:

*/

public abstract class Delegator implements InvocationHandler {

//--------------------------------------------

protected Object obj_orgin = null; //原始对象

protected Object obj_proxy = null; //代理对象

//--------------------------------------------

public Delegator() {

}

public Delegator(Object orgin) {

this.createProxy(orgin);

}

/*

* 完成原始对象和委托对象的实例化

* @param orgin 原始对象实例

*/

protected Object createProxy(Object orgin) {

obj_orgin = orgin;

//下面语句中orgin.getClass().getClassLoader()为加载器,orgin.getClass().getInterfaces()为接口集

obj_proxy = Proxy.newProxyInstance(orgin.getClass().getClassLoader(), orgin.getClass().getInterfaces(), this); //委托

return obj_proxy;

}

/*

* 对带有指定参数的指定对象调用由此 Method 对象表示的底层方法,具体请参见Java API

* @param args 参数

* @param method 方法类实例

*/

protected Object invokeSuper(Method method, Object[] args) throws Throwable {

return method.invoke(obj_orgin, args);

}

//--------------实现InvocationHandler接口,要求覆盖------------

//下面实现的方法是当委托的类调用toString()方法时,操作其他方法而不是该类默认的toString(),这个类的其他方法则不会。

public Object invoke(Object obj, Method method, Object[] args) throws Throwable {

// 缺省实现:委托给obj_orgin完成对应的操作

if (method.getName().equals("toString")) { //对其做额外处理

return this.invokeSuper(method, args) + "$Proxy";

} else { //注意,调用原始对象的方法,而不是代理的(obj==obj_proxy)

return this.invokeSuper(method, args);

}

}

}

下面的代码,则是作为一个委托的例子,实现Map的功能。

import java.io.IOException;

import java.lang.reflect.Method;

import java.util.Hashtable;

import java.util.Map;

import org.apache.commons.logging.Log;

import org.apache.commons.logging.LogFactory;

import com.bs2.core.UtilLog;

/**

* @author Liusheng

* 本代码主要用于演示RelegateTo的使用方法

*/

public class Delegator4Map extends Delegator {

private static Log _log = LogFactory.getLog(Delegator4Map.class);

private Map orginClass = null; //原始对象

private Map proxyClass = null; //代理对象

public Map getOrgin() {

return orginClass;

}

public Map getProxy() {

return proxyClass;

}

public Delegator4Map(Map orgin) {

super(orgin);

orginClass = orgin;

proxyClass = (Map) super.obj_proxy;

}

public Object invoke(Object obj, Method method, Object[] args) throws Throwable {

if (method.getName().equals("size")) { //修改size处理逻辑

Object res2 = new Integer(-1);

System.out.println("调用委托的方法");

return res2;

} else {

System.out.println("调用原始的方法");

return super.invoke(obj, method, args);

}

}

public static void main(String[] args) throws IOException {

Delegator4Map rtm = new Delegator4Map(new Hashtable());

Map m = rtm.getProxy();

m.size();

}

}

java中采用事件委托模型实现对事件的监听正确吗

正确。

java委托事件模型的使用首先由事件源发起特定事件,并将事件发送给一个或多个事件监控器。其次监控器在此过程中一直处于等待状态,直到接收到事件,然后处理事件并返回。

事件委托模型是利用冒泡的原理,把本应该添加到某个元素上的事件委托给他的父级,从而减少DOM交互达到网页优化。

java的委托的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于java中的委托、java的委托的信息别忘了在本站进行查找喔。

发布于 2023-04-09 09:04:38
收藏
分享
海报
27
目录

    忘记密码?

    图形验证码

    复制成功
    微信号: cloud7591
    如需了解更多,欢迎添加客服微信咨询。
    我知道了