java map value值是引用的变量?

本文解决了在使用Map存储对象时遇到的值对象变化问题。通过每次存储前创建新的对象实例,避免了对象引用导致的数据错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天碰到个奇怪的问题,花了很久终于找到原因。

原来代码类似如下:


 getFinancalReport tf=new getFinancalReport();
    	  for(int i=1;i<sheetResult.getRows();i++)
    	  {
    		  String teamLeader=sheetResult.getCell(12,i).getContents().trim();
    		  double amt=Double.parseDouble(sheetResult.getCell(4,i).getContents().trim());
    		  if(!map.containsKey(teamLeader))
    		  {
    			  //每次存进去都要新建,否则会出问题
    			
    			  tf.amt=amt;
    			  map.put(teamLeader,tf);
    		  }else
    		  {
    			 
    			  tf.amt=amt+map.get(teamLeader).amt;
    			  map.put(teamLeader,tf);
    		  }

结果每次运行map的value值都会变,如下图:


第一次运行key为杨的value值是10,但当插入key为叶的值后,杨的value值也会跟着变。

后来改成如下代码:

 for(int i=1;i<sheetResult.getRows();i++)
    	  {
    		  String teamLeader=sheetResult.getCell(12,i).getContents().trim();
    		  double amt=Double.parseDouble(sheetResult.getCell(4,i).getContents().trim());
    		 
    		  if(!map.containsKey(teamLeader))
    		  {
    			  //每次存入map都要新建对象
    			  getFinancalReport tf=new getFinancalReport();
    			  tf.amt=amt;
    			  map.put(teamLeader,tf);
    		  }else
    		  {
    			  getFinancalReport tf=new getFinancalReport();
    			  tf.amt=amt+map.get(teamLeader).amt;
    			  map.put(teamLeader,tf);
    		  }

正常了


猜测是存入map时,value值直接引用了tf对象,所以跟着该对象值也会变。后续再研究




Java 中,直接遍历 `Map` 并修改其键对中的 value 需要特别注意。因为通过某些迭代方式(如 for-each 循环),你无法直接改变原始 Map 的内容。以下是几种常见的方式可以安全地完成这一操作: ### 使用 EntrySet 遍历并修改 Value 最推荐的做法是通过 `entrySet()` 方法获取到所有映射项的一个集合,并利用迭代器逐一遍历每个 entry 对象,在此过程中可以直接对其 setValue() 来更新对应的。 ```java import java.util.HashMap; import java.util.Map; public class Main { public static void main(String[] args) { Map<String, Integer> map = new HashMap<>(); map.put("A", 1); map.put("B", 2); // 修改Value示例 - 将所有的value乘以10 for (Map.Entry<String, Integer> entry : map.entrySet()) { entry.setValue(entry.getValue() * 10); // 这里使用setValue() } System.out.println(map); // 输出 {A=10, B=20} } } ``` 这种方式能够保证只更改了 values 而不会影响 keys 或者结构本身的安全性问题。 ### 其他方式注意事项 如果采用增强for循环或其他形式访问 key 和 value,则实际上只是取得了副本数据;因此单纯改写其中的变量并不会真正作用于原容器内存储的数据。例如下面这种做法就是无效的: ```java // 错误示范: 变更的是临时拷贝而非实际引用的内容 for(Integer val : map.values()){ val *= 10; // 此行完全无意义... } ``` 上面例子试图通过values视图来达到目的失败了,原因是基本类型的赋不会同步回原来的表中去。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值