Ada 编程/库/Ada.Containers.Indefinite Hashed Sets
外观
此语言功能仅从 Ada 2005 开始可用。
Ada.Containers.Indefinite_Hashed_Sets 是自 Ada 2005 以来 预定义语言环境 的一个单元。
-- Standard Ada library specification -- Copyright (c) 2003-2018 Maxim Reznik <[email protected]> -- Copyright (c) 2004-2016 AXE Consultants -- Copyright (c) 2004, 2005, 2006 Ada-Europe -- Copyright (c) 2000 The MITRE Corporation, Inc. -- Copyright (c) 1992, 1993, 1994, 1995 Intermetrics, Inc. -- SPDX-License-Identifier: BSD-3-Clause and LicenseRef-AdaReferenceManual -- -------------------------------------------------------------------------generic
type
Element_Type (<>)is
private
;with
function
Hash (Element :in
Element_Type)return
Hash_Type;with
function
Equivalent_Elements (Left :in
Element_Type; Right :in
Element_Type)return
Boolean;with
function
"=" (Left :in
Element_Type; Right :in
Element_Type)return
Booleanis
<>;package
Ada.Containers.Indefinite_Hashed_Setsis
pragma
Preelaborate (Indefinite_Hashed_Sets);type
Setis
tagged
private
;pragma
Preelaborable_Initialization (Set);type
Cursoris
private
;pragma
Preelaborable_Initialization (Cursor); Empty_Set :constant
Set; No_Element :constant
Cursor;function
"=" (Left :in
Set; Right :in
Set)return
Boolean;function
Equivalent_Sets (Left :in
Set; Right :in
Set)return
Boolean;function
To_Set (New_Item :in
Element_Type)return
Set;function
Capacity (Container :in
Set)return
Count_Type;procedure
Reserve_Capacity (Container :in
out
Set; Capacity :in
Count_Type);function
Length (Container :in
Set)return
Count_Type;function
Is_Empty (Container :in
Set)return
Boolean;procedure
Clear (Container :in
out
Set);function
Element (Position :in
Cursor)return
Element_Type;procedure
Replace_Element (Container :in
out
Set; Position :in
Cursor; New_Item :in
Element_Type);procedure
Query_Element (Position :in
Cursor; Process :not
null
access
procedure
(Element :in
Element_Type));procedure
Move (Target :in
out
Set; Source :in
out
Set);procedure
Insert (Container :in
out
Set; New_Item :in
Element_Type; Position :out
Cursor; Inserted :out
Boolean);procedure
Insert (Container :in
out
Set; New_Item :in
Element_Type);procedure
Include (Container :in
out
Set; New_Item :in
Element_Type);procedure
Replace (Container :in
out
Set; New_Item :in
Element_Type);procedure
Exclude (Container :in
out
Set; Item :in
Element_Type);procedure
Delete (Container :in
out
Set; Item :in
Element_Type);procedure
Delete (Container :in
out
Set; Position :in
out
Cursor);procedure
Union (Target :in
out
Set; Source :in
Set);function
Union (Left :in
Set; Right :in
Set)return
Set;function
"or" (Left :in
Set; Right :in
Set)return
Setrenames
Union;procedure
Intersection (Target :in
out
Set; Source :in
Set);function
Intersection (Left :in
Set; Right :in
Set)return
Set;function
"and" (Left :in
Set; Right :in
Set)return
Setrenames
Intersection;procedure
Difference (Target :in
out
Set; Source :in
Set);function
Difference (Left :in
Set; Right :in
Set)return
Set;function
"-" (Left :in
Set; Right :in
Set)return
Setrenames
Difference;procedure
Symmetric_Difference (Target :in
out
Set; Source :in
Set);function
Symmetric_Difference (Left :in
Set; Right :in
Set)return
Set;function
"xor" (Left :in
Set; Right :in
Set)return
Setrenames
Symmetric_Difference;function
Overlap (Left :in
Set; Right :in
Set)return
Boolean;function
Is_Subset (Subset :in
Set; Of_Set :in
Set)return
Boolean;function
First (Container :in
Set)return
Cursor;function
Next (Position :in
Cursor)return
Cursor;procedure
Next (Position :in
out
Cursor);function
Find (Container :in
Set; Item :in
Element_Type)return
Cursor;function
Contains (Container :in
Set; Item :in
Element_Type)return
Boolean;function
Has_Element (Position :in
Cursor)return
Boolean;function
Equivalent_Elements (Left :in
Cursor; Right :in
Cursor)return
Boolean;function
Equivalent_Elements (Left :in
Cursor; Right :in
Element_Type)return
Boolean;function
Equivalent_Elements (Left :in
Element_Type; Right :in
Cursor)return
Boolean;procedure
Iterate (Container :in
Set; Process :not
null
access
procedure
(Position :in
Cursor));generic
type
Key_Type (<>)is
private
;with
function
Key (Element :in
Element_Type)return
Key_Type;with
function
Hash (Key :in
Key_Type)return
Hash_Type;with
function
Equivalent_Keys (Left :in
Key_Type; Right :in
Key_Type)return
Boolean;package
Generic_Keysis
function
Key (Position :in
Cursor)return
Key_Type;function
Element (Container :in
Set; Key :in
Key_Type)return
Element_Type;procedure
Replace (Container :in
out
Set; Key :in
Key_Type; New_Item :in
Element_Type);procedure
Exclude (Container :in
out
Set; Key :in
Key_Type);procedure
Delete (Container :in
out
Set; Key :in
Key_Type);function
Find (Container :in
Set; Key :in
Key_Type)return
Cursor;function
Contains (Container :in
Set; Key :in
Key_Type)return
Boolean;procedure
Update_Element_Preserving_Key (Container :in
out
Set; Position :in
Cursor; Process :not
null
access
procedure
(Element :in
out
Element_Type));end
Generic_Keys;private
type
Setis
tagged
null
record
; Empty_Set :constant
Set := (null
record
);type
Cursoris
null
record
; No_Element :constant
Cursor := (null
record
);end
Ada.Containers.Indefinite_Hashed_Sets;
外部示例
[编辑源代码]- 在以下位置搜索 示例
Ada.Containers.Indefinite_Hashed_Sets
:Rosetta Code,GitHub (gists),任何 Alire 包 或 此维基教科书。 - 在以下位置搜索 帖子 与
Ada.Containers.Indefinite_Hashed_Sets
相关:Stack Overflow,comp.lang.ada 或 任何与 Ada 相关的页面。
FSF GNAT
- 规范:a-cihase.ads
- 主体:a-cihase.adb
drake