-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathFuture.java
More file actions
59 lines (51 loc) · 2.23 KB
/
Future.java
File metadata and controls
59 lines (51 loc) · 2.23 KB
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
/*************************************************************************************************
* Future interface
*
* Copyright 2020 Google LLC
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of the License at
* https://www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, software distributed under the
* License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
* either express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*************************************************************************************************/
package tkrzw;
/**
* Future containing a status object and extra data.
* @note Future objects are made by methods of AsyncDBM. Every future object should be destroyed by the "destruct" method or the "get" method to free resources.
*/
public class Future<T> {
/**
* Default forbidden constructor.
*/
private Future() {}
/**
* Destructs the object and releases resources.
*/
public native void destruct();
/**
* Awaits the operation to be done.
* @param timeout The waiting time in seconds. If it is negative, no timeout is set.
* @return True if the operation has done. False if timeout occurs.
*/
public native boolean await(double timeout);
/**
* Awaits the operation to be done and gets the result status.
* @return The result status and extra data if any. The existence and the type of extra data
* depends on the operation which makes the future. For DBM#Get, a tuple of the status and
* the retrieved value is returned. For DBM#Set and DBM#Remove, the status object itself is
* returned.
* @note The internal resource is released by this method. "aait" and "get" cannot be called after calling this method.
*/
public native T get();
/**
* Gets a string representation of the database.
*/
public native String toString();
/** The pointer to the native object */
private long ptr_ = 0;
/** Wheether the extra value is string data. */
private boolean is_str_ = false;
}
// END OF FILE