在处理Buisness类时,例如典型的客户和员工课程,最好仅使用Getters和Setter或使用属性?

我正在转化Delphi(用于自学习)中的一些OO示例中的一些OO示例,在这些示例中,总是有getName()和setName(),不使用属性。

现在,我可以看到,如果我创建具有已发布属性的组件,我有一个很好的理由使用属性,但是在正常类中,哪种方法更好?代码是否可以使用Getter和Setter(强调我们正在阅读/编写属性的事实)或属性(一见一见钟情可以与无参数方法混淆)更易读?

有帮助吗?

解决方案

不。Getters和Setter仅在Java中出现,因为它没有属性。它为使用属性提供了更干净的代码。然后,如果您需要Getter或Setter,则可以将其构建到该属性中,但是您不必使用一堆功能调用用访问代码。

其他提示

哇。属性比“他们只是为getter和setter方法包装”要多得多。

属性是一种优雅但功能强大的方法,可用于探索对课堂字段的控制。

访问字段

如前所述,您可以直接访问类字段。这确实非常好,并且使代码更清晰。这也是实现班级可行的第一版的非常好方法。

TMyClass = class
private
  FValue: String;
public
  property Value: String read FValue write FValue;
end; 

稍后,您可以重新设计课程以使用方法来验证和操纵字段访问。公共界面将仍然相同。

TMyClass = class
private
  FValue: String;
  procedure SetValue(AValue: String);
public
  property Value: String read FValue write SetValue;
end; 

procedure TMyClass.SetValue(AValue: String);
begin
  if AValue = '' 
  then FValue := 'No value!'
  else FValue := AValue;
end;

控制访问

属性为您提供了可读/写入字段的简单概述。例如,可读/不变的类:

TClient = class
private
  FName: String;
  FSite: String;
  FMail: String;
public
  constructor Create(AName, ASite, AMail: String);
  property Name: String read FName;
  property Site: String read FSite;
  property Mail: String read FMail;
end; 

多态性

TClient = class
private
  FName: String;
protected
  function GetName: String; virtual; abstract;
public
  property Name: String read GetName write FName;
end; 

TImportantClient = class(TClient)
protected
  function GetName: String; override;
end; 

TArgumentativeClient = class(TClient)
protected
  function GetName: String; override; 
end; 

function TImportantClient.GetName: String; 
begin
  Result := '+++ ' + FName;
end; 

function TArgumentativeClient.GetName: String; 
begin
  Result := ':-( ' + FName;
end; 

{----- ----- ----- ----- -----}
var
  ClientA,
  ClientB: TClient;
begin
  ClientA := TImportantClient.Create;
  ClientB := TArgumentativeClient.Create;

  ClientA.Name := 'Mr. Nice';
  ClientB.Name := 'Mr. Dumbhead';

  ShowMessage(ClientA.Name);
  ShowMessage(ClientB.Name);
end;
{----- ----- ----- ----- -----}

默认属性

在您的课程中,您可以定义默认类字段,这意味着您可以直接访问该字段而无需指定属性名称。

A := MyStringList[i]:
MyStringList[i] := B;

{ instead of }

A := MyStringList.Strings[i];
MyStringList.Strings[i] := B;

{ or }

A := MyStringList.GetString(i);
MyStringList.SetString(i, B);

指数

Index 关键字,Delphi将将常数值作为参数传递给Getter/Setter方法。

TMyRect = class
private
  FValues: Array[0..3] of Integer;
  function GetProperty(Index: Integer): Integer;
public
  property Top    : Integer  Index 0  read GetProperty;
  property Left   : Integer  Index 1  read GetProperty;
  property Width  : Integer  Index 2  read GetProperty;
  property Height : Integer  Index 3  read GetProperty;
end;


function TMyRect.GetProperty(Index: Integer): Integer;
begin
  Result := FValues[Index];
end; 

一些资源

仍然有一些涵盖的主题(实现接口,存储的值,RTTI/Design Time属性等),但是这篇文章开始越来越长...

可以在这些网站上阅读更多内容:

属性是Delphi的重要优势。我自己做了很多Java和Delphi,肯定会属于财产。实际上,两种方法最终都会做同样的事情,唯一的区别是,属性看起来比Getters/setters更加整洁。

我建议您获得财产,并充分利用它们!

这确实是一种口味和使用问题。

对于像程序员这样的Pascal,很明显,您是否正在阅读或编写一个值,因此我认为,如果您不以Java的方式使用getxxx或setxxx,则代码更可读您的程序。

对我而言,我假设大多数Pascal程序员,如果您只包含您正在阅读/写作的属性名称,则代码更可读,我们都知道将调用Getter或Setter方法(如有必要) 。

另外,我认为这是Delphi属性模型的巨大好处(和优雅),您可以直接从字段获得/设置属性值,以使用仅使用该值的代码行的许多GET/设置方法从字段分配或阅读的是浪费时间/时间。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top