Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.06.06;
Скачать: CL | DM;

Вниз

Люди помогите   Найти похожие ветки 

 
IceMan   (2004-10-20 12:04) [0]

Я описал тип
type
TFunction:function(x:real):real;
Мне надо написать функцию перевода строки в этот тип.
function StrToFunction(s:string):TFunction;

Например:
var
  S:string;
...
Begin
 S:="cos(x)+5*sin(2+3*x)";
Как Сделать так что-бы эту фигню прога воспринимала как функцию


 
Андрей ©   (2004-10-20 12:55) [1]

Вообще-то вопрос не по теме конференции...
И удалит его модератор...
Но я отвечу, т.к. настроение у меня сегодня хорошее :)

Как ты думаешь, зачем нужен компилятор?
Ну, собственно, неважно, что ты думаешь, суть в следующем

Если ты напишешь в программе

y:=cos(x)+5*sin(2+3*x);

то компилятор проанализирует синтаксис этой конструкции на соответствие правилам своего языка, и, если все правильно,
откомпилирует это в следующую цепочку действий (примерно,
поэтому прошу ногами не пинать)

1. Взять значение X и поместить его в стек сопроцессора
2. Поместить 3 в стек сопроцессора
3. Перемножить два верхних числа и результат поместить обратно в стек сопроцессора
4. Поместить 2 в стек сопроцессора
5. Сложить два верхних числа и результат поместить обратно в стек сопроцессора
6. Взять значение X и занести его в регистры или обычный стек
7. Вызвать функцию cos
8. Полученный результат поместить из регистров в стек сопроцессора
9. Сложить два верхних числа и результат поместить обратно в стек сопроцессора
10. Взять верхнее число из стека сопроцессора и поместить его в ячейку Y

Причем это будет ФИКСИРОВАНЫЙ порядок действий, и если ты захочешь его изменить, программу надо перекомпилировать.

Интрепретатор поступает немного иначе, он может проверить синтаксис и перевести код во внутреннее предстваление, а на момент исполнения брать каждую команду и выполнять ее.

Теперь о твоей конструкции
S:="cos(x)+5*sin(2+3*x)";

Это просто строковая константа, которую компилятор
сохранит в область данных, а в коде будет присвоение и ничего более.
-------
Значит, чтобы реализовать свою задачу, ты должен написать СВОЙ синтаксический анализатор и, например, интерпретатор.
Или взять готовый и встроить в свою программу.

В любом случае, ни Delphi ни KOL тебе не помогут.
Если хочешь поручить разбор такой конструкции компилятору своего кода, пиши программу на FoxPro


 
Gandalf ©   (2004-10-30 13:01) [2]

Тебе нужн парсер. Это оффтоп. Иди на torry.



Страницы: 1 вся ветка

Текущий архив: 2005.06.06;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.056 c
1-1116501266
microcomp
2005-05-19 15:14
2005.06.06
Дельфийский ассемблер


9-1110439112
4ECHOK
2005-03-10 10:18
2005.06.06
Cтолкновение с bsp-картой с помощью ODE ?


1-1116677692
scrazy
2005-05-21 16:14
2005.06.06
графическое дерево


3-1115099064
_DB_
2005-05-03 09:44
2005.06.06
SQL запрос на выбор записей, начанающихся с определенного слова


6-1107518050
JaoDa
2005-02-04 14:54
2005.06.06
Сниффер