扫码一下
查看教程更方便
table
表示一个特殊的映射,其中可以以组合方式指定两个键以引用单个值。 它类似于创建 map 的映射。
以下是 com.google.common.collect.table
接口的声明
@gwtcompatible
public interface table
序号 | 方法 | 说明 |
---|---|---|
1 | set |
返回一组所有行键/列键/值三元组。 |
2 | void clear() | 从表中删除所有映射。 |
3 | map |
返回具有给定列键的所有映射的视图。 |
4 | set |
返回一组在表中具有一个或多个值的列键。 |
5 | map |
返回一个视图,该视图将每个列键与从行键到值的相应映射相关联。 |
6 | boolean contains(object rowkey, object columnkey) | 如果表包含具有指定行键和列键的映射,则返回 true。 |
7 | boolean containscolumn(object columnkey) | 如果表包含具有指定列的映射,则返回 true。 |
8 | boolean containsrow(object rowkey) | 如果表包含具有指定行键的映射,则返回 true。 |
9 | boolean containsvalue(object value) | 如果表包含具有指定值的映射,则返回 true。 |
10 | boolean equals(object obj) | 比较指定对象与此表是否相等。 |
11 | v get(object rowkey, object columnkey) | 返回对应于给定行和列键的值,如果不存在此类映射,则返回 null。 |
12 | int hashcode() | 返回此表的哈希码。 |
13 | boolean isempty() | 如果表不包含映射,则返回 true。 |
14 | v put(r rowkey, c columnkey, v value) | 将指定的值与指定的键相关联。 |
15 | void putall(table table) | 将指定表中的所有映射复制到此表。 |
16 | v remove(object rowkey, object columnkey) | 删除与给定键关联的映射(如果有)。 |
17 | map |
返回具有给定行键的所有映射的视图。 |
18 | set |
返回一组在表中具有一个或多个值的行键。 |
19 | map |
返回一个视图,该视图将每个行键与从列键到值的相应映射相关联。 |
20 | int size() | 返回表中行键/列键/值映射的数量。 |
21 | collection |
返回所有值的集合,其中可能包含重复项。 |
在 c:/> guava 中使用我们选择的任何编辑器创建以下 java 程序。
guavatester.java
import java.util.map;
import java.util.set;
import com.google.common.collect.hashbasedtable;
import com.google.common.collect.table;
public class guavatester {
public static void main(string args[]) {
//table == map>
/*
* company: ibm, microsoft, tcs
* ibm -> {101:mahesh, 102:ramesh, 103:suresh}
* microsoft -> {101:sohan, 102:mohan, 103:rohan }
* tcs -> {101:ram, 102: shyam, 103: sunil }
*
* */
//create a table
table employeetable = hashbasedtable.create();
//initialize the table with employee details
employeetable.put("ibm", "101","mahesh");
employeetable.put("ibm", "102","ramesh");
employeetable.put("ibm", "103","suresh");
employeetable.put("microsoft", "111","sohan");
employeetable.put("microsoft", "112","mohan");
employeetable.put("microsoft", "113","rohan");
employeetable.put("tcs", "121","ram");
employeetable.put("tcs", "122","shyam");
employeetable.put("tcs", "123","sunil");
//get map corresponding to ibm
map ibmemployees = employeetable.row("ibm");
system.out.println("list of ibm employees");
for(map.entry entry : ibmemployees.entryset()) {
system.out.println("emp id: " entry.getkey() ", name: " entry.getvalue());
}
//get all the unique keys of the table
set employers = employeetable.rowkeyset();
system.out.print("employers: ");
for(string employer: employers) {
system.out.print(employer " ");
}
system.out.println();
//get a map corresponding to 102
map employermap = employeetable.column("102");
for(map.entry entry : employermap.entryset()) {
system.out.println("employer: " entry.getkey() ", name: " entry.getvalue());
}
}
}
使用 javac 编译器编译类,如下所示
c:\guava>javac guavatester.java
现在运行 guavatester 以查看结果。
c:\guava>java guavatester
结果如下
list of ibm employees
emp id: 102, name: ramesh
emp id: 101, name: mahesh
emp id: 103, name: suresh
employers: ibm tcs microsoft
employer: ibm, name: ramesh