今天测试 dummy project 的时候突然发现原来我取出来的 company 和 department 存在重名的 company ,最开始我认为是原始的数据库中存在脏数据,而后来查看数据库字段原来Company_Department表中只有company和department两个字段,而且是联合主键。 这样也就否决了我之前的假设,而现在这个阶段我已经把所有的模块都写完了,如果修改原来的方法就会“动一发而牵全身”,为了方便我就需要另外写一个过滤方法,把原来那个方法取出来的 List 容器再进行一次过滤操作,这样就不需要所有的地方都改了,只要再添加一个方法调用即可。似乎感觉到【扩展编程】的好处。 可是当我写完发现我的方法只能过滤掉一部分重复的数据,而有一部分(连续存在多个重复的数据,个数大于3)没有过滤掉。因为过滤掉一个之后 List 容器的大小就要改变,而你的索引却在增加(++),这样无形之中你就漏掉了一个重复数据。于是乎写了个测试代码,经过修改成功了。 过滤代码: public class TesFilterList { 运行结果: 123 nihao 456 789 注意: 这里最容易犯错误就是第二个for循环中索引变量J的减小(--),如果不减小就跳过了一个变量没有进行比较。这样当有多个重复数据连续出现的时候就会过滤不完全。 |
过滤 List 容器中重复(相同)的数据元素
最新推荐文章于 2024-05-20 16:58:06 发布