forked from algorhythms/LintCode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSingleton.py
46 lines (35 loc) · 1.08 KB
/
Singleton.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
"""
Singleton is a most widely used design pattern. If a class has and only has one instance at every moment, we call this
design as singleton. For example, for class Mouse (not a animal mouse), we should design it in singleton.
You job is to implement a getInstance method for given class, return the same instance of this class every time you call
this method.
Example
In Java:
A a = A.getInstance();
A b = A.getInstance();
a should equal to b.
Challenge
If we call getInstance concurrently, can you make sure your code could run correctly?
"""
import threading
__author__ = 'Daniel'
class Solution_unsafe:
obj = None
@classmethod
def getInstance(cls):
"""
:return: The same instance of this class every time
"""
if not Solution.obj:
Solution.obj = cls()
return Solution.obj
class Solution:
__lock = threading.Lock()
__obj = None
@classmethod
def getInstance(cls):
if not cls.__obj:
with cls.__lock:
if not cls.__obj:
cls.__obj = cls()
return cls.__obj