1 回答
TA贡献1111条经验 获得超0个赞
我想说你被卡住的原因是将用户名字符串映射到密码的 HashMap 需要一个HashMap<String, String> uc,但你已经创建了一个HashMap<Integer, User> uc,这消除了使用 HashMap 的价值!如果您打算利用 java.util.HashMap 提供的“优化”——这意味着字符串被“散列”以便在数据结构中快速轻松地查找,您可以按如下方式保存 HashMap:
HashMap<Integer, User> uc = new HashMap <Integer, User>(); {
uc.put("user1", "pass1");
uc.put("user2", "pass2");
uc.put("user3", "pass3");
uc.put("user4", "pass4");
}
以这种方式,您可以按如下方式查找用户名和密码组合:
public boolean checkPassword(String enteredUserName, String enteredPassword)
{
String userPassword = uc.get(enteredUserName);
return enteredPassword.equals(userPassword);
}
如果您绝对必须在 HashMap 中使用“用户”数据结构,另一种选择是:
HashMap<Integer, User> uc = new HashMap <Integer, User>(); {
uc.put("user1", new User("user1", "pass1"));
uc.put("user2", new User ("user2", "pass2"));
uc.put("user3", new User ("user3", "pass3"));
uc.put("user4", new User ("user4", "pass4"));
}
此时获取密码可能如下所示:
public boolean checkPassword(String enteredUserName, String enteredPassword)
{
String userPassword = uc.get(enteredUserName).getPassword();
return enteredPassword.equals(userPassword);
}
我不确定您用来启动的“整数”(用户 ID?)是什么HashMap<Integer, User>-但是- 要意识到的最重要的事情是 HashMap 的目的是在表中“查找”要快得多,因为对查找值执行“哈希”函数。
如果您不打算使用“用户 ID 整数”进行查找,那么将其存储为 HashMap 的键根本没有多大用处。
您的迭代器必须遍历整个表才能找到用户:
public boolean checkPassword(String enteredUserName, String enteredPassord)
{
Iterator<Entry<Integer, User>> it = uc.entrySet().iterator();
while (it.hasNext()){
//some code to validate user input against HashMap entries
User u = it.next().getValue();
if (u.getUserName().equals(enteredUserName())
return u.getPassword().equals(enteredPassword);
}
}
添加回答
举报