blob: 69f6c3312a017e679265f4158f6da06ec9b9a9b9 (
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
|
// -*- C++ -*-
//
// $Id$
ACE_INLINE
ACE_Hashable::ACE_Hashable (void)
: hash_value_ (0)
{
}
ACE_INLINE
ACE_Hashable::~ACE_Hashable (void)
{
}
ACE_INLINE unsigned long
ACE_Hashable::hash (void) const
{
// In doing the check below, we take chance of paying a performance
// price when the hash value is zero. But, that will (hopefully)
// happen far less often than a non-zero value, so this caching
// strategy should pay off, esp. if hash computation is expensive
// relative to the simple comparison.
if (this->hash_value_ == 0)
(const_cast <ACE_Hashable *> (this))->hash_value_ = this->hash_i ();
return this->hash_value_;
}
|