10.31 实验7:单例模式

[实验任务一]:学号的单一
仿照课堂的身份证的例子,实现每个同学仅有一个学号这一问题。
实验要求:
1.画出对应的类图;

 

2.提交源代码;
复制代码
#include <iostream>

using namespace std;

class S_num{
private:
    static S_num sno;
    static int num;
public:
    static S_num getintance() {
        // TODO Auto-generated method stub
        if(num==0) {
            cout<<"第一次办理学生证,分配新号码!"<<endl;
            sno.setNum(20193288);
        }
        else {
            cout<<"重复办理学生证,获取旧号码!"<<endl;
        }
        return sno;
    }
    int getNum() {
        return num;
    }
    void setNum(int n) {
        num = n;
    }
};

int S_num::num = 0;
S_num S_num::sno = S_num();

int main()
{
    S_num sno1=S_num().getintance();
    cout<<"第一次获取学号"<<sno1.getNum()<<endl;
    S_num sno2=S_num().getintance();
    cout<<"第二次获取学号"<<sno2.getNum()<<endl;
    cout<<"内容是否相等:"<<(sno1.getNum()==sno2.getNum())<<endl;
    //cout<<"是否是相同对象:"<<(sno1==sno2)<<endl;
}
复制代码

 

3.注意编程规范。
posted @     阅读(12)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
点击右上角即可分享
微信分享提示