Sponsored Content
Full Discussion: C++ singleton
Top Forums Programming C++ singleton Post 302709463 by vistastar on Wednesday 3rd of October 2012 09:14:13 AM
Old 10-03-2012
C++ singleton

How to write a class that can only be instancialized once?

what about my implementation below?

Code:
#include<iostream>
#include<stdexcept>
using namespace std;

class Singleton
{
public:
 int b;
 Singleton();
private:
    static int num;
};


int Singleton::num = 1;
Singleton::Singleton()
{
    if (num == 0)
        throw runtime_error("Singleton instancialized more than 1 times");
    num--;
}

int main()
{
        Singleton a;
        Singleton b; //here exception occurs
}

 

3 More Discussions You Might Find Interesting

1. Programming

What is singleton class ?

hello members, What is singleton class in c++ and in which case we will go with singleton class. Thanks & Regards Rajkumar_g (2 Replies)
Discussion started by: rajkumar_g
2 Replies

2. Programming

C++ abstract (singleton) factory implementation...

I want to create an abstract factory template which will allow me to pass in an "ID" for a subclass and return the singleton instance of that class stored in the factory. It'd be easy to adapt for "multi-ton", but for its present use this isn't necessary. The requirements are: - I don't want... (2 Replies)
Discussion started by: DreamWarrior
2 Replies

3. UNIX for Beginners Questions & Answers

AIX errpt : ( E7A89C7D Local adapter disabled after unstable singleton for long time )

Medel : 9117-MMC OS: AIX 6.1 Patch level : 6100-07-04-1216 Hacmp version : HACMP v 6.1.0.8 Oracle : 11.2.0.3 RAC Node : 2 node Dear, my one node server has been restarted early this morning, So, i tried to start HA and Oracle database. after that, the follow error appears at the node... (1 Reply)
Discussion started by: tomato00
1 Replies
pthread_mutex_init(3T)													    pthread_mutex_init(3T)

NAME
pthread_mutex_init(), pthread_mutex_destroy() - initialize or destroy a mutex SYNOPSIS
PARAMETERS
mutex Pointer to the mutex to be initialized or destroyed. attr Pointer to the attributes object that defines the characteristics of the mutex to be initialized. If the pointer is NULL, default attributes are used. DESCRIPTION
The function initializes the mutex referenced by mutex with the attributes attr. If the parameter attr is NULL, the default mutex attributes are used. See pthread_mutexattr_init(3T) for a list of default mutex attributes. After successful initialization, the mutex is initialized, unlocked, and ready to be used in mutex operations. A mutex should be initialized only once or the resulting behavior is undefined. The function provides a way to ensure that a mutex is initialized only once. The macro can be used to initialize mutexes that are statically allocated. These mutexes will be initialized with default attributes. The function does not need to be called for statically initialized mutexes. If the process-shared attribute in the mutex attributes object referenced by attr is defined as the mutex must be allocated such that the processes sharing the mutex have access to it. This may be done through the memory-mapping functions (see mmap(2)) or the shared memory functions (see shmget(2)). The function destroys the mutex referenced by mutex. This function may set mutex to an invalid value. The destroyed mutex can be reini- tialized using the function If the mutex is used after destruction in any mutex call, the resulting behavior is undefined. A mutex should be destroyed only when it is unlocked. Destroying a mutex that is currently being used results in undefined behavior. RETURN VALUE
Upon successful completion, and return zero. Otherwise, an error number is returned to indicate the error (the variable is not set). ERRORS
If any of the following occur, the function returns the corresponding error number: The necessary resources (other than memory) to initialize mutex were not available. mutex is an already initialized mutex. However, getting for reinitializing the mutex cannot be expected all the time since the behavior of reinitializing the mutex is undefined. mutex points to an illegal address. The value specified by mutex or attr is invalid. There is insufficient memory available in which to initialize mutex. The caller does not have the necessary permission to perform the mutex initialization. If any of the following occur, the function returns the corresponding error number: mutex is currently locked or in use by another thread. mutex is not a valid mutex. WARNINGS
The space for the mutex must be allocated before calling Undefined behavior will result if the process-shared attribute of attr is and the space allocated for the mutex is not accessible to cooperating threads. AUTHOR
and were derived from the IEEE POSIX P1003.1c standard. SEE ALSO
pthread_mutex_lock(3T), pthread_mutex_trylock(3T), pthread_mutex_unlock(3T). STANDARDS CONFORMANCE
Pthread Library pthread_mutex_init(3T)
All times are GMT -4. The time now is 02:20 PM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy