3 回答

TA貢獻(xiàn)1880條經(jīng)驗(yàn) 獲得超4個(gè)贊
但我的觀(guān)點(diǎn)是,對(duì)于每個(gè)鍵,我都會(huì)顯式設(shè)置值,因此如果鍵的數(shù)量增加,方法代碼也會(huì)增加
您需要Map使用 DTO 中的不同值填充 ,因此您沒(méi)有其他選擇。
該方法很長(zhǎng),因?yàn)槟?Map 中添加的鍵和從 DTO 檢索的值之間沒(méi)有映射。
您可以使用以下函數(shù)編寫(xiě)代碼:
static void setValueInMap(Map<String, Object> map, String key, Supplier<Object> mapper) {
map.put(key, mapper.get());
}
并使用它:
Map<String, Object> map = ...;
AbcLoginDTO dto = ...;
setIfPresent(map, "keyUserName", dto::getUserName);
// and so for
但沒(méi)有真正的優(yōu)勢(shì)。
您的第二個(gè)片段與第一個(gè)片段完全沒(méi)有關(guān)系。

TA貢獻(xiàn)2041條經(jīng)驗(yàn) 獲得超4個(gè)贊
如果我理解正確,您想要做的是迭代對(duì)象的所有成員,獲取它們的值,然后根據(jù)它們的名稱(chēng)將它們?cè)O(shè)置為映射。如果是這樣,那么您正在尋找的就是所謂的“反射”。
每個(gè)對(duì)象都可以為您提供其字段或方法(甚至是私有的?。┑臄?shù)組,然后您可以使用 Field / Method 對(duì)象來(lái)操作它們。
Field[] members = AbcLoginDTO.class.getDeclaredFields();
Map<String, Object> values = new HashMap<>();
for(Field member : members) {
member.setAccessible(true);
values.put(member.getName(), member.get(abcLoginDTO));
}
您最終得到的是 AbcLoginDTO 實(shí)例的“地圖表示”。從這里你可以用它做你想做的事...請(qǐng)注意,我在第 1 行中“檢查”類(lèi)本身,然后使用第 6 行中的實(shí)例。這段代碼并不完整,但它是一個(gè)開(kāi)始,這可以也適用于任何對(duì)象。

TA貢獻(xiàn)1853條經(jīng)驗(yàn) 獲得超18個(gè)贊
我不知道我是否理解正確,但如果我這樣做了,那就意味著您所需要的只是一種為您的方法手動(dòng)設(shè)置不同鍵的方法AbcLoginDTO class 如果是這樣,那么這可以輕松完成,讓我們考慮一下您的方法abcLoginDTO.getClientId()總是不同的每個(gè)AbcLoginDTO對(duì)象:
private void setMap(AbcLoginDTO abcLoginDTO, Map<String, Object> getMap) {
getMap.put(Integer.toString(abcLoginDTO.getClientId())+"_NAME", abcLoginDTO.getUsername());
getMap.put(Integer.toString(abcLoginDTO.getClientId())+"_ID", abcLoginDTO.getClientId());
getMap.put(Integer.toString(abcLoginDTO.getClientId())+"_ID", abcLoginDTO.getUserId());
getMap.put(Integer.toString(abcLoginDTO.getClientId())+"_TIME", abcuserLoginDTO.getLocktime());
}
添加回答
舉報(bào)