
- •Определение по Шеннону
- •Создание первых компьютеров
- •События, предшествовавшие появлению персональных компьютеров
- •Устройства для вывода визуальной информации
- •История Ранние разработки
- •Известные компиляторы языка Си
- •Данные плавающего типа
- •Переменные перечислимого типа
- •Массивы
- •Структуры
- •Объединения (смеси)
- •If (условие) оператор
- •If (условие) оператор1 else оператор2;
- •Оператор switch
- •Оператор for
- •1.4.8. Оператор while
- •1.4.9. Оператор do while
- •Функции с параметрами.
- •Передача параметра по значению
- •Передача параметра по адресу
- •Передача параметра по ссылке
- •Чтение из потока при помощи fgetc
- •При помощи fgets
- •Запись в файл при помощи fwrite
- •Запись в поток при помощи fputc
История Ранние разработки
Язык программирования Си был разработан в лабораториях Bell Labs в период с 1969 по 1973 годы. Согласно Ритчи, самый активный период творчества пришёлся на 1972 год. Язык назвали «Си» (C — третья буква латинского алфавита), потому что многие его особенности берут начало от старого языка «Би» (B — вторая буква латинского алфавита). Существует несколько различных версий происхождения названия языка Би. Кен Томпсон указывает на язык программирования BCPL, однако существует ещё и язык Bon, также созданный им, и названный так в честь его жены Бонни.
В 1978 году Ритчи и Керниган опубликовали первую редакцию книги «Язык программирования Си». Эта книга, известная среди программистов как «K&R», служила многие годы неформальной спецификацией языка. Версию языка Си, описанную в ней, часто называют «K&R C».
В конце 1970-х годов Си начал вытеснять Бейсик с позиции ведущего языка для программирования микрокомпьютеров. В 1980-х годах он был адаптирован для использования в IBM PC, что привело к резкому росту его популярности. В то же время Бьярне Строуструп и другие в лабораториях Bell Labs начали работу по добавлению в Си возможностей объектно-ориентированного программирования. Язык, который они в итоге сделали, C++, в настоящее время является самым распространённым языком программирования. Си остаётся более популярным в UNIX-подобных системах.
В 1983 году Американский Национальный Институт Стандартизации (ANSI) сформировал комитет для разработки стандартной спецификации Си. По окончании этого долгого и сложного процесса в 1989 году он был наконец утверждён как «Язык программирования Си» ANSI X3.159-1989. Эту версию языка принято называть ANSI C или C89.
После стандартизации в ANSI спецификация языка Си оставалась относительно неизменной в течение долгого времени, в то время как Си++ продолжал развиваться (в 1995 году в стандарт Си была внесена Первая нормативная поправка, но её почти никто не признавал). Однако в конце 1990-х годов стандарт подвергся пересмотру, что привело к публикации ISO 9899:1999 в1999 году. Этот стандарт обычно называют «С99». В марте 2000 года он был принят и адаптирован ANSI. Язык программирования С++ произошёл от Си. Однако в дальнейшем Си и C++ развивались независимо, что привело к росту несовместимостей между ними. Последняя редакция Си, С99, добавила в язык несколько конфликтующих с С++ особенностей. Эти различия затрудняют написание программ и библиотек, которые могли бы нормально компилироваться и работать одинаково в компиляторах Си и C++, что, конечно, запутывает тех, кто программирует на обоих языках.
Известные компиляторы языка Си
Borland C++
C++ Builder
Microsoft Visual Studio
Элементы программы, написанной на языке Си.
Под алфавитом языка понимается набор символов, которые используются при написании программ. Язык Си включает в себя латинские буквы A..Z, a..z, а также символ «_», цифры 0-9. И 28 спец. символов :+,-,*, \,/,(,),[,],{,}, «.», «,» , #, $, &, |, ^,?, !, %, ~, «;», «:», `, “.
Программа на языке Си представляет собой последовательность строк символов (не более 126 символов в строке) состоящих из лексем. Лексема – мин. ед. языка, имеющая самостоятельный смысл.
Типы лексем:
1.Зарезервированные (ключевые) слова(char, long, continue, return, else, float, for, if…)
2.Идентификаторы (имена) - для обозначения типов имен переменных, констант, ф-й. состоит из букв и цифр(max…elem)
3.Коментарии: многостр /*…*/ одностр //…//
4.Ограничители: ( ) { } [ ] : ;
5. Операции: 1.односимвольные ?=!+-/*%остаток от деления\~< >^.
2.многосимвольные == != <= >= += -= *= /=
Отличаются либо разделителями (пробел, табуляция, перевод строки, возврат каретки) либо комментаторами.
\a |
Звонок |
007 |
\b |
Возврат на шаг |
008 |
\t |
Горизонтальная табуляция |
009 |
\n |
Переход на новую строку |
00A |
\v |
Вертикальная табуляция |
00B |
\r |
Возврат каретки |
00C |
\f |
Перевод формата |
00D |
\" |
Кавычки |
022 |
\' |
Апостроф |
027 |
\0 |
Ноль-символ |
000 |
\\ |
Обратная дробная черта |
05C |
\ddd |
Символ набора кодов ПЭВМ в восьмеричном представлении |
|
\xddd |
Символ набора кодов ПЭВМ в шестнадцатеричном представлении |
|
Константы языка Си.
Константами называются перечисление величин в программе. В языке СИ разделяют четыре типа констант: целые константы, константы с плавающей запятой(вещественные), символьные константы и строковые.
Целая константа: это десятичное, восьмеричное или шестнадцатеричное число, которое представляет целую величину в одной из следующих форм: десятичной, восьмеричной или шестнадцатеричной.
Примеры целых констант:
Десятичная Восьмеричная Шестнадцатеричная
константа константа константа
16 020 0x10
127 0117 0x2B
240 0360 0XF0
Для того чтобы любую целую константу определить типом long, достаточно в конце константы поставить букву "l" или "L". Пример:
5l, 6l, 128L, 0105L, OX2A11L.
Константа с плавающей точкой - десятичное число, представленное в виде действительной величины с десятичной точкой или экспонентой. Формат имеет вид:
[ цифры ].[ цифры ] [ Е|e [+|-] цифры ] .
Число с плавающей точкой состоит из целой и дробные части и (или) экспоненты. Константы с плавающей точкой представляют положительные величины удвоенной точности (имеют тип double). Для определения отрицательной величины необходимо сформировать константное выражение, состоящее из знака минуса и положительной константы.
Примеры: 115.75, 1.5Е-2, -0.025, .075, -0.85Е2
Символьная константа - представляется символом заключенном в апострофы. Управляющая последовательность рассматривается как одиночный символ, допустимо ее использовать в символьных константах. Значением символьной константы является числовой код символа. Примеры:
' '- пробел ,
'Q'- буква Q ,
'\n' - символ новой строки ,
'\\' - обратная дробная черта ,
'\v' - вертикальная табуляция .
Символьные константы имеют тип int и при преобразовании типов дополняются знаком.
Строковая константа (литерал) - последовательность символов (включая строковые и прописные буквы русского и латинского а также цифры) заключенные в кавычки (") . Например: "Школа N 35", "город Тамбов", "YZPT КОД".
Отметим, что все управляющие символы, кавычка ("), обратная дробная черта (\) и символ новой строки в строковом литерале и в символьной константе представляются соответствующими управляющими последовательностями. Каждая управляющая последовательность представляется как один символ. Например, при печати литерала "Школа \n N 35" его часть "Школа" будет напечатана на одной строке, а вторая часть "N 35" на следующей строке.
Символы строкового литерала сохраняются в области оперативной памяти. В конец каждого строкового литерала компилятором добавляется нулевой символ, представляемый управляющей последовательностью \0.
Строковый литерал имеет тип char[] . Это означает, что строка рассматривается как массив символов. Отметим важную особенность, число элементов массива равно числу символов в строке плюс 1, так как нулевой символ (символ конца строки) также является элементом массива. Все строковые литералы рассматриваются компилятором как различные объекты. Строковые литералы могут располагаться на нескольких строках. Такие литералы формируются на основе использования обратной дробной черты и клавиши ввод. Обратная черта с символом новой строки игнорируется компилятором, что приводит к тому, что следующая строка является продолжением предыдущей. Например:
"строка неопределенной \n
длины"
полностью идентична литералу
"строка неопределенной длинны" .
Для сцепления строковых литералов можно использовать символ (или символы) пробела. Если в программе встречаются два или более строковых литерала, разделенные только пробелами, то они будут рассматриваться как одна символьная строка. Этот принцип можно использовать для формирования строковых литералов занимающих более одной строки.
Система типов языка Си.
Тип(сорт)- относительно устойчивая независимая совокупность элементов, которую можно выделить во всем рассматриваемом множестве. Задается либо набором допустимых значений либо набором действий, которые можно совершить над каждой переменной действительного типа.
Типы языка Си:
---Пустой(void)
---Скалярные типы: --Указатели
--арифм. Типы:--Целые и вещественные.
-- перечисления
---Функции
Комбинированные типы: -- массивы и записи(структуры) и объединения.
Целые:
Тип |
Размер памяти в байтах |
Диапазон значений |
char |
1 |
от -128 до 127 |
int |
Для IBM XT,AT,SX,DX 2 |
|
short |
2 |
от -32768 до 32767 |
long |
4 |
от -2 147 483 648 до 2 147 483 647 |
unsigned shar |
1 |
oт 0 до 255 |
unsigned int |
Для IBM XT,AT,SX,DX 2 |
|
unsigned short |
2 |
от 0 до 65535 |
unsigned long |
4 |
от 0 до 4 294 967 295 |