А. Григорьев - О чём не пишут в книгах по Delphi

Здесь есть возможность читать онлайн «А. Григорьев - О чём не пишут в книгах по Delphi» — ознакомительный отрывок электронной книги совершенно бесплатно, а после прочтения отрывка купить полную версию. В некоторых случаях можно слушать аудио, скачать через торрент в формате fb2 и присутствует краткое содержание. Город: СПб, Год выпуска: 2008, ISBN: 2008, Издательство: БХВ-Петербург, Жанр: Программирование, на русском языке. Описание произведения, (предисловие) а так же отзывы посетителей доступны на портале библиотеки ЛибКат.

О чём не пишут в книгах по Delphi: краткое содержание, описание и аннотация

Предлагаем к чтению аннотацию, описание, краткое содержание или предисловие (зависит от того, что написал сам автор книги «О чём не пишут в книгах по Delphi»). Если вы не нашли необходимую информацию о книге — напишите в комментариях, мы постараемся отыскать её.

Рассмотрены малоосвещённые вопросы программирования в Delphi. Описаны методы интеграции VCL и API. Показаны внутренние механизмы VCL и приведены примеры вмешательства в эти механизмы. Рассмотрено использование сокетов в Delphi: различные механизмы их работы, особенности для протоколов TCP и UDP и др. Большое внимание уделено разбору ситуаций возникновения ошибок и получения неверных результатов в "простом и правильном" коде. Отдельно рассмотрены особенности работы с целыми, вещественными и строковыми типами данных, а также приведены примеры неверных результатов, связанных с ошибками компилятора, VCL и др. Для каждой из таких ситуаций предложены методы решения проблемы. Подробно рассмотрен синтаксический анализ в Delphi на примере арифметических выражений. Многочисленные примеры составлены с учётом различных версий: от Delphi 3 до Delphi 2007. Прилагаемый компакт-диск содержит примеры из книги.
Для программистов

О чём не пишут в книгах по Delphi — читать онлайн ознакомительный отрывок

Ниже представлен текст книги, разбитый по страницам. Система сохранения места последней прочитанной страницы, позволяет с удобством читать онлайн бесплатно книгу «О чём не пишут в книгах по Delphi», без необходимости каждый раз заново искать на чём Вы остановились. Поставьте закладку, и сможете в любой момент перейти на страницу, на которой закончили чтение.

Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

::= | ['^' ]

::= | | | '(' ')'

Правая ассоциативность также заложена в этих определениях. Рассмотрим, как будет разбираться выражение a^b^c. Сначала функция Factor(через вызов функции Base) выделит и вычислит множитель а, а потом вызовет саму себя для вычисления остатка b^c. Таким образом, а будет возведено в степень b^c, как это и требуют правила правой ассоциативности. Вообще, вопросы правой и левой ассоциативности операторов, которые мы здесь опустили, оказывают влияние на то, как определяется грамматика языка. Более подробно об этом написано в [5].

Так как определения символов и в нашей новой грамматике не изменились, не изменятся и соответствующие функции. Для реализации нового синтаксиса нам потребуется изменить функцию Factorи ввести новые функции Base, Identifierи Func(примем такое сокращение, т.к. functionв Delphi является зарезервированным словом). Идентификаторы будем полагать нечувствительными к регистру символов.

Для простоты обойдемся тремя функциями: sin, cosи ln. Увеличение количества функций, допустимых в выражении, — простая техническая задача, не представляющая особого интереса.

Если у нас появились переменные, то мы должны как-то хранить их значения, чтобы при вычислении выражения использовать их. В нашем примере мы будем хранить их в объекте типа TStrings, получая доступ через свойство Values. С точки зрения производительности, этот способ — один из самых худших, поэтому при создании реального калькулятора лучше придумать что-нибудь другое. Мы здесь выбрали этот способ исключительно из соображений наглядности. Получившийся в итоге код показан в листинге 4.9.

Листинг 4.9. Реализация полноценного калькулятора

// вычисление функции, имя которой передается через FuncName

function Func(const FuncName, S: string; var Integer): Extended;

var

Arg: Extended;

begin

// Вычисляем аргумент

Arg := Expr(S, P);

// Сравниваем имя функции с одним из допустимых

if AnsiCompareText(FuncName, 'sin') = 0 then

Result := Sin(Arg)

else if AnsiCompareText(FuncName, 'соs') = 0 then

Result := Cos(Arg)

else if AnsiCompareText(FuncName, 'ln') = 0 then

Result := Ln(Arg)

else

raise ESyntaxError.Create('Неизвестная функция ' + FuncName);

end;

// Выделение из строки идентификатора и определение,

// является ли он переменной или функцией

function Identifier(const S: string: var P: Integer): Extended;

var

InitP: Integer;

IDStr, VarValue: string;

begin

// Запоминаем начало идентификатора

InitP := P;

// Первый символ был проверен ещё в функции Base.

// Сразу переходим к следующему

Inc(P);

while (P <= Length(S)) and

(S[P] in ('A'..'Z', 'a'..'z', '_', '0'..'9']) do

Inc(P);

// Выделяем идентификатор из строки

IDStr := Copy(S, InitP, P - InitP);

// Если за ним стоит открываемая скобка — это функция

if (Р <= Length(S)) and (S[P) - '(' then

begin

Inc(P);

Result := Func(IDStr, S, P);

// Проверяем, что скобка закрыта

if (Р > Length(S)) or (S[P] <> ')') then

raise ESyntaxError.Create(

'Ожидается ")" в позиции ' + IntToStr(P));

Inc(P);

end

// если скобки нет - переменная

else

begin

VarValue := Form1.ListBoxVars.Items.Values[IDStr];

if VarValue = '' then

raise ESyntaxError.Create(

'Необъявленная переменная ' + IDStr +

' в позиции ' + IntToStr(P))

elsе Result := StrToFloat(VarValue);

end;

end;

// Выделение подстроки, соответствующей ,

// и ее вычисление

function Base(const S: string; var P: Integer): Extended;

begin

if P > Length(S) then

raise ESyntaxError.Create('Неожиданный конец строки');

// По первому символу подстроки определяем,

// какое это основание

case S[P] of

'(': // выражение в скобках

begin

Inc(Р);

Result := Expr(S, Р);

// Проверяем, что скобка закрыта

if (Р > Length(S)) or (S[P) <> ')') then

raise ESyntaxError.Create(

'Ожидается ")" в позиции ' + IntToStr(Р));

Inc(Р);

end;

'0'..'9': // Числовая константа

Result := Number(S, P);

'A'..'Z', 'a'..'z', '_': // Идентификатор (переменная или функция)

Result := Identifier(S, P);

else

raise ESyntaxError.Create(

'Некорректный символ в позиции ' + IntToStr(Р));

end;

end;

// Выделение подстроки, соответствующей ,

// и ее вычисление

Читать дальше
Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

Похожие книги на «О чём не пишут в книгах по Delphi»

Представляем Вашему вниманию похожие книги на «О чём не пишут в книгах по Delphi» списком для выбора. Мы отобрали схожую по названию и смыслу литературу в надежде предоставить читателям больше вариантов отыскать новые, интересные, ещё непрочитанные произведения.


Отзывы о книге «О чём не пишут в книгах по Delphi»

Обсуждение, отзывы о книге «О чём не пишут в книгах по Delphi» и просто собственные мнения читателей. Оставьте ваши комментарии, напишите, что Вы думаете о произведении, его смысле или главных героях. Укажите что конкретно понравилось, а что нет, и почему Вы так считаете.

x