- •1) Базовые элементы языка с. Алфавит и словарь языка (в1б1, в3б3)
- •2) Основные типы данных. Классификация их типов. Модификация базовых типов. (в1б2, в3б17)
- •3) Константы (в1б3, в3б2)
- •4) Переменные (в1б4, в3б16)
- •5) Структура с-программы. Понятие локальных и глобальных переменных. Функция main(). Директивы препроцессора (# include и #define). Комментарии. (в1б5, в3б1)
- •6) Операции языка с. Арифметические, логические операции. Поразрядные операции. (в1б6, в3б15)
- •7. Операции языка с. Операция присваивания и отношения. Операция определения размера. Оператор последовательного вычисления. (в1б7, в2б30)
- •8. Операции языка с. Условная операция. Операция (), операция []. (в1б8, в3б14)
- •9) Приоритет операций и порядок вычислений (в1б9, в2б29)
- •10) Основные сведения о вводе-выводе. (в1б10, в3б13)
- •11) Ввод-вывод символов (в1б11, в2б28)
- •12) Форматированный ввод-вывод. Модификаторы формата. Спецификаторы преобразования. Подавление ввода. (в3б12, в1б12)
- •13) Операторы языка с. Условные операторы (if, switch). (в1б13, в2б27)
- •14) Операторы цикла (while, for, do while )(в1б14, в3б11)
- •15) Операторы безусловного перехода ( break, continue, go to, return) (в1б15, в2б26)
- •16) Одномерные массивы. (в1б16, в3б10)
- •17) Строковый литерал. Чтение и запись строк. (в1б17, в2б25)
- •18)Двухмерные массивы. Массивы строк (в1б18, в3б9)
- •19) Инициализация массива. (в1б19, в2б24)
- •20) Способы доступа к элементом массива. (в1б20, в3б8)
- •22) Указательные переменные. Операции получения адреса (&) и раскрытие ссылка (*) (в1б22, в3б7)
- •23) Указательные выражения. Адресная арифметика. (в1б23, в2б22)
- •24) Связь массивов и указателей (в1б24,в3б6)
- •25) Функции динамического распределения памяти (в1б25, в2б21)
- •26) Динамическое выделение памяти для массивов. (в1б26, в3б5)
- •27) Функции. Определения функций. Оператор return.( в1б27, в3б20)
- •28) Функции. Прототипы функции. (в1б28, в3б4)
- •29) Функции. Вызов функций: вызов по значению и по ссылке. (в1б29, в2б19)
- •30) Передача массива в функцию. (в1б30, в3б27)
- •31) Классы памяти. Область видимости. (в2б1, в3б28)
- •32) Аргумент функции main(): argv и argc (в2б2, в3б26)
- •33) Рекурсия. (в2б3, в3б29)
- •34) Вызов библиотечных функций(в2б4, в3б25)
- •35) Директива препроцессора #define: создание макрофункций с помощью директивы #define (в2б5, в3б30)
- •36) Директивы условной компиляции #if, #else, #elif, #endif, #ifdef, #ifndef (в2б6, в3б24)
- •37) Понятие структуры. Доступ к членом структуры (в2б7)
- •38) Присваивание структур (в2б8, в3б23)
- •39) Массивы структуры(в2б9)
- •40) Передача членов структур функциям. Передача целых структур функциям. (в2б10, в3б22)
- •41) Указатели на структуры. Средство typedef (в2б11)
- •42) Понятие объединение и перечисления. Битовые поля. (в2б12,в3б21)
- •44) Методы поиска: последовательный и двоичный поиск. (в2б14, в3б20)
- •45) Основы файловой системы. Стандартные потоки. Указатель файла. Открытые файлы. Закрытые файлы. (в2б15)
- •46) Форматированный ввод-вывод в файл (в2б16, в2б17, в3б19)
- •48) Понятие очереди, стеков, связанных списков и деревьев. (в2б12, в3б18)
3) Константы (в1б3, в3б2)
Константы (литералы) – фиксированные величины, которые не могут быть изменены в программе.
Константами бывают: самоопределенные, арифметические, символьные и строковые данные, ID массивов и функций и эл-ты перечислений.
Арифметические константы м/б целого и вещественного типа. Целочисленные константы подраздел. на десятичные, 8-ричные и 16-ричные.
Десятичная константа состоит из одной или нескольких десятичных цифр, причем первая цифра не
должна быть нулем (в противном случае число будет воспринято как восьмеричное). От 0 до 9.
Восьмеричная константа состоит из последов-ти цифр от 0 до 7, первой из кот не д/б 0.
16-ричная константа начинается с обязательной последовательности 0х или 0Х и содержит одну или несколько шестнадцатеричных цифр (цифры представляющие собой набор цифр шеснадцатеричной
системы счисления: 0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F).
Каждой целой константе присваивается тип, определяющий преобразования, которые должны быть
выполнены, если константа используется в выражениях. Тип константы определяется следующим образом:
- десятичные константы рассматриваются как величины со знаком, и им присваивается тип int (целая) или long (длинная целая) в соответствии со значением константы. Если константа меньше 32768, то ей присваивается тип int в противном случае long.
- восьмеричным и шестнадцатеричным константам присваивается тип int, unsigned int (беззнаковая
целая), long или unsigned long в зависимости от значения константы.
Для того чтобы любую целую константу определить типом long, достаточно в конце константы поставить
букву "l" или "L". Пример: 5l, 6l, 128L, 0105L, OX2A11L.
Константы вещественного типа могут размещ-ся в памяти по формату double, а во внешнем представлении могут использовать 2 формы: - с фиксированной 10-ичной точкой, - с плавающей 10-ичной точкой.
Символьная константа - представляется символом, заключенном в апострофы. Также исп-ся спец послед-ти символов, т.е. управляющие послед-ти, основные из кот:
’\n’ - символ новой строки
’\t’ – горизонтальная табуляция
‘\0’ – нулевой символ, т.е. пусто.
Символьные константы имеют тип int и при преобразовании типов дополняются знаком.
Строковая константа (литерал) - последовательность символов (включая строковые и прописные буквы
русского и латинского, а также цифры), заключенные в кавычки (") . Например: "Школа N 35", "город
Тамбов", "YZPT КОД".
Отметим, что все управляющие символы, кавычка ("), обратная дробная черта (\) и символ новой строки в строковом литерале и в символьной константе представляются соответствующими управляющими
последовательностями. Каждая управляющая последовательность представляется как один символ.
Например, при печати литерала "Школа \n N 35" его часть "Школа" будет напечатана на одной строке,
а вторая часть "N 35" на следующей строке.
Символы строкового литерала сохраняются в области оперативной памяти. В конец каждого строкового
литерала компилятором добавляется нулевой символ, представляемый управляющей последовательностью
\0.
Строковый литерал имеет тип char[] . Это означает, что строка рассматривается как массив символов.
Отметим важную особенность, число элементов массива равно числу символов в строке плюс 1, так как
нулевой символ (символ конца строки) также является элементом массива. Все строковые литералы
рассматриваются компилятором как различные объекты. Строковые литералы могут располагаться на
нескольких строках. Такие литералы формируются на основе использования обратной дробной черты и
клавиши ввод. Обратная черта с символом новой строки игнорируется компилятором, что приводит к
тому, что следующая строка является продолжением предыдущей. Например:
"строка неопределенной \n
длины"
полностью идентична литералу
"строка неопределенной длинны"
Для сцепления строковых литералов можно использовать символ (или символы) пробела. Если в
программе встречаются два или более строковых литерала, разделенные только пробелами, то они
будут рассматриваться как одна символьная строка. Этот принцип можно использовать для формирования строковых литералов занимающих более одной строки.