import java.util.LinkedHashMap;
import java.util.Map;
/*
Deep clone example
*/
public class Solution implements Cloneable {
public static void main(String[] args) {
Solution solution = new Solution();
solution.users.put("Hubert", new User(172, "Hubert"));
solution.users.put("Zapp", new User(41, "Zapp"));
try {
Solution clone = (Solution) solution.clone();
System.out.println(solution);
System.out.println(clone);
System.out.println(solution.users);
System.out.println(clone.users);
} catch (CloneNotSupportedException e) {
e.printStackTrace(System.err);
}
}
@Override
public Object clone() throws CloneNotSupportedException {
Solution o = (Solution) super.clone();
//clone users
Map<String, User> newUsers = new LinkedHashMap<>();
for (String key : o.users.keySet()) {
User user = o.users.get(key);
newUsers.put(key, (User) user.clone());
}
o.users = newUsers;
return o;
}
protected Map<String, User> users = new LinkedHashMap<>();
public static class User implements Cloneable {
int age;
String name;
public User(int age, String name) {
this.age = age;
this.name = name;
}
@Override
protected Object clone() throws CloneNotSupportedException {
return super.clone();
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
User user = (User) o;
if (age != user.age) {
return false;
}
return name != null ? name.equals(user.name) : user.name == null;
}
@Override
public int hashCode() {
int result = age;
result = 31 * result + (name != null ? name.hashCode() : 0);
return result;
}
}
}
-
MY PROJECTS
-
Recent Posts
- Database.What problems can arise with concurrent access using transactions?
- Database.What are the levels of transaction isolation?
- Database.What are the main properties of a transaction?
- Database.What is a “transaction”?
- Database.What is Low Selectivity problem, when we speaking about indexes ?
- Datasource.When is a full scan of a data set more advantageous than index access?
- Database.Does it make sense to index data that has a small number of possible values?
- Database.How do i define my clustered index ?
- Database.What is clustered index ?
- Datasource.What is the difference between clustered and non-clustered indexes?
- Database.How EXPLAIN shows B-tree vs. hash usage in query plans ?
- Database.I was sure that Composite Index (Multi-column) is b-tree
- Database.What types of indexes exist?
- Database.What are “indexes”? What are they used for? What are their advantages and disadvantages?
- Database.If i define primary key as student_id, course_id, why i use only WHERE student_id = 1, for example, and how index of primary key works here ?
- Database.Give example of use of composite primary key
- Database.Is primary key always indexed ?
- Database.What are the types of relationships in a database? Give examples.
- Database.What is “denormalization”? What is it used for?
- Database.3NF, give example
Categories
- Aptana
- Azure
- C#
- DataSnap
- DBExpress
- Delphi
- Delphi и сети
- Delphi. Язык программирования
- ExtJS
- FastReport
- FireDAC
- FireMonkey
- GIT
- ICS
- IDE
- IIS
- Indy
- InnoSetup
- javascript
- jQuery
- JSON
- LiveBindings
- MSHTML
- MySQL
- PHP
- REST
- Ribbons
- SMS
- SQL инструкции
- SVN
- TRichView
- UniGui
- WebBroker
- WinAPI
- Windows
- Алгоритмы
- Без рубрики
- Деревья
- Ищу ответ
- Компонентостроение
- Мои компоненты
- Начальный уровень
- Обработка исключений
- Парсинг
- Потоки(Threads)
- Регулярные выражения
- Тестирование приложений