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

Вниз

Описание классов   Найти похожие ветки 

 
Satrap   (2001-12-28 13:19) [0]

Уважаемые мастера, ответьте на вопрос, можно ли объявлять
процедурный тип с дерективой stdcall например
type
TMyType=procedure (var Message:TMessage) of object stdcall;

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


 
Владислав ©   (2001-12-28 13:20) [1]

Удалено модератором


 
vuk ©   (2001-12-28 13:56) [2]

Если уж "of object", то еще один параметр будет добавлен неявно. Этот параметр - указатель на экземпляр (то же, что и self в методах объектов).


 
Юрий Зотов ©   (2001-12-28 14:54) [3]

Я бы не рискнул сочетать "of object" с "stdcall". Думаю, что это приведет к ошибке при выполнении реального вызова (вряд ли методы дельфишных объектов могут работать по соглашению stdcall).

А если не сочетать, то это будет не метод объекта, а обычная процедура - и тогда почему бы и нет?

Поэтому, если уж очень нужно, то объявите просто процедуру
TMyType = procedure(var Message:TMessage); stdcall;
и уже из нее вызывайте метод объекта (ссылку на его экземпляр процедура может получить, например, через глобальную переменную).


 
vuk ©   (2001-12-28 15:30) [4]

>вряд ли методы дельфишных объектов могут работать по соглашению
>stdcall
Работают. Как из ружья... Единственное ограничение по форматам вызовов - у методов доступа published свойств. Они могут быть только register.


 
Иван Шихалев ©   (2001-12-28 22:27) [5]

прекрасно работает (кроме published)

а объявляентся так :

TMyType=procedure (var Message:TMessage) of object ; stdcall;



 
Satrap   (2002-01-06 07:39) [6]

большое всем спасибо за помощь



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

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

Наверх




Память: 0.47 MB
Время: 0.008 c
3-75513
Kouzmine
2001-12-18 16:27
2002.01.24
Сообщение Table is full Кто поможет?


7-75707
Desdechado
2001-10-10 18:16
2002.01.24
класс TPrinter


3-75523
cpu
2001-12-18 23:25
2002.01.24
Password for Oracle-7


1-75600
ripp
2002-01-07 09:08
2002.01.24
Проблема вот в чем


1-75566
CEBE
2002-01-04 16:08
2002.01.24
Знаю, старо, но что делать, ЦИФРА ПРОПИСЬЮ ...