blob: c3c9bc43a1a116e0dcd7fb1240df465ac80c606a (
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
 | //$Id: Hashable.cpp 80826 2008-03-04 14:51:23Z wotte $
#include "ace/Hashable.h"
#if !defined (__ACE_INLINE__)
#include "ace/Hashable.inl"
#endif /* __ACE_INLINE __ */
ACE_RCSID (ace,
           Hashable,
           "$Id: Hashable.cpp 80826 2008-03-04 14:51:23Z wotte $")
ACE_BEGIN_VERSIONED_NAMESPACE_DECL
ACE_Hashable::~ACE_Hashable (void)
{
}
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)
    this->hash_value_ = this->hash_i ();
  return this->hash_value_;
}
ACE_END_VERSIONED_NAMESPACE_DECL
 |