• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 314
  • Last Modified:

making a new List

I  have two  lists:
List<Student> studentList1
List<Student> studentList2


student class looks like below...

class Student{
 private int ID
 ......
 ........

}


Now ...I want to build a a new  list  


Logic:  replace  students from studentList1 with the students from studentList2  whoose studentId matches.

What is the quicker approach ?  I may have to do such operations  for  5/6  lists.
0
cofactor
Asked:
cofactor
  • 4
  • 2
1 Solution
 
CEHJCommented:
replace  students from studentList1 with the students from studentList2  whoose studentId matches.
Why are they not identical in all respects - how do they differ?
0
 
cofactorAuthor Commented:
they differ by some fields values -  they are just populated. I want to keep them.
0
 
CEHJCommented:
replace  students from studentList1 with the students from studentList2  whoose studentId matches.
Why are they not identical in all respects - how do they differ?

Assuming the Student class is uniquely identified by its ID (it should be) then it follows the ID can be used by Student.hashCode and Student.equals. For a List<Student> 'sl' then the following might be used:

	Set<Student> s = new HashSet<Student>(sl1);
	s.addAll(sl2); 

Open in new window

If there are instances in the second List you don't want to end up in the first, then an iterative approach might be better
0
Free Tool: IP Lookup

Get more info about an IP address or domain name, such as organization, abuse contacts and geolocation.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

 
cofactorAuthor Commented:
>>Set<Student> s = new HashSet<Student>(sl1);
>>s.addAll(sl2);

what is sl1   and sl2 in your code ? is this the complete code ?  

I am bit confused.
0
 
CEHJCommented:
what is sl1   and sl2 in your code
The first and second List<Student>
0
 
c_kedarCommented:
If the order in the list is not important then use set as suggested by CEHJ.
Remember to implement equals and hashcode in Student for this to work.
Eclipse can do this for you: Source > Generate hashCode() and equals()
	@Override
	public int hashCode() {
		final int prime = 31;
		int result = 1;
		result = prime * result + id;
		return result;
	}
	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		LogTest other = (LogTest) obj;
		if (id != other.id)
			return false;
		return true;
	}

Open in new window


Also note that size of combined set can be greater than first list, i.e. combined set will have Students that were not present in first list but present in second list.
If this is not what you want, then
s.retainAll(sl1);

Open in new window

0
 
CEHJCommented:
:)

If you need a hashCode method for Student, you can just use its ID (which should be unique)
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Free Tool: Subnet Calculator

The subnet calculator helps you design networks by taking an IP address and network mask and returning information such as network, broadcast address, and host range.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

  • 4
  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now