Другое событие NullPointerException
возникает, когда объявляется массив объектов, а затем сразу же пытается разыменовать его внутри.
String[] phrases = new String[10];
String keyPhrase = "Bird";
for(String phrase : phrases) {
System.out.println(phrase.equals(keyPhrase));
}
Этот конкретный NPE можно избежать, если порядок сравнения отменяется ; а именно, использовать .equals
для гарантированного непустого объекта.
Все элементы внутри массива инициализируются их общим начальным значением ; для любого типа массива объектов, это означает, что все элементы null
.
Вы должны инициализировать элементы в массиве перед доступом или разыменованием их.
String[] phrases = new String[] {"The bird", "A bird", "My bird", "Bird"};
String keyPhrase = "Bird";
for(String phrase : phrases) {
System.out.println(phrase.equals(keyPhrase));
}
Преимущества попыток:
основы:
Новые операции:
Преимущества связанной структуры:
Преимущества хеш-таблиц:
Все это зависит, на какой проблеме Вы пытаетесь решить. Если все, что необходимо сделать, является вставками и поисками, пойдите с хеш-таблицей. Если необходимо решить более сложные проблемы, такие как связанные с префиксом запросы, то trie мог бы быть лучшим решением.
Некоторые (обычно встраиваемый, в реальном времени) приложения требуют, чтобы время обработки было независимо от данных. В этом случае хеш-таблица может гарантировать известное время выполнения, в то время как trie варьируется на основе данных.