动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Java教程 ]的信息

本月文章推荐
.学习心得:Java基本功之Referenc.
.Struts Menu中基于角色的权限管理.
.看java编程思想笔记(5-6).
.Boolean 对象.
.Struts+Spring+Hibernate快速入门.
.中国农历二百年算法及年历程序分.
.Java Web层的下一个王者是谁?.
.Windows98下安装和配置JDK.
.JBuilder Editor中光标不能正确定.
.用lpadmin打印多种内容形式.
.JDBMonitor全攻略.
.软件最大的追求是什么?.
.bug? Hbm2JavaTask无法实现joine.
.解析J2EE中的安全问题.
.J2EE的概念.
.jdbc驱动导致的中文问题.
.读取数码照片中的Exif信息.
.正确使用ArrayList和LinkedList—.
.菜鸟初学Java的备忘录(三).
.Unix标准加密方法(2).

Model View Controller 与 Observer

发表日期:2008-1-5 |



  MVC:
  “模型-视图-控制器(Model-View-Controller,MVC)结构是为那些需要为同样的数据提供多个视图的应用程序而设计的,它很好的实现了数据层与表示层的分离。例如下图中的例子:
  
 Model View Controller 与 Observer(图一)


  我们看到,图中的几组数据以不同的形式(View)表现出来,一个是表格样式,一个是图形样式。
  
  MVC把这种应用程序分为三种对象类型:
  模型:维护数据并提供数据访问方法。
  视图:给制模型的部分数据或所有数据的可视图。
  控制器:处理事件.
  以下是典型的MVC通信方式
  
 Model View Controller 与 Observer(图二)

  设计模式:实战MVC模式 turbochen
  
  内容:
  1.MVC
  2.Observer接口
  3.模型Model
  4.视图View
  5.控制器Controller
  6.运行程序
  
  MVC
  “模型-视图-控制器(Model-View-Controller,MVC)结构是为那些需要为同样的数据提供多个视图的应用程序而设计的,它很好的实现了数据层与表示层的分离。例如下图中的例子:
  
 Model View Controller 与 Observer(图三)

  我们看到,图中的几组数据以不同的形式(View)表现出来,一个是表格样式,一个是图形样式。
  
  MVC把这种应用程序分为三种对象类型:
  模型:维护数据并提供数据访问方法。
  视图:给制模型的部分数据或所有数据的可视图。
  控制器:处理事件.
  以下是典型的MVC通信方式
  
Model View Controller 与 Observer(图四)

  事件由控制器来处理,控制器接收用户事件,并根据事件的类型来改变模型。
  视图事先会在模型中登记,当模型数据发生改变时,马上通知已向此模型登记的每个视图。
  视图从模取得最新的数据并刷新自己.
  要实现MVC,最重要的一个环节是使用Design Pattern中的Observer模式。Observer模式答应某个对象在所观察的对象发生修改时通知多个观察者(Observer).
  
  下面我们就以实例来讲解如何用Obserer模式实现MVC的程序结构。在我的例子中,我要实现一个学生年龄显示的例子。分别用清单和图形的方式显示每个学生的年龄。当年龄改变时,自动更新显示。
  
  Observer接口
  为了实现观察的对象发生修改时通知多个观察者,通常要在被观察者与观察者之间有一个小的接口,如下:
  /* file&: Observer.Java */
  
  public interface Observer
  {
  public void dataUpdate(Model model);
  }
  
  这个接口中有一个dataUpdate(Model model)方法,只要实现了这个接口对象,就成了一个观察者。
  
  模型Model
  再来建立一个数据模型。在我的例子中,先建立了一个数据对象:
  /* file&: Data.java */
  
  public class Data
  {
  public int value;  public String name;
  }
  
  现在来建立一个Model:
  /* file&: Model.java */
  
  import java.util.*;
  public class Model
  {
  ArrayList data = new ArrayList();
  ArrayList observer = new ArrayList();
  public Model()
  {  super();
  }
  public Model(int[] value, String[] name)
  {
    for ( int i = 0; i< value.length; i++ )
    {
      addData(value[i],name[i]);
    }
  }
  public Model(Data[] data)
  {
    for ( int i = 0; i< data.length; i++ )
    {
      addData(data[i]);
    }
  }
  public void addData(int value, String name)
  {
    Data data = new Data();
    data.value = value;
    data.name = name;
    this.data.add(data);
  }
  public void addData(Data data)
  {
    this.data.add(data);
  }
  public Data getData(int idx)
  {
    return (Data)(data.get(idx));
  }
  
  public int size()
  {
    return data.size();
  }
  public void registerObserver(Observer o)
  {
    observer.add(o);
  }
  public void removeObserver(Observer o)
  {
    observer.remove(o);
  }
  public void changeModel(Model model)
  {
    data.clear();
    for (int i=0; i
    {
      this.addData(model.getData(i));
    }
    dataUpdate();
  }
  private void dataUpdate()
  {
    for (Iterator i = observer.iterator(); i.hasNext(); )
    {
      Observer o = (Observer)(i.next());
      o.dataUpdate(this);
    }
  }
  }
  
  这个模型提供各种数据访问的方法。并提供一个changeModel(Model model)方法供Controller访问。还提供一个registerObserver(Observer o)方法,用来向Model中登记观察者Observer。
  
  视图View
  我们要实现一个清单显示样式的视图View1和一个图形方式显示的视图View2,并让它们实现Observer接口,以便当Model数据改变时,自动刷新自己.
  /* file&: View1.java */
  
  import javax.swing.*;
  import java.awt.*;
  import javax.swing.border.*;
  public class View1 extends JPanel implements Observer
  {
  Model model;
  
  public View1()
  {
  }
  public View1(Model model)
  {
    try
    {
      this.model = model;
      jbInit();
    }
    catch(Exception e)
    {
      e.printStackTrace();
    }
  }
  private void jbInit() throws Exception
  {
    this.setBackground(Color.white);
    this.setBorder(new TitledBorder(BorderFactory.createLineBorder(Color.black,1),"View1"));
  }
  
  public void paintComponent(Graphics g)
  {
    super.paintComponent(g);
    if ( model == null ) return;
    int x = 20,y = 50;
    int h = g.getFontMetrics().getHeight();
    for ( int i=0; i< model.size(); i++ )
    {
      Data data = model.getData(i);
      g.drawString(data.name,x,y);
      y+=h;
      g.drawString(String.valueOf(data.value),x,y);
      y+=h;
    }
  }
  public void dataUpdate(Model model)
  {
    /**@todo: Implement this Observer method*/
    this.model = model;
    repaint();
  }
  }
  /* file&: View2.java */
  import javax.swing.*;
  import java.awt.*;
  import javax.swing.border.*;
  public class View2 extends JPanel implements Observer
  {
  Model model;
  
  public View2()
  {
  }
  public View2(Model model)
  {
    try
    {
      this.model = model;
      jbInit();
    }
    catch(Exception e)
    {
      e.printStackTrace();
    }
  }
  private void jbInit() throws Exception
  {
    this.setBackground(Color.white);
    this.setBorder(new TitledBorder(BorderFactory.createLineBorder(Color.black,1),"View1"));
  }
  
  public void paintComponent(Graphics g)
  {
    super.paintComponent(g);
    if ( model == null ) return;
    int x = 20,y = 50;
    int h = g.getFontMetrics().getHeight();
    int width = this.getWidth();
    int height = this.getHeight();
    int sy = height / model.size();
    int sx = width/ 2;
    for ( int i=0; i< model.size(); i++ )
    {
      Data data = model.getData(i);
      int value = data.value;
      int dx = 3;
      int r = 3;
      Color c = new Color((int)(255*Math.random()),(int)(255*Math.random()),(int)(255*Math.random()));
      int cx = sx;
      int cy = y+i * sy;
      for ( int j=0;j
      {
上一篇:控制反转(Inversion of Control)介绍 人气:709
下一篇:JML起步--使用JML改进你的Java程序(3) 人气:487
浏览全部Java的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-10-10 企业网站智能管理系统(TZIMS) v6
2008-10-10 拓文asp.net网站内容管理系统 v6
2008-10-10 动网论坛PHP版 v2.0++ Build 081
2008-10-10 免费时代CMS v5.0
2008-10-10 wodig第四季中文DIGG社区 v4.1 b
2008-10-10 老Y文章管理系统 v2.2 bulid 081
2008-10-10 魔法盒动感相册 ASP+SQL版 v2.0
2008-10-10 Asoft签到管理系统 v3.0 Pack1
2008-10-10 哥特人音乐网潮流留言本 v1.1
2008-9-29 酷狗音乐(原KuGoo)2008 v5.310 正
2008-9-29 QQTab 1.1
2008-9-29 网络传送带 Net Transport 2.64a
2008-9-29 谷歌金山词霸v1.8
2008-9-29 TweakVI 1.0 Build 1090
2008-9-29 ACDSee Pro 2.5 Build 333 汉化绿
2008-9-29 Winamp v5.541(2189) 周明波简体
2008-9-27 CCleaner 2.12.651
2008-9-27 Mozilla Thunderbird 2.0.0.17 英
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | js/vbs加密 | md5加密 | 进制转换 | UTF-8 转换工具 | Html转换js | Html转换asp | Html转换php | Html转换perl
实用工具:汉字翻译拼音 | 拼音字典 | 符号对照表 | 个税计算 | 实时汇率查询换算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 | 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号