如何将界面代码和功能代码分离(基于Delphi/VCL)

原创 2001年07月14日 14:32:00

 

东日文档

    很多朋友看了上次我写的“创建良好设计的代码(基于Delphi/VCL)”后,对我说感觉上可以接受其中的观点,但似乎说得太简单,不够具体;也有的朋友对其中的一个小例子有些异议。因此便有了此文。

    上次,我举的例子是这样的:假设要从某处获得一个字符串列表,然后显示于 TListBox 中,我所推崇的代码是:
    ObjectXXX := TObjectXXX.Create;
    ListBox1.Items := ObjectXXX.GetStringList;
    ObjectXXX.Free;
    的确,我承认,单纯从这三行代码来看,似乎有了“滥用对象”之嫌。也许是例子过于简单,给人的感觉是TObjectXXX只有GetStringList这一个public成员函数,如果真的这样的话,那可真是“滥用对象”了。类是对对象的抽象,而对象是由状态和操作(也就是数据和对数据的操作)的集合组成。因此,没有状态的对象不是对象!没有私有数据成员的类的设计是失败的设计(那不是类,而是接口了)。

    好,下面我就举一个详细的例子来说明,如何将界面代码和功能代码分离。
    假设我要做一个简单的个人通讯录管理软件,很显然,整个软件分为两部分:一部分是面象用户的,也就是所谓界面部分,我可以提供四个按钮(分别为“添加”、“删除”、“修改”、“查找”)和一个编辑框(显示通讯录信息和接受用户输入)用于和用户交互;另一部分是功能化的,也就是软件内部的对于通讯录的存取操作。
    于是,有了一个TAddrBook类,它是对功能化部分的抽象。
    TAddrBook = class
    private
        //一些私有成员
    public
        constructor Create;
        destructor Destroy;override;
        GetCount: Integer;
        FindRecord(strString): Integer;
        GetRecord(nIndex:Integer): String;
        SetRecord(nIndex:integer; strRec:String): Boolean;
        AddRecord(strRec:String): Boolean;
        DelRecord(nIndex): Boolean;
        //其它共有成员函数
    end;
    私有成员之所以无法确定,主要是取决于这个类的实现。
   
    如此,可以将对通讯录的存取操作的逻辑封装。而界面部分的代码不会涉及到这些存取逻辑。界面部分代码如下:
    var
      Form1: TForm1;
      AddrBook: TAddrBook;
      nCurRec: Integer;

    implementation   
   
    procedure TForm1.FormCreate(Sender: TObject);
    begin
        AddrBook := TAddrBook.Create;
        nCurRec := AddrBook.GetCount;
    end;

    procedure TForm1.FormClose(Sender: TObject; var Action: TCloseAction);
    begin
        AddrBook.Free;
    end;
   
    //添加按钮
    procedure TForm1.Button1Click(Sender: TObject);
    begin
        if not AddrBook.AddRecord(memo1.Text) then
            ShowMessage("error");
    end;
   
    //删除按钮
    procedure TForm1.Button2Click(Sender: TObject);
    begin
        if not AddrBook.DelRecord(nCurRec) then
            ShowMessage("error");
    end;
   
    //修改按钮
    procedure TForm1.Button3Click(Sender: TObject);
    begin
        if not AddrBook.SetRecord(nCurRec, memo1.Text) then
            ShowMessage("error");
    end;
   
    //查找按钮
    procedure TForm1.Button4Click(Sender: TObject);
    begin
        memo1.Text := AddrBook.GetRecord(AddrBook.FindRecord(memo1.Text));
    end;
   
    以上界面部分的代码,不涉及任何存取逻辑,每个模块的代码简单,易懂,便于维护。而实际上,该通讯录是使用数据库保存还是用文本文件来保存,界面代码都不知道;使用数据库的话,是通过ODBC还是ADO还是BDE访问数据库,界面代码也不知道。实际上,这些存取逻辑的东西取决于TAddrBook类的实现,TAddrBook类的实现可以单独的放在一个.pas文件中,对TAddrBook类的实现的任何更改,都不会影响界面部分。维护代码的时候,将更改局限于某一个模块中的做法是非常明智的。
   
   
Nicrosoft(nicrosoft@sunistudio.com) 于 2001.7.14

如何将界面代码和功能代码分离(基于Delphi/VCL)

  • zgqtxwd
  • zgqtxwd
  • 2008年04月30日 23:06
  • 127

如何将界面代码和功能代码分离(基于Delphi/VCL)

 很多朋友看了上次我写的“创建良好设计的代码(基于Delphi/VCL)”后,对我说感觉上可以接受其中的观点,但似乎说得太简单,不够具体;也有的朋友对其中的一个小例子有些异议。因此便有了此文。    ...
  • hegemon
  • hegemon
  • 2009年03月03日 15:49
  • 605

界面与代码分离

http://dev.csdn.net/Develop/article/8/8839.shtm这是对上文的补充:http://dev.csdn.net/article/10/article/08/08...
  • sumsky
  • sumsky
  • 2005年02月13日 21:31
  • 594

逻辑代码与呈现代码分离原则

问题的提出B/S软件开发的过程中,软件开发人员使用的已经不仅仅是一门单纯的编程语言。除了会用C# 或者java(c++,vb,php...)等高级语言外,还需要使用html或者xml设定页面结构,使用...
  • xhinker
  • xhinker
  • 2008年05月18日 21:07
  • 2336

一点小感受:界面和程序的分离

1 Windows程序,界面和程序是源码级混合 Windows系统下的GUI程序,界面(GUI)与程序其他部分逻辑上是分离的,但是源码上直接交互,界面功能直接通过调用Win32 API来实现。 例...
  • smstong
  • smstong
  • 2016年09月07日 10:27
  • 3135

也谈将界面代码和功能代码分离(基于DELPHI/VCL)

 进一步将界面代码和功能代码分离(基于DELPHI/VCL)之一-----如何将界面代码和功能代码分离(基于Delphi/VCL)一文之补充建议读过Nicrosoft(奈软) 朋友的‘如何将界面代码和...
  • hegemon
  • hegemon
  • 2009年03月03日 16:00
  • 811

界面程序分离思路

目前web开发中面临的一个问题是,很难分清楚哪些是程序员负责的,哪些是美工负责的。在同一个公司还好办,沟通容易,协调也简单。如果是多方合作的项目,一方负责界面一方负责程序,这样分工就很难,由于界面是和...
  • linzhisong
  • linzhisong
  • 2007年07月13日 09:49
  • 795

界面层与逻辑层分离

转自:http://bbs.csdn.net/topics/260019609 问题:如何将 界面层 与 复杂的业务逻辑层 分离开来呢?或者是 分离开到一个什么样的程度算是不耦合?   谈一...
  • CodeSinger
  • CodeSinger
  • 2014年04月19日 22:04
  • 5027

C#实现多线程时如何将底层服务与界面表现分离?

     C/S。    多线程的网络服务端,一个界面线程,一个监听线程,n个对客户的服务线程。希望能将这三者完全分离。界面能够控制监听线程,能够开启或者中止监听线程;监听线程启动服务线程;服务线程将...
  • kofsky
  • kofsky
  • 2007年08月27日 20:47
  • 1232

Python学习 Python3.5+PyQt5环境--------02、代码与界面GUI分离

以GUI_ClearText.py为例。 分解成三个文件: 1、Ui
  • sqxyq
  • sqxyq
  • 2017年06月08日 15:32
  • 625
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:如何将界面代码和功能代码分离(基于Delphi/VCL)
举报原因:
原因补充:

(最多只允许输入30个字)