Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Понятие о функциях printf.docx
Скачиваний:
0
Добавлен:
27.12.2019
Размер:
26.91 Кб
Скачать

Понятие о функциях printf, scanf.

Функция printf() является функцией стандартного вывода. С помощью этой функции можно вывести на экран монитора строку символов, число, значение переменной... Функция printf() имеет прототип в файле stdio.h int printf(char *управляющая строка, ...); В случае успеха функция printf() возвращает число выведенных символов. Управляющая строка содержит два типа информации: символы, которые непосредственно выводятся на экран, и спецификаторы формата, определяющие, как выводить аргументы. Функция printf() это функция форматированного вывода. Это означает, что в параметрах функции необходимо указать формат данных, которые будут выводиться. Формат данных указывается спецификаторами формата. Спецификатор формата начинается с символа % за которым следует код формата. Функция scanf() - функция форматированного ввода. С её помощью вы можете вводить данные со стандартного устройства ввода (клавиатуры). Вводимыми данными могут быть целые числа, числа с плавающей запятой, символы, строки и указатели. Функция scanf() имеет следующий прототип в файле stdio.h: int scanf(char *управляющая строка); Функция возвращает число переменных которым было присвоено значение. Управляющая строка содержит три вида символов: спецификаторы формата, пробелы и другие символы. Спецификаторы формата начинаются с символа %. 

Обработка файлов в программах на СИ.

Файлом называют способ хранения информации на физическом устройстве. Файл - это понятие, которое применимо ко всему - от файла на диске до терминала. В языке Си отсутствуют операторы для работы с файлами. Все необходимые действия выполняются с помощью функций, включенных в стандартную библиотеку. Они позволяют работать с различными устройствами, такими, как диски, принтер, коммуникационные каналы и т.д. Эти устройства сильно отличаются друг от друга. Однако файловая система преобразует их в единое абстрактное логическое устройство, называемое потоком. В Си существует два типа потоков: текстовые (text) и двоичные (binary). Текстовый поток - это последовательность символов. При передаче символов из потока на экран, часть из них не выводится (например, символ возврата каретки, перевода строки). Двоичный поток - это последовательность байтов, которые однозначно соответствуют тому, что находится на внешнем устройстве. Прежде чем читать или записывать информацию в файл, он должен быть открыт и тем самым связан с потоком. Это можно сделать с помощью библиотечной функции fopen( ). Она берет внешнее представление файла (например, c:\my_prog.txt) и связывает его с внутренним логическим именем, которое используется далее в программе. Логическое имя - это указатель на требуемый файл. Его необходимо определить; делается это, например, так: FILE *fp; Здесь FILE - имя типа, описанное в стандартном заголовочном файле stdio.h, fp - указатель на файл. Обращение к функции fopen( ) в программе осуществляется выражением: fp = fopen(спецификация файла, "способ использования файла"); Спецификация файла (т.е. имя файла и путь к нему) может, например, иметь вид: "c:\\my_prog.txt" - для файла my_prog.txt на диске с:. Способ использования файла задается следующими символами: r - открыть существующий файл для чтения; w - создать новый файл для записи (если файл с указанным именем существует, то он будет переписан); 

6. Операторы

За исключением особо оговариваемых случаев, операторы

выполняются последовательно.

6.1. Операторное выражение

большинство операторов являются операторными выражени-

ями, которые имеют форму

выражение;

Обычно операторные выражения являются присваиваниями или

обращениями к функциям.

6.2. Составной оператор (или блок)

С тем, чтобы допустить возможность использования нес-

кольких операторов там, где ожидается присутствие только

одного, предусматривается составной оператор (который также

называют "блоком"):

составной оператор:

{список_описаний список_операторов}

необ необ

список_описаний:

описание

описание список_описаний

список_операторов:

оператор

оператор список_операторов

Если какой-либо идентификатор из списка_описаний был описан

-34-

ранее, то во время выполнения блока внешнее описание подав-

ляется и снова вступает в силу после выхода из блока.

Любая инициализация автоматических и регистровых пере-

менных проводится при каждом входе в блок через его начало.

В компиляторе ОС ДЕМОС разрешается (но это плохая практика)

передавать управление внутрь блока; в таком случае эти ини-

циализации не выполняются. Инициализации статических пере-

менных проводятся только один раз, когда начинается выполне-

ние программы.

Находящиеся внутри блока внешние описания не резерви-

руют памяти, так что их инициализация не разрешается.

6.3. Условные операторы

Имеются две формы условных операторов:

if (выражение) оператор

if (выражение) оператор else оператор

В обоих случаях вычисляется выражение и, если оно отлично от

нуля, то выполняется первый подоператор. Во втором случае,

если выражение равно нулю, выполняется второй подоператор.

Как обычно, двусмысленность else разрешается связыванием

else с последним встречающимся if, у которого нет else.

6.4. Оператор while

Оператор while имеет форму

while (выражение) оператор

Подоператор выполняется повторно до тех пор, пока значение

выражения остается отличным от нуля. Проверка производится

перед каждым выполнением оператора.

6.5. Оператор do

Оператор do имеет форму

do оператор while (выражение)

Оператор выполняется повторно до тех пор, пока значение

выражения не станет равным нулю. Проверка производится после

каждого выполнения оператора.

6.6. Оператор for

Оператор for имеет форму

(выражение1;выражение2;выражение3)оператор

необ необ необ

-35-

Оператор for эквивалентен следующему:

выражение1;

while (выражение2) {

оператор

выражение3;

}

Таким образом, первое выражение определяет инициализацию

цикла; второе специфицирует проверку, выполняемую перед каж-

дой итерацией, так что выход из цикла происходит тогда,

когда значение выражения становится нулем; третье выражение

часто задает приращение параметра, который вычисляется после

каждой итерации.

Любое выражение или все они могут быть опущены. Если

отсутствует второе выражение, то предложение с while счита-

ется эквивалентным while(1); другие отсутствующие выражения

просто опускаются из приведенного выше расширения.