[英]How to get a Unique ID for a list of strings?
如何获得字符串列表的唯一ID(作为整数)?
例如,列表看起来像["Cat","Dog","Cow","Cat","Rat"]
,结果应为:
1 -> Cat
2 -> Dog
3 -> Cow
4 -> Rat
我需要保存此结构和新结构。
编辑:重要的是, Cat
在新结构中只有一次。
您可以使用HashMap<Integer, String>
。 键将是当前List
的索引,而值将是实际的String
。
例:
List<String> myList = new ArrayList<String>();
// no identical Strings here
Set<String> mySet = new LinkedHashSet<String>();
myList.add("Cat"); // index 0
myList.add("Dog"); // index 1
myList.add("Cow"); // etc
myList.add("Cat");
myList.add("Rat");
mySet.add("Cat"); // index 0
mySet.add("Dog"); // index 1
mySet.add("Cow"); // etc
mySet.add("Cat"); // index 0 - already there
mySet.add("Rat");
Map<Integer, String> myMap = new HashMap<Integer, String>();
for (int i = 0; i < myList.size(); i++) {
myMap.put(i, myList.get(i));
}
System.out.println(myMap);
Map<Integer, String> myOtherMap = new HashMap<Integer, String>();
int i = 0;
for (String animal: mySet) {
myOtherMap.put(i++, animal);
}
System.out.println(myOtherMap);
输出:
{0=Cat, 1=Dog, 2=Cow, 3=Cat, 4=Rat}
{0=Cat, 1=Dog, 2=Cow, 3=Rat}
如果它仅在流程中唯一,则可以在每次需要新值时使用AtomicInteger
并调用AtomicInteger
incrementAndGet()
。
否则你可以试试这个
int uniqueId = 0;
int getUniqueId()
{
return uniqueId++;
}
如果希望线程安全,请添加同步。
private enum Animals {
Cat,
Dog,
Cow,
Sheep,
Horse
}
Animals.Cat.ordinal()
-给您数字。 Animals.valueOf("Cat");
-匹配字符串。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.