|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
В свежей Delphi 12.2 появился класс TParallelArray. Из записи в блоге. https://blogs.embarcadero.com/faster-delphi-rtl-with-parallel-arrays-and-ordered-dictionaries/ Код: Delphi 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. 26. 27. 28. 29. 30. 31. 32. 33. 34. 35. 36. 37. 38. 39. 40. 41. 42. 43. 44. 45. 46. 47. 48. 49. 50. 51. 52.
Цитата [игнорируется] If I run it on my main computer, an Intel(R) Core(TM) i7-10700 CPU @ 2.90GHz , I get the following results, a nice 585% improvement! (output trimmed to milliseconds for readability) Код: Delphi 1. 2.
Код: Delphi 1.
... |
|||
:
Изменено: 03.10.2024, 11:04 - s62
Нравится:
Не нравится:
|
|||
03.10.2024, 10:43 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
Видел, как человек пользовался, но как-то сам не обращал внимания. Удобная вещь вверху окна редактора кода - два выпадающих окна, в левом список классов, в правом - список методов выбранного класса. И, как я понял, в нем же, если класс не выбрано - список процедур/функций (не методов классов) этого модуля. А я всё пользовался поиском и переходом к объявлению (Ctrl+Click). Есть ещё конечно боковое окно структуры модуля, но я им редко до сих пор пользовался, обычно, когда какой-то чужой модуль открывал и искал какие-то классы, методы и т.п., так, оно у меня обычно свернуто. В одном из текущих проектов есть большие модули с большими классами, где много методов, там эта штука удобна наверное. Всё, сейчас после обеда попробую использовать это. p.s. Это - часть того, что называется Navigation toolbar, появилось, оказывается в Delphi XE8, я пользовался из этой панели (тулбара) переходом к разным секциям модуля. https://docwiki.embarcadero.com/RADStudio/Athens//en/Code_Editor#Navigation_Toolbar ... |
|||
:
Изменено: 18.10.2024, 12:15 - s62
Нравится:
Не нравится:
|
|||
18.10.2024, 12:14 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
Модуль Sysutils. Код: Delphi 1.
... |
|||
:
Нравится:
Не нравится:
|
|||
27.02.2025, 14:17 |
|
Заметки о Делфи.
|
|
---|---|
#18+
Столкнулся с небольшим багом в версии 12.2. Запостил в соответствующий раздел сайта Эмбаркадеро (Quality portal). Сегодня поставили статус, что пофиксили в версии 12.3. Но из-за санкций сейчас в РФ нельзя купить и нельзя продлить подписку на Delphi. А у нас кончилась в конце прошлого ноября. Обновления на сайте Эмбаркадеро доступны для клиентов с активной подпиской. Ну, баг не очень серьезный, есть обход. ... |
|
:
|
|
27.03.2025, 13:59 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
Один из недостатков языка Delphi (Object Pascal) - что интерфейсы (интерфейсные типы) изначально были привязаны к технологии COM и по-умолчанию в них релизован подсчет ссылок и автоматическое удаление, когда ссылок становится ноль. Это усложняет использование интерфейсов как просто контрактов, как они например широко используются в Java. Например вы создаете обычным образом объект, который реализует какой-то интерфейс, потом когда-то собираетесь объект удалить. Но если вы обратились к нему через интерфейс, то как только ссылка на интерфейс выйдет из сферы видимости, компилятор сразу сам удалит этот объект. Вот статья на эту тему. https://www.codeproject.com/Articles/1252175/Fixing-Delphis-Interface-Limitations У меня один объкет создает другой, а этому другому нужно вызвать методы первого. Получается круговая ссылка (circular reference), Почитал, как такие ситуации разрешают, ИИ от гугла написал несколько вариантов. Один из них, первый объект реализует некий интерфейс, а второй обращается к этому интерфейсу, а не к самому первому объекту. Но особенности интерфейсов в Delphi делают этот метод геморным, неподходящим в общем. Сейчас у меня это решено так, что объявлен процедурный тип (процедура объекта) и в конструктор второго объекта передаются три параметра этого типа (т.е. три метода первого объекта). Т.е. второй объект не должен что-либо знать о первом классе, ему достаточно знать тип параметра. Можно наверное и как-то иначе разрешить эту ситуацию, но не придумал, как это сделать. А если бы интерфейсы были бы без reference counting, сделал бы интерфейс с этими тремя методами, он как раз и в других ситуациях пригодился бы. Мне надо из других модулей (и потоков) запускать в модуле определенного типа (и потоке) два типа действий и останавливать их оба одной и той же процедурой "стоп". Причем запускать могут разные модули. Интерфейс по-моему был бы к месту здесь. ... |
|||
:
Изменено: 29.05.2025, 13:22 - s62
Нравится:
Не нравится:
|
|||
29.05.2025, 13:19 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
Один из недостатков языка Delphi (Object Pascal) - что интерфейсы (интерфейсные типы) изначально были привязаны к технологии COM и по-умолчанию в них релизован подсчет ссылок и автоматическое удаление, когда ссылок становится ноль. Это усложняет использование интерфейсов как просто контрактов, как они например широко используются в Java. Например вы создаете обычным образом объект, который реализует какой-то интерфейс, потом когда-то собираетесь объект удалить. Но если вы обратились к нему через интерфейс, то как только ссылка на интерфейс выйдет из сферы видимости, компилятор сразу сам удалит этот объект. Вот статья на эту тему. https://www.codeproject.com/Articles/1252175/Fixing-Delphis-Interface-Limitations У меня один объкет создает другой, а этому другому нужно вызвать методы первого. Получается круговая ссылка (circular reference), Почитал, как такие ситуации разрешают, ИИ от гугла написал несколько вариантов. Один из них, первый объект реализует некий интерфейс, а второй обращается к этому интерфейсу, а не к самому первому объекту. Но особенности интерфейсов в Delphi делают этот метод геморным, неподходящим в общем. Сейчас у меня это решено так, что объявлен процедурный тип (процедура объекта) и в конструктор второго объекта передаются три параметра этого типа (т.е. три метода первого объекта). Т.е. второй объект не должен что-либо знать о первом классе, ему достаточно знать тип параметра. Можно наверное и как-то иначе разрешить эту ситуацию, но не придумал, как это сделать. А если бы интерфейсы были бы без reference counting, сделал бы интерфейс с этими тремя методами, он как раз и в других ситуациях пригодился бы. Мне надо из других модулей (и потоков) запускать в модуле определенного типа (и потоке) два типа действий и останавливать их оба одной и той же процедурой "стоп". Причем запускать могут разные модули. Интерфейс по-моему был бы к месту здесь. Наоборот, пиздатейшая вещь. А для контрактов можно использовать обычные объекты, без интерфейсов ... |
|||
:
Нравится:
Не нравится:
|
|||
29.05.2025, 13:49 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
А для контрактов можно использовать обычные объекты, без интерфейсов ... |
|||
:
Нравится:
Не нравится:
|
|||
29.05.2025, 16:58 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
Оказывается можно вот так: Код: Delphi 1. 2. 3. 4. 5. 6. 7.
Цитата [игнорируется] counter is a local variable (declared in the block containing the for statement) of ordinal type, without any qualifiers. ... |
|||
:
Изменено: 30.05.2025, 22:00 - s62
Нравится:
Не нравится:
|
|||
30.05.2025, 21:59 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
Оказывается можно вот так: Код: Delphi 1. 2. 3. 4. 5. 6. 7.
Цитата [игнорируется] counter is a local variable (declared in the block containing the for statement) of ordinal type, without any qualifiers. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.05.2025, 22:00 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
Гарыныч [игнорируется] Это 11, но вот это уже давно было. Не помню, раньше пользовался таким или нет. ... |
|||
:
Нравится:
Не нравится:
|
|||
30.05.2025, 22:01 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
Оказывается можно вот так: Код: Delphi 1. 2. 3. 4. 5. 6. 7.
Цитата [игнорируется] counter is a local variable (declared in the block containing the for statement) of ordinal type, without any qualifiers. а эти перечисления - всего лишь биты в этой переменной. В современных дельфях можно указывать вот так Код: Delphi 1. 2.
... |
|||
:
Нравится:
Не нравится:
|
|||
30.05.2025, 23:36 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
В современных дельфях можно указывать вот так Код: Delphi 1. 2.
... |
|||
:
Изменено: 30.05.2025, 23:47 - s62
Нравится:
Не нравится:
|
|||
30.05.2025, 23:44 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
испокон веков в Паскале так было можно ... |
|||
:
Нравится:
Не нравится:
|
|||
31.05.2025, 00:43 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
а эти перечисления - всего лишь биты в этой переменной. https://docwiki.embarcadero.com/RADStudio/Athens//en/Internal_Data_Formats_(Delphi)#Enumerated_Types ... |
|||
:
Изменено: 31.05.2025, 00:47 - s62
Нравится:
Не нравится:
|
|||
31.05.2025, 00:47 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
Для оживления темы что ли. Сам не пользуюсь обычно (не помню, может где-то и пользовался), но фича интересная. Как известно, в ряде ЯП даже переменные простых типов суть объекты. Соответственно, у них могут быть методы. В Delphi это не так. Но, с помощью record helper'ов, как именно, я особо не разбирался, ряд функций и процедур для строк реализованы синтактически, как методы. При этом остаются старые варианты. Например. Код: Delphi 1. 2. 3. 4. 5. 6. 7. 8.
https://docwiki.embarcadero.com/Libraries/Athens/en/System.SysUtils.TStringHelper_Methods ... |
|||
:
Нравится:
Не нравится:
|
|||
23.07.2025, 15:50 |
|
Заметки о Делфи.
|
|
---|---|
#18+
Для оживления темы что ли. Сам не пользуюсь обычно (не помню, может где-то и пользовался), но фича интересная. Как известно, в ряде ЯП даже переменные простых типов суть объекты. Соответственно, у них могут быть методы. В Delphi это не так. Но, с помощью record helper'ов, как именно, я особо не разбирался, ряд функций и процедур для строк реализованы синтактически, как методы. При этом остаются старые варианты. Например. Код: Delphi 1. 2. 3. 4. 5. 6. 7. 8.
https://docwiki.embarcadero.com/Libraries/Athens/en/System.SysUtils.TStringHelper_Methods Приходится иногда кодить в древних дельфях типа Delphi 5 или 7 - вот там заебёшься некотоорые очевидные и простые вещи реализовывать, которые уже 15 лет как сделаны в новых ... |
|
:
|
|
23.07.2025, 16:20 |
|
Заметки о Делфи.
|
|
---|---|
#18+
На одной фабрике в программе возникала вчера ошибка, в логе записи остались, но несколько секунд было, потом прошло. В процедуре, которая отображает в главном окне состояние устройств периодически. Ошибка - Access violation. На всякий случай перечитал подсказки Gunsmoker'а из его большой статьи про обработку ошибок: Цитата [игнорируется] 12). В случае EAccessViolation у нас есть два адреса: "Access violation at address 004564AA in module 'Project1.exe'. Read of address 00000000". Первый из них ("at address 004564AA") — это адрес проблемной инструкции. С ним можно поступить, как и в предыдущем пункте. Кроме него, в этом сообщении ещё интересны слова "Read" или "Write" и второй адрес ("of address 00000000"). "Read" указывает на то, что ваша программа пытается прочитать что-то из недоступной памяти (или, иногда, — выполнить), а "Write" — на то, что она пытается что-то записать. Это поможет вам проанализировать проблемную строчку — нужно анализировать только места чтения или только места записи в строке. Далее, второй адрес в сообщении указывает, откуда/куда программа пытается читать или писать данные. Обычно это значение само по себе не очень полезно, однако из него тоже можно извлечь кой-какую информацию. Например, это значение может быть очень мало, например 00000000, 00000008 или 000000A1. В этом случае можно биться об заклад, что у вас какой-то объект равен nil, а вы пытаетесь с ним работать. Например, объект равен nil, и вы читаете/пишете его свойство. Или указатель на массив равен nil, а вы пытаетесь прочитать значение его ячейки. Откуда это следует — оставим вам в качестве домашнего задания :) Если же это значение относительно велико, например 7FEB0010, 70000008 и т.п., то велики шансы, что у вас мусорная ссылка. Например, вы освободили объект, а потом позже пытаетесь к нему обратиться. Кстати, также велика вероятность, что эта ошибка — плавающая. Поэтому, если вы встретились с ней по время прогона под Delphi, не мешкайте — начинайте отлаживаться с места, а то потом можете и не повторить её. Для профилактики таких ошибок используйте процедуру FreeAndNil вместо метода Free, FreeMemAndNil вместо FreeMem или же явно обнуляйте все ссылки после освобождения объектов. Также, внимательно просмотрите свой код на предмет того, не используете ли вы где две ссылки на один и тот же объект. И если да, то обнуляете ли вы все ссылки при удалении объекта. Например, вы занесли объект в массив/список с автоосвобождением, и у вас есть ещё ссылка на объект. Кстати, если второй адрес в сообщении с EAccessViolation совпадает с первым, то велика вероятность, что у вас ситуация с переходом выполнения программы по недействительному адресу (см. предыдущий пункт). https://www.gunsmoker.ru/p/best.html#exceptions ... |
|
:
|
|
29.08.2025, 14:13 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
Как-то никогда с этим не сталкивался, оказывается свойства в потомках тоже можно override, изменить. То, что методы можно переопределить, override, это понятно, это не раз делал, собственно иерархия классов во многом на этом и основана же, полиморфизм, это самое. Например было в предке свойство только для чтения, а в потомке - для чтения и записи. Вот у меня, например, в предке: Код: Delphi 1. 2. 3.
Появилась программа - сетевой клиент. Там мы сначала объект создадим, потом параметры запросим по сети. И вот надо присваивать. В потомке добавляем возможность записи, т.е. в потомке пишем Код: Delphi 1. 2. 3.
... |
|||
:
Изменено: Вчера, 17:49 - s62
Нравится:
Не нравится:
|
|||
04.09.2025, 16:34 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
Как-то никогда с этим не сталкивался, оказывается свойства в потомках тоже можно override, изменить. То, что методы можно переопределить, override, это понятно, это не раз делал, собственно иерархия классов во многом на этом и основана же, полиморфизм, это самое. Например было в предке свойство только для чтения, а в потомке - для чтения и записи. Вот у меня, например, в предке: Код: Delphi 1. 2. 3.
Появилась программа - сетевой клиент. Там мы сначала объект создадим, потом параметры запросим по сети. И вот надо присваивать. В потомке добавляем возможность записи, т.е. в потомке пишем Код: Delphi 1. 2. 3.
если будут находиться в разных - такое не сработает а вообще, такой подход - прямой путь к пиздецу в коде ... |
|||
:
Изменено: 04.09.2025, 16:41 - defecator
Нравится:
Не нравится:
|
|||
04.09.2025, 16:40 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
это только в том случае, если оба класса - предок и потомок - находятся в одном юните если будут находиться в разных - такое не сработает https://docwiki.embarcadero.com/RADStudio/Alexandria/en/Properties_(Delphi)#Property_Overrides_and_Redeclarations ... |
|||
:
Изменено: 04.09.2025, 16:51 - s62
Нравится:
Не нравится:
|
|||
04.09.2025, 16:51 |
|
Заметки о Делфи.
#1515191
![]() Ссылка:
Ссылка на сообщение:
Ссылка с названием темы:
Ссылка на профиль пользователя:
Ссылка на вложение:
|
||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
#18+
это только в том случае, если оба класса - предок и потомок - находятся в одном юните если будут находиться в разных - такое не сработает https://docwiki.embarcadero.com/RADStudio/Alexandria/en/Properties_(Delphi)#Property_Overrides_and_Redeclarations внутри одного юнита всё доступно, а если разнести по разным - то увы И это не наследование, как у тебя написано, просто компилятор видит поля класса в рамках одного юнита TParentClass описан в другом юните ... |
||||||||||||||||
:
Изменено: 04.09.2025, 16:56 - defecator
Нравится:
Не нравится:
|
||||||||||||||||
04.09.2025, 16:53 |
|
Заметки о Делфи.
|
|||
---|---|---|---|
#18+
а вообще, такой подход - прямой путь к пиздецу в коде Разрабатывается другая программа, сетевой клиент, который сам измерять не будет, а будет получать данные от первой программы. Хранить метаданные и данные удобно в такой же примерно структуре, но и-за отличий функций клиента и сервера удобно кое-что изменить для клиента. Изменить как раз в потомке. Сейчас даже модули используются разные, просто старый модуль скопирован в новый проект. Но в принципе можно было бы использовать и общий модуль, но нет такой необходимости. Т.е. можно было бы для клиента написать свой отдельный класс. Но нужная функциональность легко достигается внесением некоторых изменений в потомке. Как раз разделение не дает возникнуть хаосу, т.к. отличия в функционале реализованы в отдельных классах. p.s. На самом деле я сначала написал для клиента отдельный класс для хранения метаданных измерений. А потом уже увидел, что в нем нет нужды, что можно слегка подрихтовать в наследнике того, что уже было, некоторые моменты и добавить нужную дополнительную функциональность. (В том числе кое-какие поля, которые в старой программе были в другом месте). ... |
|||
:
Изменено: 04.09.2025, 17:39 - s62
Нравится:
Не нравится:
|
|||
04.09.2025, 17:22 |
|
Заметки о Делфи.
#1515260
![]() Ссылка:
Ссылка на сообщение:
Ссылка с названием темы:
Ссылка на профиль пользователя:
Ссылка на вложение:
|
||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
#18+
нет, никакого override свойств не бывает Вот это, что я выделил, работать не будет синтаксически - write без read не бывает ... |
||||||||||||||||
:
Нравится:
Не нравится:
|
||||||||||||||||
04.09.2025, 17:56 |
|
|
start [/forum/topic.php?fid=16&msg=1423309&tid=15954]: |
0ms |
get settings: |
10ms |
get forum list: |
13ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
26ms |
get topic data: |
9ms |
get forum data: |
3ms |
get page messages: |
99ms |
get tp. blocked users: |
1ms |
others: | 31ms |
total: | 198ms |
0 / 0 |