AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

TThread - property oder nicht?

Ein Thema von Pentium 80486 · begonnen am 23. Nov 2012 · letzter Beitrag vom 23. Nov 2012
Antwort Antwort
Pentium 80486
(Gast)

n/a Beiträge
 
#1

TThread - property oder nicht?

  Alt 23. Nov 2012, 01:39
Hallo,

eher eine simple, fast schon eine überflüssige Frage, welche mir dennoch wichtig erscheint.

Sollte man beim Erstellen eines Threads lieber mit properties oder mit "einfachen Variablen" arbeiten?

Beispiel mit Properties:
Delphi-Quellcode:
type
 TMyThread = class(TThread)
 private
  { Private-Deklarationen }
  FsTest: String;
 public
  { Public-Deklarationen }
  property sTest: String read FsTest write FsTest;
 end;

// . . .

aMyThread := TMyThread.Create;
aMyThread.sTest := 'Test';

Beispiel mit Variablen:
Delphi-Quellcode:
type
 TMyThread = class(TThread)
 private
  { Private-Deklarationen }
 public
  { Public-Deklarationen }
  sTest: String;
 end;

// . . .

aMyThread := TMyThread.Create;
aMyThread.sTest := 'Test';
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.062 Beiträge
 
Delphi 12 Athens
 
#2

AW: TThread - property oder nicht?

  Alt 23. Nov 2012, 01:53
Welche Delphi-Version hattest du nochmal?


Gib einfach mal das ein
Delphi-Quellcode:
type
  TMyThread = class(TThread)
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
    property sTest: String;
  end;
und das Strg+Shift+C (Klassenvervollständigung) drücken, mit Textcursor innerhalb der Klassendeklaration.
Wenn das geht, dann auf jeden Fall Property ... ist nicht mehr Arbeit und in Zukunft läßt sich der Zugriff naträglich noch ganz bequem regeln. (z.B. Getter und Setter einbauen)
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  Mit Zitat antworten Zitat
Pentium 80486
(Gast)

n/a Beiträge
 
#3

AW: TThread - property oder nicht?

  Alt 23. Nov 2012, 01:59
Klappt wunderbar mit delphi XE2.

Bleibt nur die Frage, ob man dann aMyThread.SetsTest('Test'); oder aMyThread.sTest := 'Test'; nehmen sollte.

Im Prinzip ist es doch dasselbe. Nur eine Style-Guide-Frage (denke ich).
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.062 Beiträge
 
Delphi 12 Athens
 
#4

AW: TThread - property oder nicht?

  Alt 23. Nov 2012, 02:01
Delphi dürfte doch SetsTest im Private erstellt haben?

Dann beantwortet sich die Frage von selber.



Ich halte es so:
- Extern immer über den Property
- Intern direkt auf das Feld oder auf den Setter, jenachdem was benötigt wird ... so sieht man dann auch ganz schnell was verwendet wird. (ohne das F zu übersehn)
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu (23. Nov 2012 um 02:03 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 16. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#5

AW: TThread - property oder nicht?

  Alt 23. Nov 2012, 02:34
Also ich verwende zu Beginn der Entwicklung meistens einfache Variablen; ganz einfach deswegen, weil man weniger Schreibaufwand benötigt und schneller ändern kann. (Zumindest dann wenn die IDE keine Unterstützung zum Refaktorieren bietet)

Später, wenn sich die Klasse und die öffentlich sichtbaren Methoden & Variablen stabilisiert haben, mache ich aus den einfachen Variablen richtige Properties.
  Mit Zitat antworten Zitat
Pentium 80486
(Gast)

n/a Beiträge
 
#6

AW: TThread - property oder nicht?

  Alt 23. Nov 2012, 02:36
Ich hätte nicht gedacht, dass ich die Umstellung von "alt" auf "neu" (mit Properties) so schnell vollziehen kann!

Wo vorher z.B. sMeinString:String; stand, einfach ein property sMeinString:String; draus gemacht, STRG+Shift+C gedrückt, fertig.

Jetzt kenne ich leider den technischen Unterschied von meinem "alten" und dem "neuen" Code nicht. Gibt es da überhaupt einen?
Denn es muss ja einen Grund geben, warum properties vorgezogen werden.
  Mit Zitat antworten Zitat
sahimba

Registriert seit: 14. Nov 2011
Ort: Berlin, Hauptstadt der DDR
137 Beiträge
 
Delphi 10 Seattle Professional
 
#7

AW: TThread - property oder nicht?

  Alt 23. Nov 2012, 03:28
Denn es muss ja einen Grund geben, warum properties vorgezogen werden.
Wie "himitsu" schon schrieb
Zitat:
und in Zukunft läßt sich der Zugriff naträglich noch ganz bequem regeln
kannst Du so später, ohne Deinen bestehenden Code großartig zu ändern, Kontrollen vornehmen.

Bspw. stellst Du später fest, dass sich der Wert einer Property nur innerhalb eines bestimmten Bereiches bewegen darf/soll, der übergebene String nicht leer sein soll, etc.pp. so brauchst Du das bestehende write FPropertyName nur in ein write SetPropertyName zu ändern und kannst dies dort, in dem dann hinzugefügtem Setter, implementieren statt, was zu fehlerträchtigen Codeduplizierungen führen würde, diese Einschränkung(en) beim Aufrufer sicherzustellen.
  Mit Zitat antworten Zitat
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.464 Beiträge
 
Delphi 12 Athens
 
#8

AW: TThread - property oder nicht?

  Alt 23. Nov 2012, 16:51
Insbesondere Thread-Klassen sind ein gutes Beispiel warum Properties benötigt werden.
Soll auf Variablen vom Hauptthreat und vom Thread der Klasse selbst zugegriffen werden,
ist z.B. eine TCriticalSection notwendig, damit es nicht zu Konflikten kommt.
Delphi-Quellcode:
type
  TMyThread = class(TThread)
    constructor Create;
    destructor Destroy; override;
  private
    FCS: TCriticalSection;
    FValue1: Integer;
    FValue2: string;
    function GetValue1: Integer;
    function GetValue2: string;
    procedure SetValue1(AValue: Integer);
    procedure SetValue2(AValue: string);
  public
    property CS: TCriticalSection read FCS;
    property Value1: Integer read GetValue1 write SetValue1;
    property Value2: string read GetValue2 write SetValue2;
    procedure ReadFromStream(AStream: TStream);
    procedure WriteToStream(AStream: TStream);
  end;

constructor TMyThread.Create;
begin
  inherited;
  FCS := TCriticalSection.Create;
end;

destructor TMyThread.Destroy;
begin
  FCS.Free;
  inherited;
end;

function TMyThread.GetValue1: Integer;
begin
  CS.Enter;
  try
    Result := FValue1;
  finally
    CS.Leave;
  end;
end;

function TMyThread.GetValue2: string;
begin
  CS.Enter;
  try
    Result := FValue2;
  finally
    CS.Leave;
  end;
end;

procedure TMyThread.SetValue1(AValue: Integer);
begin
  CS.Enter;
  try
    FValue1 := AValue;
  finally
    CS.Leave;
  end;
end;

procedure TMyThread.SetValue2(AValue: string);
begin
  CS.Enter;
  try
    FValue2 := AValue;
  finally
    CS.Leave;
  end;
end;

procedure TMyThread.ReadFromStream(AStream: TStream);
begin
  {Zugriffe anderer Threads sperren}
  CS.Enter;
  try
    {Value1 lesen} 
    {Value2 lesen} 
  finally
    CS.Leave;
  end;
  {Zugriffe von anderen Threads wieder frei}
end;

procedure TMyThread.WriteToStream(AStream: TStream);
begin
  {Zugriffe anderer Threads sperren}
  CS.Enter;
  try
    {Value1 speichern} 
    {Value2 speichern} 
  finally
    CS.Leave;
  end;
  {Zugriffe von anderen Threads wieder frei}
end;
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 09:38 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz