Навигация
Главная
Поиск
Форум
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
Пример работы с... 65535
ТЕХНОЛОГИИ ДОСТ... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
21 ошибка прогр... 65535
Гостевая книга ... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Содержание сайт... 65535
Invision Power ... 65535
Программируемая... 65535
Оператор выбора... 65535
Модуль Forms 65535
Реклама
Сейчас на сайте
Гостей: 5
На сайте нет зарегистрированных пользователей

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

Моделирование процесса поступления заявок в систему, состоящую из трёх Э...
Моделирование работы ЭВМ на GPSS + Пояснительная записка
База данных студентов на Turbo Pascal (Списки) + Пояснительная записка

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Состояния потока
аа[2] = 3; аа[3] = 4; аа[4] = 5; аа[5] = 0; аа[6] = 0; аа[7] = 0; аа[8] = 0; аа[9] = 0;



Символ «е», введенный после цифры 5, не является допустимым для целого числа и поэтому ограничивает ввод.
В условиях можно задавать и явный вызов методов. Например, пусть мы хотим посчитать количество символов ' \ п', которым оканчиваются вводимые строки. Это можно сделать, использовав метод get():
int nl = 0;
while(cin.get(ch)) // читать все символы, в том числе пробельные
{ if(ch=='\n') nl++; cout.put(ch);
}



Так как «неправильных» символов не существует, цикл можно завершить только вводом комбинации клавиш Ctrl+Z. Можно использовать и другую форму метода get():
int nl = 0;
while(ch = cin.get() && ch != EOF) // читать все символы
{ if(ch=='\n') nl++; cout.put(ch);
}



Константа EOF помещается в переменную ch при нажатии комбинации Ctrl+Z.
В библиотеке реализована логическая операция operator!, с помощью которой можно проверить аварийное состояние потока, например:
if (!(cin >> х))
{ // ввод завершился неудачей }



Обратите внимание: выражение ввода заключено в скобки. Это необходимо, так как в соответствии с приоритетом операций выражение без скобок интерпретируется так:
(!cin) >> х



Естественно, ввод и проверку состояния потока можно разделить, например:
cin >> х; if (!cin)
{ // ввод завершился неудачей }



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

while (!from.eof()) { getline(from, s);

// явная проверка признака конца файла // чтение строки из потока from

cout << s << endl;
}



Однако тут возможны сюрпризы. По умолчанию ограничителем строки является символ ' \ п', который записан в конце каждой строки. В данном случае при считывании последней строки состояния eof файла не возникает — она возникает только при попытке ввода за концом файла. Поэтому цикл выполнится лишний раз и на экране дважды появится последняя строка.
Правильная последовательность операторов может быть такой:
getline(from, s); // чтение строки из потока from
while (!from.eof()) // явная проверка признака конца файла
{ cout << s << endl;
getline(from, s); // чтение строки из потока from
}



Хотите новый дизайн для сайта - http://itcreators-group.com/web-design/ тут.

Другой вариант — бесконечный цикл с проверкой ситуации конца файла внутри цикла:
wtiile (true)
{ getline(from, s); // чтение строки из потока from
if(from.eof()) break; // явная проверка признака конца файла cout << s << endl;
}


Опубликовал Kest Март 12 2014 15:35:36 · 0 Комментариев · 2702 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
NotePad Pro [Исхо...
Панель поиска
SendSMS для PHP-F...
MxProtector
Программирование ...
Rss Parser
Измерение тактово...
Berg
RAS
Платформа програм...
BSButton
SysInfo [Исходник...
JBlabel3D
SynEdit
Tetris 2002
Print Grid
Игра змейка
DateEdit
Пятнашки и крести...
PDJ_Anima

Топ загрузок
Приложение Клие... 100721
Delphi 7 Enterp... 96510
Converter AMR<-... 20213
GPSS World Stud... 16901
Borland C++Buil... 14084
Borland Delphi ... 9932
Turbo Pascal fo... 7299
Калькулятор [Ис... 5787
Visual Studio 2... 5168
FreeSMS v1.3.1 3643
Случайные статьи
Хакинг приставок X...
Вулкан Неон на реа...
Когда маршрутизато...
Внешние ссылки, об...
Решение задачи, ис...
Свободныеадреса в ...
Удаление экземпляр...
• Negotiate Securi...
Тестирование на De...
Использование расп...
Синтаксис
Архивация данных в...
Мультиметод нового...
Операции с файлами...
Описание типа доку...
744Определение пол...
String constant ex...
Стратегия обмена с...
Практика
На какие на какие ...
Временные меры чис...
Grocery outlet cou...
7.8. Использован...
Класс Array_ref бл...
Сплит-тестирование...
Статистика



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


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