blob: 3c02779f36e2cfd41385391416edf3769fb5196a (
plain)
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
|
/* -*- C++ -*- */
// $Id$
// ============================================================================
//
// = LIBRARY
// none
//
// = FILENAME
// ID_Generator.h
//
// = AUTHOR
// Nanbor Wang
//
// ============================================================================
#ifndef ACE_ID_GENERATOR_H
#define ACE_ID_GENERATOR_h
#include "ace/Synch.h"
#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */
#define ACE_OFFER_ID_LENGTH 21
class ACE_ID_Generator
// = TITLE
// An unique ID generator.
//
// = DESCRIPTION
// Generate an offer ID according to current time and avoid
// duplicate ID. It guarantees ID uniqueness within a process,
// i.e. no two threads may get the same ID string. Using a
// similar method like the backery algorithm.
{
public:
static char *get_new_id (char *id);
// allocate a new ID string and point <id> to it.
private:
static void get_serial_id (time_t &t, size_t &s);
// Atomically get info required to generate an offer ID.
static ACE_SYNCH_MUTEX *get_lock (void);
// Get the lock instance.
static time_t last_time_;
// Record the time last offer ID generated.
static size_t last_number_;
// Record serial number of last offer ID with same
// generation time.
static ACE_SYNCH_MUTEX *lock_;
// mutex to access private member.
};
#endif /* ACE_ID_GENERATOR_H */
|