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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
|
// $Id$
#include "ace/config-lite.h"
#if defined (ACE_HAS_THREADS)
#include "ace/OS_main.h"
#include "ace/OS_Memory.h"
#include "ace/Guard_T.h"
#include "ace/Log_Msg.h"
#include "ace/Thread_Mutex.h"
// This file exists primarily to get code into the book to show different
// ways to do the same thing. For complete context and explanation, please
// see APG chapter 12.
class HA_Device_Repository {
public:
int update_device (int device_id);
private:
ACE_Thread_Mutex mutex_;
};
class Object {
};
static Object *object;
#if 0
// This is less-desired way to do this...
// Listing 1 code/ch12
int
HA_Device_Repository::update_device (int device_id)
{
this->mutex_.acquire ();
ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%t) Updating device %d\n"),
device_id));
// Allocate a new object.
ACE_NEW_RETURN (object, Object, -1);
// ...
// Use the object
this->mutex_.release ();
}
// Listing 1
// Listing 2 code/ch12
int
HA_Device_Repository::update_device (int device_id)
{
// Construct a guard specifying the type of the mutex as
// a template parameter and passing in the mutex to hold
// as a parameter.
ACE_Guard<ACE_Thread_Mutex> guard (this->mutex_);
// This can throw an exception that is not caught here.
ACE_NEW_RETURN (object, Object, -1);
// ..
// Use the object.
// ..
// Guard is destroyed, automatically releasing the lock.
}
// Listing 2
#endif /* 0 */
// Listing 3 code/ch12
int
HA_Device_Repository::update_device (int /* device_id */)
{
ACE_GUARD_RETURN (ACE_Thread_Mutex, mon, mutex_, -1);
ACE_NEW_RETURN (object, Object, -1);
// Use the object.
// ...
return 0;
}
// Listing 3
int ACE_TMAIN (int, ACE_TCHAR *[])
{
HA_Device_Repository rep;
rep.update_device (42);
return 0;
}
#else
#include "ace/OS_main.h"
#include "ace/OS_NS_stdio.h"
int ACE_TMAIN (int, ACE_TCHAR *[])
{
ACE_OS::puts (ACE_TEXT ("This example requires threads."));
return 0;
}
#endif /* ACE_HAS_THREADS */
|