Java добавить элемент массив строк

Как добавить строку в массив java

Нужно указать номер ячейки массива и записать в нее строку. Важно чтобы массив был предназначен для хранения соответствующего типа данных.

Посмотрим на это в коде (рекомендую, для наглядности, сразу вводить построчно код в jshell ):

// объявим массив размером 10, который умеет хранить строки String[] arrayWithStrings = new String[10]; // запишем в самую начальную ячейку некую строку arrayWithStrings[0] = "Some very important string."; 

Последнюю строку можно расшифровать так: в ячейку №0 массива arrayWithStrings присвоить (записать) результат вычисления выражения справа от = . Поскольку справа от = у нас уже готовый объект класса String , то в ячейку записывается не сам объект, а ссылка на него. Сам объект находиться в памяти JVM.

Если в jshell ввести имя ссылки на массив arrayWithStrings и нажать Enter, то мы увидим следующее: arrayWithStrings ==> String[10] < "Some very important string.", null, null, null, null, null, null, null, null, null >.

По аналогии можно заполнить все оставшиеся 9 ячеек массива.

И помните: размер массива считается от 1 до n, а нумерация ячеек считается от 0 до n-1!

Источник

Класс ArrayList . Методы изменяющие данные в массиве

Пример. В примере формируется массив квадратов чисел от 1 до 10. Для добавления числа в конец массива используется метод add() .

import java.util.*; public class TrainCollections <  public static void main(String[] args) < // Метод addAll() - добавить элемент в конец массива // 1. Создать массив из чисел типа Integer ArrayList AI = new ArrayList(); // 2. Добавить в массив квадраты чисел от 1 до 10  for (int i=1; i // 3. Вывести массив System.out.println(AI); // 4. Добавить число 555 на начало массива в позицию 0 AI.add(0, 555); System.out.println(AI); > >

Результат выполнения программы

[1, 4, 9, 16, 25, 36, 49, 64, 81, 100] [555, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
2. Метод addAll() . Добавить коллекцию к массиву

Метод addAll() предназначен для добавления уже существующей коллекции в массив. Коллекцией могут быть коллекция, очередь, другой массив и т.д. Метод имеет две перегруженные реализации

addAll(Collectionextends E>) addAll(int index, Collectionextends E>)
  • E – тип элементов массива (коллекции);
  • index – позиция, с которой происходит вставка.

Пример. Демонстрируется использование метода addAll() для массива целых чисел.

import java.util.*; public class TrainCollections <  public static void main(String[] args) < // Метод addAll() - добавить коллекцию к массиву // 1. Создать массив из 5 чисел типа Float ArrayList AI = new ArrayList(); AI.add(1.0f); AI.add(2.0f); AI.add(3.0f); AI.add(4.0f); AI.add(5.0f); System.out.println("AI color: #008000;"> // 2. Создать другой массив из 3 чисел типа Float ArrayList AI2 = new ArrayList(); for (int i=1; iout.println("AI2 color: #008000;"> // 3. Добавить массив AI2 в конец массива AI AI.addAll(AI2); System.out.println("AI + AI2 color: #008000;"> // 4. Записать массив AI2 в массив AI начиная с позиции 2 AI.addAll(2, AI2); System.out.println("AI[2] + AI2 color: #333300;">⇑ 
3. Метод clear(). Очистить массив

Метод clear() предназначен для очищения массива. Согласно документации общая форма объявления метода следующая

public void clear();

Пример. В примере создается коллекция из символов-разделителей.

import java.util.*; public class TrainCollections <  public static void main(String[] args) < // Метод clear() - очистить коллекцию // 1. Создать коллекцию из разделительных символов в предложении ArrayList AL = new ArrayList(); AL.add(';'); AL.add(':'); AL.add(','); AL.add('.'); AL.add('!'); AL.add('?'); AL.add(' '); // 2. Вывести коллекцию System.out.println("AL => " + AL); // 3. Очистить коллекцию AL.clear(); // 4. Вывести коллекцию после очистки System.out.println("AL.clear() => " + AL); > >

Результат выполнения программы

4. Метод remove() . Удалить элемент в указанной позиции

С помощью метода remove() можно удалить элемент в заданной позиции. Согласно документации, объявление метода следующее

public E remove(int index);
  • E – тип элементов массива (коллекции);
  • index – номер позиции, которую нужно удалить. Позиция нумеруется с 0.

Метод возвращает значение удаляемого элемента из массива (коллекции).

Если значение index указано за пределами допустимого диапазона

то будет сгенерировано исключение IndexOutOfBoundsException .

import java.util.*; public class TrainCollections <  public static void main(String[] args) < // Метод remove() - удалить отдельный элемент из массива // 1. Создать коллекцию вещественных чисел ArrayList AL = new ArrayList(); AL.add(2.8f); AL.add(3.5f); AL.add(7.2f); AL.add(9.4f); AL.add(5.2f); // 2. Вывести коллекцию System.out.print("AL => "); for (int i=0; iout.print(AL.get(i) + " "); System.out.println(); // 3. Удалить элемент в позиции 2, который имеет значение 7.2 AL.remove(2); // 4. Вывести измененную коллекцию System.out.print("AL => ");  for (int i=0; iout.print(AL.get(i) + " "); > >

Результат выполнения программы

AL => 2.8 3.5 7.2 9.4 5.2 AL => 2.8 3.5 9.4 5.2
5. Метод removeAll() . Удалить группу элементов из коллекции

С помощью метода removeAll() можно удалить несколько элементов, представленных в виде коллекции. Согласно документации объявление метода следующее:

public boolean removeAll(Collection c);

Метод возвращает true , если текущий массив изменился в результате вызова.

В примере формируются две целочисленные коллекции:

  • AL – исходная коллекция чисел;
  • AL2 – коллекция чисел, которые необходимо удалить из коллекции AL .

С помощью метода removeAll() происходит удаление из коллекции AL всех частей, входящих в коллекцию AL2 .

import java.util.*; public class TrainCollections <  public static void main(String[] args) < // Метод removeAll() - удалить группу элементов из массива // 1. Создать коллекцию целых чисел ArrayList AL = new ArrayList(); AL.add(2); AL.add(3); AL.add(2); AL.add(4); AL.add(7); AL.add(3); AL.add(4); AL.add(5); AL.add(6); AL.add(1); // 2. Вывести исходную коллекцию System.out.print("AL => "); for (int i=0; iout.print(AL.get(i) + " "); System.out.println(); // 3. Создать коллекцию чисел, которые нужно удалить ArrayList AL2 = new ArrayList(); // удалить все числа 2, 4, 7 AL2.add(2); AL2.add(4); AL2.add(7); // 4. Вызвать метод removeAll() AL.removeAll(AL2); // 4. Вывести измененную коллекцию System.out.print("AL => "); for (int i=0; iout.print(AL.get(i) + " "); > >

Результат выполнения программы

AL => 2 3 2 4 7 3 4 5 6 1 AL => 3 3 5 6 1
6. Метод removeIf() . Изменить коллекцию на основе предиката

С помощью метода removeIf() можно удалить элементы из коллекции согласно условию. В результате формируется новая коллекция (массив). Общая форма объявления метода следующая

public boolean removeIf(Predicatesuper E> filter);

Метод возвращает true , если хотя бы один элемент был удалён.

В примере демонстрируется выполнение метода removeIf() . Демонстрируются следующие операции:

  • создается коллекция целых чисел;
  • формируется предикат, в котором определяются числа, которые больше 4;
  • вызывается метод removeIf() , с помощью которого формируется новый массив чисел согласно предикату.
import java.util.*; import java.util.function.*; public class TrainCollections <  public static void main(String[] args) < // Метод removeIf() - изменить массив по заданному условию // 1. Создать коллекцию целых чисел ArrayList AL = new ArrayList(); AL.add(2); AL.add(3); AL.add(2); AL.add(4); AL.add(7); AL.add(3); AL.add(4); AL.add(5); AL.add(6); AL.add(1); // 2. Вывести исходную коллекцию System.out.print("AL => "); for (int i=0; iout.print(AL.get(i) + " "); System.out.println(); // 3. Объявить ссылку на интерфейс Predicate Predicate ref; // 4. Сформировать условие для ссылки ref на основе лямбда-выражения: // взять все числа, которые больше 4 ref = (value) -> value > 4; // 5. Вызвать метод removeIf() и передать ему ссылку ref условием AL.removeIf(ref); // удалить все числа, которые больше 4 // 6. Вывести измененный массив AL System.out.print("AL => "); for (int i=0; iout.print(AL.get(i) + " "); System.out.println(); > >

Результат выполнения программы

AL => 2 3 2 4 7 3 4 5 6 1 AL => 2 3 2 4 3 4 1
7. Метод replaceAll() . Произвести вычисления над каждым элементом массива

С помощью метода replaceAll() можно применить некоторую операцию к каждому элементу массива. Такой операцией может быть, например произведение каждого элемента на 2. Согласно документации, общая форма объявления метода следующая:

public void replaceAll(UnaryOperator operator);
  • operator – лямбда-выражение, определяющее операцию над каждым элементом последовательности. Лямбда-выражение формируется с помощью функционального интерфейса UnaryOperator .

Пример. В примере создается массив целых чисел. Затем каждый элемент массива умножается на 3 с помощью метода replaceAll() . Для выполнения вычисления формируется ссылка на подходящее лямбда-выражение.

import java.util.*; import java.util.function.*; public class TrainCollections <  public static void main(String[] args) < // Метод replaceAll() - изменить значение элементов исходного массива // 1. Создать коллекцию целых чисел ArrayList AL = new ArrayList(); AL.add(2); AL.add(3); AL.add(2); AL.add(4); AL.add(7); AL.add(3); // 2. Вывести коллекцию с помощью итератора Iterator it = AL.iterator(); System.out.print("AL => "); while (it.hasNext()) System.out.print(it.next()+" "); System.out.println(); // 3. Сформировать лямбда-выражение, которое умножает элемент на 3 UnaryOperator op = (num) -> num*3; // 4. Вызвать метод replaceAll() и применить к нему оператор op AL.replaceAll(op); // 5. Вывести измененную коллекцию (массив) целых чисел it = AL.iterator(); System.out.print("AL => "); while (it.hasNext()) < System.out.print(it.next() + " "); > > >

Результат выполнения программы

AL => 2 3 2 4 7 3 AL => 6 9 6 12 21 9
8. Метод set() . Установить новое значение в элементе

Метод set() устанавливает новое значение в заданной позиции массива. Другими словами, старое значение массива в заданной позиции заменяется новым. Объявление метода имеет вид

public E set(int index, E element);
  • index – позиция вставки (нумеруется с 0);
  • element – новое значение, которое необходимо установить в позиции index .

Метод возвращает предыдущее значение, установленное в заданной позиции.

Если значение index выходит за пределы допустимого диапазона, т.е.

то будет сгенерировано исключение IndexOutOfBoundsException .

import java.util.*; import java.util.function.*; public class TrainCollections <  public static void main(String[] args) < // Метод set() - установить значение в отдельном элементе массива // 1. Создать коллекцию строк ArrayList AL = new ArrayList(); AL.add("a"); AL.add("b"); AL.add("c"); // 2. Вывести исходный массив с помощью итератора Iterator it = AL.iterator(); System.out.print("AL => "); while (it.hasNext()) System.out.print(it.next()+" "); System.out.println(); // 3. Установить новое значение в элементе с индексом 1 String oldValue; oldValue = AL.set(1, "bbb"); // 4. Вывести предыдущую строку System.out.println("oldValue color: #008000;"> // 5. Вывести измененный массив System.out.print("AL => "); for (int i=0; iout.print(AL.get(i) + " "); System.out.println(); > >

Результат выполнения программы

AL => a b c oldValue = b AL => a bbb c
9. Метод sort() . Отсортировать элементы массива

С помощью метода sort() можно сортировать элементы массива. Общая форма объявления метода следующая

public void sort(Comparatorsuper E> c);
  • c – компаратор (условие), реализующий принцип сравнения каких-либо двух элементов массива. Компаратор используется в случае разработки собственного класса, объекты которого могут быть отсортированы по некоторому критерию. В этом случае класс должен реализовать интерфейс Comparator . В этом интерфейсе определен метод compare() , сравнивающий два элемента. Конкретно этот способ нужно переопределить и воплотить в этом классе и задать свой механизм сравнения.

Для стандартных типов-оболочек ( Integer , Double , String и т.д.) реализован внутренний компаратор, сортирующий элементы в естественном порядке (от меньшего к большему или по алфавиту).

Для использования стандартного способа сортировки следует вызвать метод sort() с аргументом null

AL.sort(null);

здесь AL – массив сортируемых элементов.

import java.util.*; import java.util.function.*; public class TrainCollections <  public static void main(String[] args) < // Метод sort() - сортировка в естественном порядке // 1. Создать массив строк ArrayList AL = new ArrayList(); AL.add("jklm"); AL.add("abcd"); AL.add("elsd"); AL.add("lkls"); AL.add("azsd"); // 2. Вывести исходный массив Iterator it = AL.iterator(); System.out.print("AL => "); while (it.hasNext()) System.out.print(it.next()+" "); System.out.println(); // 3. Отсортировать элементы массива, метод sort() AL.sort(null); // 4. Вывести отсортированный массив System.out.print("AL => "); for (int i=0; iout.print(AL.get(i) + " "); System.out.println(); > >

Результат выполнения программы

AL => jklm abcd elsd lkls azsd AL => abcd azsd elsd jklm lkls

Связанные темы

Источник

Читайте также:  Jquery получить свойство css элемента
Оцените статью