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

Вниз

Стек элементы которого - объекты   Найти похожие ветки 

 
Kolan ©   (2005-09-13 16:14) [0]

Здравствуйте,
 Понадобилось сделать стек. Если исопользовать в качестве элементов стека записи то всё легко.
 
 PNode = ^TNode;

 TNode = record
   FData: TNodeData;
   FNext: PNode;
 end;


 Как быть в случае если элемент стека - это объект. Следующие правильно?
 
 TNode = class
 private
   FNext: TNode;
 protected
 public
 end;
 

 В этом описании FNext будет ссылкой на следуюший?
 Или экземпляр класса TNode будет какбы в себе содержать еще один такой же Node?


 
Anatoly Podgoretsky ©   (2005-09-13 16:20) [1]

Не похоже на стек


 
Ega23 ©   (2005-09-13 16:20) [2]

 В этом описании FNext будет ссылкой на следуюший?

Если ты туда положишь указатель на следующий объект, то - да, будет.


 
Ega23 ©   (2005-09-13 16:22) [3]

Не похоже на стек

Почему? Товарищч LIFO пытается организовать. Точнее - просто список, а LIFO или LILO - это уж как получится...


 
begin...end ©   (2005-09-13 16:23) [4]


> Kolan ©   (13.09.05 16:14)
> Понадобилось сделать стек.

Contnrs.TStack


 
Fay ©   (2005-09-13 16:24) [5]

Ega23 ©   (13.09.05 16:22) [3]
LILO это FIFO ?


 
Zeqfreed ©   (2005-09-13 16:28) [6]

Kolan ©   (13.09.05 16:14)
Every class (and therefore every component) is really a pointer. The compiler automatically dereferences class pointers for you, so most of the time you do not need to think about this. The status of classes as pointers becomes important when you pass a class as a parameter. In general, you should pass classes by value rather than by reference. The reason is that classes are already pointers, which are references; passing a class by reference amounts to passing a reference to a reference.

Fay ©   (13.09.05 16:24) [5]
А можно ещё сказать nInO, n-ым зашел, n-ым вышел ;)


 
Kolan ©   (2005-09-13 16:37) [7]


> Если ты туда положишь указатель на следующий объект

Ну да в смысле это ссылка - правильно.


> Не похоже на стек

Это элемент стека.

Я уже кое-что сделал для записей:
Вот родитель стека, очереди итд
TCustomList = class(TObject)
 private
   FCount: Integer;
   FHead: PNode;
   FFormHandle: THandle;
 protected


Сдесь FHead - указатель на вершину.
Если я использую обекты то допустим создание элемента и добавление его в стек примерно будет выглядеть так?

(Как работать со стеком вообше я знаю...)

Node := TNode.Create;
Создал новый.

А теперь мне надо чтобы FHead указывал на Этот Node.

Как это будет выглядеть? Мне надо FHead создать?
В ообщем как это сделать(пример)?

С записями это выглядит так
var
 Node: PNode;
begin
 inherited Add(Data);
 Node := inherited NewNode(Data);
   Создал новый
 if Head <> nil then
   Node.FNext := Head;
 Head := Node;
Head указывает на новый.
end;


 
Kolan ©   (2005-09-13 16:40) [8]


> Fay ©   (13.09.05 16:24) [5]

Lats In First Out and so on... :)


 
Kolan ©   (2005-09-13 16:48) [9]


> А теперь мне надо чтобы FHead указывал на Этот Node.

Похоже разобрался.
Просто FHead := Node;? И всё? И FHead создавать ненадо...


 
Zeqfreed ©   (2005-09-13 17:07) [10]

Kolan ©   (13.09.05 16:48) [9]

> И FHead создавать ненадо...

Не надо. Если ты его создашь - получишь ещё один экземпляр класса в памяти.


 
Kolan ©   (2005-09-13 17:13) [11]


> Zeqfreed ©   (13.09.05 17:07) [10]

Ну всё, а то чтото я запарился. Всех благодарю за помощь. :)



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

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

Наверх




Память: 0.49 MB
Время: 0.025 c
11-1108113078
Alec
2005-02-11 12:11
2005.10.16
KOLEDB:MEMO поля


5-1103272219
han
2004-12-17 11:30
2005.10.16
Копонент наподобии CombBox


1-1127814803
Archer84
2005-09-27 13:53
2005.10.16
Пожалуйста объясните


3-1125486181
intaari
2005-08-31 15:03
2005.10.16
данные в DBGrid как в cross-tab отчета


14-1127590552
KilkennyCat
2005-09-24 23:35
2005.10.16
Предлагаю всем соседям по куоомуналке, родственничкам и