泡泡

              宠辱不惊-闲看庭前花开花落
                           去留无意-漫观天外云展云舒
  首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

22)Template

Posted on 2007-09-21 17:07  AlanPaoPao  阅读(171)  评论(0)    收藏  举报
    模板方法模式的目的是: 定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。
    实例代码:
abstract class DataAccessObject
{
  
protected string connectionString;
  
protected DataSet dataSet;
  
public virtual void Connect()
  
{
    connectionString 
="provider=Microsoft.JET.OLEDB.4.0; data source=c:\\nwind.mdb";
  }

  
public abstract void Select();
  
public abstract void Process();
  
public virtual void Disconnect()
  
{
    connectionString 
= "";
  }

  
public void Run()
  
{
    Connect();
    Select();
    Process();
    Disconnect();
  }

}

class Categories : DataAccessObject
{
  
public override void Select()
  
{
    
string sql = "select CategoryName from Categories";
    OleDbDataAdapter dataAdapter 
= new OleDbDataAdapter(sql, connectionString);
    dataSet 
= new DataSet();
    dataAdapter.Fill(dataSet, 
"Categories");
  }

  
public override void Process()
  
{
    Console.WriteLine(
"Categories ---- ");
    DataTable dataTable 
= dataSet.Tables["Categories"];
    
foreach (DataRow row in dataTable.Rows)
    
{
      Console.WriteLine(row[
"CategoryName"]);
    }

    Console.WriteLine();
  }

}

class Products : DataAccessObject
{
  
public override void Select()
  
{
    
string sql = "select ProductName from Products";
    OleDbDataAdapter dataAdapter 
= new OleDbDataAdapter(sql, connectionString);
    dataSet 
= new DataSet();
    dataAdapter.Fill(dataSet, 
"Products");
  }

  
public override void Process()
  
{
    Console.WriteLine(
"Products ---- ");
    DataTable dataTable 
= dataSet.Tables["Products"];
    
foreach (DataRow row in dataTable.Rows)
    
{
      Console.WriteLine(row[
"ProductName"]);
    }

    Console.WriteLine();
  }

}

class MainApp
{
  
static void Main()
  
{
    DataAccessObject dao;
    dao 
= new Categories();
    dao.Run();
    dao 
= new Products();
    dao.Run();
    Console.Read();
  }

}