-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDGL_Double.pas
92 lines (69 loc) · 2.38 KB
/
DGL_Double.pas
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
(*
* Copyright (c) 2004
*
* This material is provided "as is", with absolutely no warranty expressed
* or implied. Any use is at your own risk.
*
* Permission to use or copy this software for any purpose is hereby granted
* without fee, provided the above notices are retained on all copies.
* Permission to modify the code and to distribute modified code is granted,
* provided the above notices are retained, and a notice that the code was
* modified is included with the above copyright notice.
*
*)
//------------------------------------------------------------------------------
// 具现化的Double类型的声明
// Create by HouSisong, 2006.10.09
//------------------------------------------------------------------------------
unit DGL_Double;
interface
uses
SysUtils;
{$I DGLCfg.inc_h}
type
_ValueType = Double;
const
_NULL_Value:Double=0;
function _HashValue(const Key: _ValueType):Cardinal;{$ifdef _DGL_Inline} inline; {$endif}//Hash函数
{$I DGL.inc_h}
type
TDoubleAlgorithms = _TAlgorithms;
IDoubleIterator = _IIterator;
IDoubleContainer = _IContainer;
IDoubleSerialContainer = _ISerialContainer;
IDoubleVector = _IVector;
IDoubleList = _IList;
IDoubleDeque = _IDeque;
IDoubleStack = _IStack;
IDoubleQueue = _IQueue;
IDoublePriorityQueue = _IPriorityQueue;
TDoubleVector = _TVector;
TDoubleDeque = _TDeque;
TDoubleList = _TList;
IVectorIterator = _IVectorIterator; //速度比_IIterator稍快一点:)
IDequeIterator = _IDequeIterator; //速度比_IIterator稍快一点:)
IListIterator = _IListIterator; //速度比_IIterator稍快一点:)
TDoubleStack = _TStack;
TDoubleQueue = _TQueue;
TDoublePriorityQueue = _TPriorityQueue;
IDoubleMapIterator = _IMapIterator;
IDoubleMap = _IMap;
IDoubleMultiMap = _IMultiMap;
TDoubleSet = _TSet;
TDoubleMultiSet = _TMultiSet;
TDoubleMap = _TMap;
TDoubleMultiMap = _TMultiMap;
TDoubleHashSet = _THashSet;
TDoubleHashMultiSet = _THashMultiSet;
TDoubleHashMap = _THashMap;
TDoubleHashMultiMap = _THashMultiMap;
implementation
uses
HashFunctions;
function _HashValue(const Key :_ValueType):Cardinal; overload;
begin
result:=HashValue_Double(Key);
end;
{$I DGL.inc_pas}
end.