当前位置: 首页 > news >正文

C++编程(五)单例模式 友元

文章目录

  • 一、单例模式
    • (一)概念
    • (二)实现方式
      • 1. 饿汉式
      • 2. 懒汉式
  • 二、友元
    • (一)概念
    • (二)友元函数
      • 1.概念
      • 2.语法格式
      • 3. 使用示例
        • 访问静态成员变量
        • 访问非静态成员变量
    • (三)友元成员函数
    • (四)友元类

一、单例模式

(一)概念

设计模式只是一种编程思想,没有固定的代码。
是面临一般问题的解决的方法。
如:单例模式、工厂模式、桥接模式…

单例指的是只有一个实例化对象

(二)实现方式

1. 饿汉式

饿汉式是加载时完成创建,无论用或者不用,单例对象一直存在
步骤
构造函数私有化
使用私有的静态成员变量维护唯一的单例对象
定义公有的静态成员函数用于获取单例对象

#include <iostream>
using namespace std;
class MyClass
{
public://定义公有的静态成员函数用于获取单例对象static MyClass& getObj(){return m1;}void print(){cout<<"m_a="<<m_a<<endl;}
private://构造函数私有化MyClass(int a):m_a(a){cout<<"私有化构造函数"<<endl;}//使用私有的静态成员变量维护唯一的单例对象static MyClass m1;int m_a;
};
//静态成员变量的定义
MyClass MyClass::m1=100;int main()
{MyClass &m=MyClass::getObj();MyClass &mm=MyClass::getObj();cout<<"&m ="<<&m<<endl;cout<<"&mm="<<&mm<<endl;m.print();mm.print();return 0;
}

输出结果:
在这里插入图片描述

2. 懒汉式

懒汉式是用时即创建,不用即销毁
步骤
构造函数私有化
使用私有的静态成员指针变量维护唯一的单例对象
定义公有的静态成员函数用于获取单例对象(每次调用该函数,都返回唯一的指针)

#include <iostream>
using namespace std;
class MyClass
{
public://定义公有的静态成员函数用于获取单例对象static MyClass* getObj(){if(NULL == m1){m1=new MyClass(100);}return m1;}void print(){cout<<"m_a="<<m_a<<endl;}
private://构造函数私有化MyClass(int a):m_a(a){cout<<"私有化构造函数"<<endl;}//使用私有的静态成员指针变量维护唯一的单例对象static MyClass *m1;int m_a;
};
//静态成员变量的定义
MyClass* MyClass::m1=NULL;int main()
{MyClass *m=MyClass::getObj();MyClass *mm=MyClass::getObj();cout<<"m ="<<m<<endl;cout<<"mm="<<mm<<endl;m->print();mm->print();return 0;
}

输出结果
在这里插入图片描述

二、友元

(一)概念

友元是C++中一种特殊的机制

(二)友元函数

1.概念

将一个全局函数作为一个类的友元函数,在类中将此函数用friend修饰,就是友元函数

友元函数打破类的封装性,友元可以访问类中的任何权限的成员

2.语法格式

class 类名{
访问控制权限:friend 返回值 函数名(形参名){}
}
  • 注意:
  • 友元函数是不受访问控制权限的限制,可以放在类中任意位置,但使用时一般放在开头。

3. 使用示例

访问静态成员变量
#include <iostream>
using namespace std;
class MyClass
{friend void print();
public:static int s_pub;
private:static int s_pri;
protected:static int s_pro;
};//静态成员变量定义
int MyClass::s_pub=100;
int MyClass::s_pri=200;
int MyClass::s_pro=300;//全局函数
void print(){cout<<"s_pub="<<MyClass::s_pub<<" ";cout<<"s_pri="<<MyClass::s_pri<<" ";cout<<"s_pro="<<MyClass::s_pro<<endl;
}int main()
{print();return 0;
}
访问非静态成员变量
#include <iostream>
using namespace std;
class MyClass
{friend void print(MyClass &c);
public:int m_pub;
private:int m_pri;
protected:int m_pro;
};void print(MyClass &c){c.m_pub=10;c.m_pri=20;c.m_pro=30;cout<<"m_pub="<<c.m_pub<<" ";cout<<"m_pri="<<c.m_pri<<" ";cout<<"m_pro="<<c.m_pro<<endl;
}int main()
{MyClass m;print(m);return 0;
}

(三)友元成员函数

将一个类的成员函数作为另一个类的友元函数

(四)友元类

假设有两个类:类A 类B
类B作为类A的友元类,说明类B可以访问类A的公有权限

  • 注:
  • 友元关系不具有交换性:A是B的朋友,B不一定是A的朋友
  • 友元关系不具有传递性
  • 友元关系不能被继承
  • 友元关系破坏了类的封装性,使访问控制权限失去了意义,因此实际开发时,不要过于依赖友元
http://www.lryc.cn/news/389428.html

相关文章:

  • 012-GeoGebra基础篇-构造圆的切线
  • 数据结构速成--查找
  • SpringMVC的基本使用
  • 【PYG】Cora数据集分类任务计算损失,cross_entropy为什么不能直接替换成mse_loss
  • MyBatis-plus这么好用,不允许还有人不会
  • Linux驱动开发实战宝典:设备模型、模块编程、I2C/SPI/USB外设精讲
  • 安全技术和防火墙
  • Webpack: 开发 PWA、Node、Electron 应用
  • python处理txt文件, 如果第一列和第二列的值在连续的行中重复,则只保留一行
  • C++17中引入了什么新的重要特性
  • Andrej Karpathy提出未来计算机2.0构想: 完全由神经网络驱动!网友炸锅了
  • 用国内镜像安装docker 和 docker-compose (ubuntu)
  • Linux多线程【线程互斥】
  • os实训课程模拟考试(大题复习)
  • QT/QML国际化:中英文界面切换显示(cmake方式使用)
  • 设计模式在Java项目中的实际应用
  • js制作随机四位数验证码图片
  • [开源软件] 支持链接汇总
  • 从零开始搭建spring boot多模块项目
  • Iot解决方案开发的体系结构模式和技术
  • 02.C1W1.Sentiment Analysis with Logistic Regression
  • Stable Diffusion秋叶AnimateDiff与TemporalKit插件冲突解决
  • PCL 渐进形态过滤器实现地面分割
  • 第十四届蓝桥杯省赛C++B组E题【接龙数列】题解(AC)
  • Ubuntu 20.04.4 LTS 离线安装docker 与docker-compose
  • vue3+ts 写echarts 中国地图
  • 【设计模式】【行为型模式】【责任链模式】
  • 超越所有SOTA达11%!媲美全监督方法 | UC伯克利开源UnSAM
  • 享元模式(设计模式)
  • 【机器学习】大模型训练的深入探讨——Fine-tuning技术阐述与Dify平台介绍