zoukankan      html  css  js  c++  java
  • java静态代理

    WorkIF.java

    package com.wzh.test;

    public interface WorkIf {

    void doWork(String name);
    }

    work.java

    package com.wzh.test;

    import java.util.logging.Level;
    import java.util.logging.Logger;

    public class Work implements WorkIf{


    /**
    * 在一段程序中,分为两种代码:
    * 1.业务逻辑代码,即和业务相关的代码
    * 2.和业务逻辑无关的代码,但是需要存在
    * */
    public void doWork(String name){
    System.out.println(name+"努力工作...");//业务逻辑代码
    }
    public static void main(String[] args) {
    // Work w=new Work();
    // w.doWork("小明");

    Work w=new Work();
    WorkProxy wp=new WorkProxy(w);
    wp.proxy("冠希");
    }
    }

    myWork.java

    package com.wzh.test;

    public class myWork implements WorkIf{

    @Override
    public void doWork(String name) {
    // TODO Auto-generated method stub
    System.out.println(name+"偷懒的工作...");//业务逻辑代码
    }

    public static void main(String[] args) {
    myWork w=new myWork();
    WorkProxy wp=new WorkProxy(w);
    wp.proxy("杰伦");
    }
    }

    WorkProxy.java

    package com.wzh.test;

    import java.util.logging.Level;
    import java.util.logging.Logger;

    /*
    * 代理类,帮助Work类写日志
    * 1.代理类如何和被代理类管理起来
    * */
    public class WorkProxy {

    private Logger logger=Logger.getLogger(this.getClass().getName());

    private WorkIf work;

    public WorkProxy(WorkIf work) {
    super();
    this.work = work;
    }

    public WorkProxy() {
    super();
    // TODO Auto-generated constructor stub
    }

    //代理方法
    public void proxy(String name){
    try {
    logger.log(Level.INFO,name+"开始工作..."); //日志
    //业务逻辑
    work.doWork(name);//被代理类执行业务逻辑方法
    logger.log(Level.INFO,name+"结束工作...");//日志
    } catch (Exception e) {
    logger.log(Level.SEVERE,name+"工作出现问题...");//日志
    }
    }
    }

  • 相关阅读:
    Winform中设置ZedGraph曲线图的字体样式是避免出现边框
    50本精品前端开发书籍免费下载
    一切“归零”的开始
    小公司大企业
    给“精点们”的一封信
    一个程序员的自我救赎
    一个微服务框架的情节
    《深入理解Java虚拟机》虚拟机类加载机制
    一个微服务框架的故事
    一个程序员的自我剖析
  • 原文地址:https://www.cnblogs.com/zhuawang/p/3364146.html
Copyright © 2011-2022 走看看