Как создавать динамические экземпляры класса

Я хочу иметь возможность создавать экземпляры класса без необходимости объявлять их как объекты. Простой пример. У меня есть программа, которая регистрирует собак для выставок. Каждый раз, когда пользователь нажимает кнопку «Добавить», он должен создавать новый экземпляр класса TDog. Как мне это сделать?

Моя попытка статически:

//clsDog_u
type
 TDog = class(TObject)
 private
  fName : string;
 public
  constructor Create(Name);
  function Get_Name():string;
end;

implementation
//I think you guys knows what goes here ;)

//------------Main Form---------------
unit Unit1;

interface

uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants,
  System.Classes, Vcl.Graphics,
  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, clsDog;

type
  TForm1 = class(TForm)
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
  private
    objDog: tDog;
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);
var
  Name: string;
begin
  name := InputBox('', 'please enter in name:', 'Doggo1');
  objDog := tDog.Create(name);
  ShowMessage(objDog.Get_Name + ' has been added to the dog show.');

end;

end.

Используйте TObjectList<TDog>.

Andreas Rejbrand 20.12.2020 11:35

Самый очевидный способ: поместить всех собак в Array — очень базовую концепцию программирования. Еще больше комфорта дает известный TList Delphi.

AmigoJack 20.12.2020 14:41
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
2
122
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Самое время использовать TObjectList<TDog>.

Для начала вы можете сделать этот объект полем класса формы:

type
  TDog = class
    Name: string;
    Breed: string;
    Born: TDateTime;
    constructor Create(const AName, ABreed: string; const ABorn: TDateTime);
  end;

type
  TDogSimForm = class(TForm)
    btnAddDog: TButton;
    eName: TEdit;
    eBreed: TEdit;
    dtpBorn: TDateTimePicker;
    procedure FormCreate(Sender: TObject);
    procedure FormDestroy(Sender: TObject);
    procedure btnAddDogClick(Sender: TObject);
  private
    FDogs: TObjectList<TDog>;
  public
  end;

и

procedure TDogSimForm.btnAddDogClick(Sender: TObject);
begin
  FDogs.Add(
    TDog.Create(eName.Text, eBreed.Text, dtpBorn.DateTime)
  )
end;

procedure TDogSimForm.FormCreate(Sender: TObject);
begin
  FDogs := TObjectList<TDog>.Create;
end;

procedure TDogSimForm.FormDestroy(Sender: TObject);
begin
  FreeAndNil(FDogs);
end;

{ TDog }

constructor TDog.Create(const AName, ABreed: string; const ABorn: TDateTime);
begin
  Name := AName;
  Breed := ABreed;
  Born := ABorn;
end;

Другие вопросы по теме