Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Гостевая книга ... 65535
Содержание сайт... 65535
Вызов хранимых ... 65535
Эмулятор микроп... 65535
Бип из системно... 61046
Организация зап... 58707
Invision Power ... 58705
Приложение «Про... 57161
Модуль Forms 57126
Оператор выбора... 56629
Создание отчето... 56091
Подключение Mic... 56071
ТЕХНОЛОГИИ ДОСТ... 52308
Программируемая... 49801
Пример работы с... 48146
Имитационное мо... 47849
21 ошибка прогр... 42791
Реклама
Офсетные ролики - увлажняющий аппарат офсетной http://www.nbkgroup.ru.
Сейчас на сайте
Гостей: 12
На сайте нет зарегистрированных пользователей

Пользователей: 13,022
новичок: igra87
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Меры близости на векторах в Delphi + Блок схемы
Лабораторная работа по динамическим спискам на Turbo Pascal (перемещение...
База данных студентов на Delphi (файл записей) + Блок схемы

Реклама

Использование цикла for в стиле for-each для обработки коллекций
Несмотря на то, что в предыдущих примерах использовались массивы, цикл for в стиле for-each не ограничивается этой областью применения. Его можно применять для обработки в цикле элементов объекта любого типа, реализующего интерфейс Iterable. К таким типам относятся все коллекции, определенные в подсистеме Collections Framework, модернизация которой для Java 2 v5.0 включает и реализацию интерфейса Iterable. В прошлом обработка коллекции в цикле требовала от Вас применения итератора и явного вызова его методов hasNext() и next(). Улучшенный цикл for теперь автоматизирует этот процесс.
В программе, приведенной в листинге 4.6, демонстрируется использование
улучшенного цикла for для обработки в цикле коллекции типа ArrayList, содержащей числовые значения. Программа вычисляет среднее арифметическое значений списка.
Листинг 4.6. Применение улучшенного цикла for для коллекций
class AvgCollection {
static double getAvg(ArrayList nums) {
double sum = 0.0;

for(double itr : nums)
sum = sum + itr;

return sum / nums.size();
}

public static void main(String args[]) {
ArrayList list = new ArrayList();

list.add(10.14);
list.add(20.22);
list.add(30.78);
list.add(40.46);

double avg = getAvg(list);

System.out.println("List average is " + avg);

}
}



Программа из листинга 4.6 выводит на экран следующую строку:
List average is 25.4
В методе getAvg() следующий цикл for в стиле for-each:
for(double itr : nums)
sum = sum + itr;



заменяет приведенный далее фрагмент кода, в котором применяется явная итерация:
Iterator itr = nums.iterator();
while(itr.hasNext()) {
Double d = itr.next();
sum = sum + d;
}



Как видите, улучшенный цикл for существенно короче и более уместен.
Еще одно замечание: если Вы хотите использовать улучшенный цикл for для обработки в цикле содержимого коллекции с заданным несформированным (raw) типом, переменная цикла должна иметь тип Object. Это означает, что переменную цикла следует явно преобразовать в заданный тип. Откровенно говоря, лучше всего избегать применения несформированных типов, как в цикле for, так и в других ситуациях. Настраиваемые типы предлагают лучшую, более безопасную и удобную альтернативу.
Опубликовал Kest January 13 2009 11:55:19 · 0 Комментариев · 7538 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
Tenis [Исходник н...
Быстрое создание ...
Dnavigator
TelBook
Email
PHP 5
Советы по Delphi
Учебник по создан...
Усложнённый кальк...
MxProtector
Последнее загруж...
Развивающийся фла...
Delphix Sample [И...
WAP версия сайта
CaptionButton
Abbrevia
Платформа програм...
Delphi 6 программ...
Редактор анимаций
Карта сайта

Топ загрузок
Приложение Клие... 100308
Delphi 7 Enterp... 78116
Converter AMR<-... 20021
Borland C++Buil... 10700
GPSS World Stud... 9304
Borland Delphi ... 7677
Turbo Pascal fo... 6885
Visual Studio 2... 4906
Калькулятор [Ис... 4007
FreeSMS v1.3.1 3486
Случайные статьи
Треугольные массивы
Персептроны
Генерация k-элемен...
получателям
contoso
UNIX предъявляет р...
Для изменения фона...
Создание вертикаль...
Метаданные
Закругленные уголк...
О стандартах прогр...
Введение в дисциплину
Бинарный поиск в у...
Дополнительная лит...
Случаи применения ...
index — индекс стр...
Терминология объек...
Инфографическое ре...
Функции обработки ...
Процедуры обработк...
CN=Configuration, ...
Система 4.4BSD - л...
Тестирование файлов
Согласовать между ...
Моделирование случ...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?