C++实现singleton

本文介绍了单例模式的两种实现方式:懒汉模式和饿汉模式。懒汉模式中实例在首次调用时创建,而饿汉模式则是在程序启动时就创建实例。详细解释了每种模式的工作原理和特点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <iostream>
using namespace std;

class Singelton
{
public:
	static Singelton* GetInstance()
	{
		if (instance_ == NULL)
		{
			instance_=new Singelton;
		}
		return instance_;
	}
private:
	Singelton(){}
	static Singelton* instance_;
};

Singelton*Singelton::instance_;

int main()
{
	Singelton *s=Singelton::GetInstance();
	Singelton *s2=Singelton::GetInstance();
}
 
 
 
#include <iostream>  //头文件
using  namespace  std;  //命名空间
 
class  Singelton   //单例类
{
public :
     static  Singelton* GetInstance()    //提供了一个获取该单例类实指针的静态函数
     {
         if  (instance_ == NULL)     //判断该实例是否存在
         {
             instance_= new  Singelton;     //不存在的话new一个
         }
         return  instance_;          //存在的话直接返回
     }
private :
     Singelton()                       //该单例类的构造函数
     {
 
     }
     static  Singelton* instance_;      //该单例类的实例,静态
};
 
Singelton*Singelton::instance_;
 
int  main()
{
     
     Singelton *s=Singelton::GetInstance();    //直接获取该单例类实例,因为不存在,所以这里会new一个
     Singelton *s2=Singelton::GetInstance();   //直接获取该单例类实例,因为存在了,所以直接返回,此时s==s2
}

二、饿汉模式:即无论是否调用该类的实例,在程序开始时就会产生一个该类的实例,并在以后仅返回此实例。

由静态初始化实例保证其线程安全性,WHY?因为静态实例初始化在程序开始时进入主函数之前就由主线程以单线程方式完成了初始化,不必担心多线程问题。

故在性能需求较高时,应使用这种模式,避免频繁的锁争夺。

 class SingletonStatic  {  private:      static const SingletonStatic* m_instance;      SingletonStatic(){}  public:      static SingletonStatic* getInstance()      {          return m_instance;     } };  //外部初始化 before invoke main const SingletonStatic* SingletonStatic::m_instance = new SingletonStatic;
JAVA实现详见:
http://www.iteye.com/topic/537563
基于html+python+Apriori 算法、SVD(奇异值分解)的电影推荐算法+源码+项目文档+算法解析+数据集,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用,详情见md文档 电影推荐算法:Apriori 算法、SVD(奇异值分解)推荐算法 电影、用户可视化 电影、用户管理 数据统计 SVD 推荐 根据电影打分进行推荐 使用 svd 模型计算用户对未评分的电影打分,返回前 n 个打分最高的电影作为推荐结果 n = 30 for now 使用相似电影进行推荐 根据用户最喜欢的前 K 部电影,分别计算这 K 部电影的相似电影 n 部,返回 K*n 部电影进行推荐 K = 10 and n = 5 for now 根据相似用户进行推荐 获取相似用户 K 个,分别取这 K 个用户的最喜爱电影 n 部,返回 K*n 部电影进行推荐 K = 10 and n = 5 for now Redis 使用 Redis 做页面访问次数统计 缓存相似电影 在使用相似电影推荐的方式时,每次请求大概需要 6.6s(需要遍历计算与所有电影的相似度)。 将相似电影存储至 redis 中(仅存储 movie_id,拿到 movie_id 后还是从 mysql 中获取电影详细信息), 时间缩短至:93ms。 十部电影,每部存 top 5 similar movie 登录了 1-6 user并使用了推荐系统,redis 中新增了 50 部电影的 similar movie,也就是说,系统只为 6 为用户计算了共 60 部电影的相似度,其中就有10 部重复电影。 热点电影重复度还是比较高的
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值