首页 > 编程语言 >模板方法模式javac++

模板方法模式javac++

时间:2022-12-23 17:22:33浏览次数:45  
标签:java void db System c++ public connDB 数据库 模板

软件设计                  石家庄铁道大学信息学院

 

实验 24:模板方法模式

本次实验属于模仿型实验,通过本次实验学生将掌握以下内容:

1、理解模板方法模式的动机,掌握该模式的结构;

2、能够利用模板方法模式解决实际问题。

 

[实验任务一]:数据库连接

对数据库的操作一般包括连接、打开、使用、关闭等步骤,在数据库操作模板类中我们定义了connDB()、openDB()、useDB()、closeDB()四个方法分别对应这四个步骤。对于不同类型的数据库(如SQL Server和Oracle),其操作步骤都一致,只是连接数据库connDB()方法不同,现使用模板方法模式对其进行设计。

实验要求:

1. 提交源代码;

 

 

 

 

2.注意编程规范。

 

 

 

package test24;

import java.util.Scanner;
public class Client {
    public static void main(String[] args) {
        DBOperator db = null;
        System.out.println("请选择:1、SQLServer 2、Oracle");
        Scanner input=new Scanner(System.in);
        int i=input.nextInt();
        if(i==1) {
            db=new SQLServerDB();
        }else if(i==2) {
            db=new OracleDB();
        }
        db.process();
    }
}
package test24;

public abstract class DBOperator {
    public void process(){
        connDB();
        openDB();
        useDB();
        closeDB();
    }
    public abstract void connDB();
    public void openDB(){
        System.out.println("打开数据库");
    }
    public void useDB(){
        System.out.println("使用数据库");
    }
    public void closeDB(){
        System.out.println("关闭数据库");
    }
}
package test24;


public class OracleDB extends DBOperator{

    @Override
    public void connDB() {
        // TODO 自动生成的方法存根
        System.out.println("连接Oracle数据库");
    }

}
package test24;

public class SQLServerDB extends DBOperator{

    @Override
    public void connDB() {
        // TODO 自动生成的方法存根
        System.out.println("连接SQLServer数据库");
    }

}
#include<iostream>
using namespace std;
//抽象类
class DBOperator{
public:
    virtual void connDB()=0;
    void openDB(){
        cout<<"打开数据库"<<endl;
    }
    void useDB(){
        cout<<"使用数据库"<<endl;
    }
    void closeDB(){
        cout<<"关闭数据库"<<endl;
    }
    void process(){
        connDB();
        openDB();
        useDB();
        closeDB();
    }
};
//具体子类
class SQLServerDB:public DBOperator{
public:
    void connDB(){
        cout<<"连接SQL Server数据库"<<endl;
    }
};
//具体子类
class OracleDB:public DBOperator{
public:
    void connDB(){
        cout<<"连接Oracle数据库"<<endl;
    }
};
//测试函数
int main(){
    int i;
    DBOperator *db=NULL;
    cout<<"请选择:1、SQL Server\t   2、Oracle"<<endl;
    cin>>i;
    if(i==1){
        db=new SQLServerDB();
    }else if(i==2){
        db=new OracleDB();
    }else{
        cout<<"输入有误!"<<endl;
    }
    db->process();
    delete db;
}

 

 

标签:java,void,db,System,c++,public,connDB,数据库,模板
From: https://www.cnblogs.com/rongzhang/p/17001154.html

相关文章

  • 访问者模式javac++
    软件设计                 石家庄铁道大学信息学院 实验25:访问者模式本次实验属于模仿型实验,通过本次实验学生将掌握以下内容:1、理解访问者模式......
  • 职责链模式javac++
    软件设计                 石家庄铁道大学信息学院 实验15:职责链模式本次实验属于模仿型实验,通过本次实验学生将掌握以下内容: 1、理解职责链模式......
  • 命令模式javac++
    软件设计                 石家庄铁道大学信息学院 实验16:命令模式本次实验属于模仿型实验,通过本次实验学生将掌握以下内容: 1、理解命令模式的动......
  • 中介者模式javac++
    软件设计                 石家庄铁道大学信息学院 实验19:中介者模式本次实验属于模仿型实验,通过本次实验学生将掌握以下内容: 1、理解中介者模式......
  • 备忘录模式javac++
    软件设计                 石家庄铁道大学信息学院 实验 20:备忘录模式本次实验属于模仿型实验,通过本次实验学生将掌握以下内容: 1、理解备忘录模......
  • Java中线程的6种状态详解
    java.lang.Thread.State枚举类中定义了六种线程的状态,可以调用线程Thread中的getState()方法获取当前线程的状态。publicenumState{NEW,RUNNABLE,......
  • 代理模式javac++
    软件设计                 石家庄铁道大学信息学院 实验14:代理模式本次实验属于模仿型实验,通过本次实验学生将掌握以下内容: 1、理解代理模式的动......
  • 15_Java筑基之Object类、多态
    15_Java筑基之Object类、多态一.Object类Object类是类层次结构的根类,每个类都使用Object作为超类(父类).1.equals()方法指示其他某个对象是否与此对象“相等”.示例代码;......
  • C++ 获取特定进程的CPU使用率
    近来发现笔记本在关闭屏幕后风扇转得特别快,打开屏幕后看任务管理器,风扇马上减速,也没有发现大量占用CPU的进程。于是想写一个小程序在后台记录每个进程的CPU使用情况,揪出锁......
  • 装饰模式javac++
    实验11:装饰模式本次实验属于模仿型实验,通过本次实验学生将掌握以下内容: 1、理解装饰模式的动机,掌握该模式的结构;2、能够利用装饰模式解决实际问题。 [实验任务一]:手......