ОБЗОР ЯЗЫКа ПРОГРАММИРОВАНИЯ С

ОСНОВЫ АЛГОРИТМИЗАЦИИ И ПРОГРАММИРОВАНИЯ.

ЯЗЫК С/С++. СТРУКТУРНЫЙ ПОДХОД

 

Краткий курс лекций

 

 

Тирасполь 2000

 

СОДЕРЖАНИЕ

 

1. ОБЗОР ЯЗЫКа ПРОГРАММИРОВАНИЯ С. 5

2. ЭТАПЫ СОЗДАНИЯ ПРОГРАММЫ.. 5

3. СТРУКТУРА ПРОГРАММЫ НА ЯЗЫКЕ СИ. 6

3.1. Внутренняя структура программы. 6

3.2. Пример программы на СИ. 6

4. БАЗОВЫЕ ЭЛЕМЕНТЫ ЯЗЫКА СИ. 7

5. ДАННЫЕ В ПРОГРАММЕ НА СИ. 8

5.1. Константы. 8

5.2. Базовые стандартные типы переменных. 9

6. ОПЕРАЦИИ ЯЗЫКА СИ. 11

6.1. Арифметические операции. 11

6.2. Операции отношения. 12

6.3. Логические операции. 12

6.4. Операции с разрядами. 13

6.5. Операции сдвига. 13

6.6. Операция условия ?: 14

6.7. Преобразование типов. 14

6.8. Операции приведения. 14

6.9. Дополнительные операции присваивания. 15

7. ОПЕРАТОРЫ ЯЗЫКА СИ. 15

8. СТАНДАРТНЫЕ ФУНКЦИИ ВВОДА И ВЫВОДА. 22

8.1. Функция вывода данных на экран printf () 22

8.2. Модификаторы спецификаций преобразования. 23

8.3. Функция ввода данных с клавиатуры sсanf() 23

8.4. Функции ввода/вывода одного символа getchar(), putchar() 24

8.5. Функции небуфиризированного ввода с клавиатуры. 24

8.6. Ввод/вывод в поток в С++. 24

8.7. Форматирование вывода. 25

9. МАССИВЫ.. 26

9.1. Одномерные массивы. 26

9.2 Многомерные массивы. 28

10 ФУНКЦИИ. 30

10.1 Cоздание и использование пользовательских функций. 31

10.2 Параметры функции. 32

10.3 Возвращение значения функцией. 33

10.4 Inline-функции. 33

10.5 Значение формальных параметров функции по умолчанию.. 33

10.6 Перегрузка функций. 34

11 КЛАССЫ ПАМЯТИ И ОБЛАСТЬ ДЕЙСТВИЯ. 35

11.1 Глобальные переменные. 35

11.2 Локальные переменные. 36

11.3 Доступ к функциям в многомодульной программе. 37

12 ПРЕПРОЦЕССОР ЯЗЫКА СИ. 39

12.1 Подстановка имен. 39

12.2 Включение файлов. 40

12.3 Условная компиляция. 40

13 УКАЗАТЕЛИ. 41

13.1 Операция косвенной адресации * 41

13.2 Описание указателей. 41

13.3 Использование указателей для связи функций. 42

13.4 Указатели на одномерные массивы. 42

13.5 Указатели на многомерные массивы. 43

13.6 Операции над указателями. 43

13.7 Передача массива в качестве параметра в функцию.. 44

13.8 Указатель на void * 45

14 СИМВОЛЬНЫЕ СТРОКИ И ФУНКЦИИ НАД СТРОКАМИ. 46

14.1 Массивы символьных строк. 46

14.2 Массивы указателей. 47

14.3 Указатель как возвращаемое значение функции. 47

Передача указателя как параметра функции. 47

14.4 Функции, работающие со строками. 48

14.5 Стандартные библиотечные функции. 48

14.6 Преобразование символьных строк. 49

15 ССЫЛКИ. 50

16 Параметры КОМАНДНОЙ СТРОКИ. 51

17 ПРОИЗВОДНЫЕ ТИПЫ ДАННЫХ. 52

17.1 Структуры. 52

17.2 Объединения. 56

17.3 Синоним имени типа. 56

17.4 Определение именнованных констант. 57

17.5 Перечисления. 57

17.6 Битовые поля. 58

18 ДИНАМИЧЕСКОЕ ВЫДЕЛЕНИЕ ПАМЯТИ. 59

18.1 Операция new и delete в С++. 60

18.2 Операция new с массивами. 61

18.3 Инициализаторы с операцией new. 61

18.4 Ошибки при использовании динамичской памяти. 62

19 ФАЙЛ. 64

19.1 Открытие файла fopen() 64

19.2 Закрытие файла fclose() 64

19.3 Функции ввода/вывода одного символа fgetc(), fputc() 64

19.4 Функции форматированного ввода/вывода в файл. 65

19.5 Функции ввода/вывода строки символов в файл. 65

19.6 Функции управления указателем в файле. 66

19.7 Ввод/вывод записей фиксированной длины. 66

20 ДИНАМИЧЕСКИЕ СТРУКТУРЫ ДАННЫХ. 68

20.1 Однонаправленные связные списки. 68

20.2 Бинарные деревья. 71

21 РАЗМЕЩЕНИЕ ДАННЫХ В ПАМЯТИ. 74

22 МОДЕЛИ ПАМЯТИ. 75

 

 

ОБЗОР ЯЗЫКа ПРОГРАММИРОВАНИЯ С

 

Разработан в 1972 году Д.Ритчи в фирме Bell Laboratories. Его предшественниками явились язык BCPL (Ричардсон, Кембридже, Англия) и язык В (1970 год, Томпсон) для ранней версии ОС UNIX для компьютера РDP 11.

У языка В не было типов данных, его единственным объектом было машинное слово. Для получения доступа к машинным словам использовались переменные, содержащие указатели. Язык Си устранил эти недостатки. Сохранились указатели, но появились и более сложные структуры данных: массивы, структуры.

Си - современный язык. Его структура позволяет программно использовать нисходящее проектирование, структурное программирование и пошаговую разработку модулей.

Си - мобильный язык. Легко переносится на другие типы машин с небольшими изменениями.

Си - эффективный язык. Программы на Си компактны и быстродействующие.

Си - мощный и гибкий язык. Большая часть UNIX написана на Си, компиляторы и интерпретаторы Fortran, Pascal, Basic, Лисп, Лого. Используются для решения физических, технических проблем, производства мультфильмов.

Си - удобный язык. Сняты многие ограничения.

С++ - язык программирования, используемый в задачах от системного программирования до проблем искусственного интеллекта. Разработал С++ сотрудник Bell Lab’s в 1983 году Брайен Страуструп.

В 1989 году фирма Borland создала Turbo C++ 1.0. А в 90г. фирам Borland C++ 2.0. Появилась возможность программировать в среде Windows. Borland C++ 3.0 имеет библиотеку классов Objekt Windows. Язык Turbo Pascal 6.0 заимствовал часть идей из С++.

В 1991 году в Москве, на выставке программных продуктов 80% программ было написаны на Си и Pascal.

Си - олицетворяет гибкость и богатство возможностей, часто в ущерб безопасности и простоте, надёжность, в ущерб универсальности и изяществу Паскаль.

Borland С++ является интегрированной средой программирования имеющей текстовый редактор, компилятор, редактор связей, отладчик, мощные средства настройки среды.

Си - это язык "компилирующего" типа.

Компилятор - это системная программа, которая преобразует "язык высокого уровня" в язык компьютера - машинный язык. Компиляторы удобны при разработке больших программ, многократного использования.

Дальнейшим продолжением развития Си++ и объектно-ориентированного стиля программирования явилась разработка среды программирования Borland C++ Builder, позволяющая быстро создавать программы, работающие в среде Windows 95, 98.

 

ЭТАПЫ СОЗДАНИЯ ПРОГРАММЫ

 

1) Программа готовится с помощью любого текстового редактора и запоминается в исходном файле с расширением *.С, *.СРР.

2) Преобразуется компилятором в объектный файл *.obj.

3) Вместе с другими объектными файлами преобразуется в исполняемый файл программой, называемой загрузчиком или редактором связей *.EXE.

Этот файл уже может быть исполнен компьютером.