Delphi中建议使用的语句

No.1 利用MaxInt常量

begin
  Caption := Copy(Edit1.Text, 3, Length(Edit1.Text) - 3 + 1); //不建议
//----
  Caption := Copy(Edit1.Text, 3, MaxInt); //建议//嘻嘻,少计算一次
end;

No.2 临时SQL查询

begin
  QueryTemp.Close;
  QueryTemp.SQL.Text := 'Select SUM(金额) AS 合计 FROM 销售表';
  QueryTemp.Open; //不建议//数据没有关闭造成资源浪费
  ShowMessage(Query1.FieldByName('合计').AsString);
//---
  QueryTemp.SQL.Text := 'Select SUM(金额) AS 合计 FROM 销售表';
  QueryTemp.Open;
  ShowMessage(Query1.FieldByName('合计').AsString);
  QueryTemp.Close; //建议用//使用完就关闭
end;

No.3 获取记录数

var
  vRecordCount: Integer;
begin
  Query1.SQL.Text := 'Select * FROM Table1'; //不建议
//严重浪费资源,会取得很多不必要得信息
 Query1.Open;
  vRecordCount := Query1.RecordCount;
  Query1.Close;
//--
  Query1.SQL.Text := 'Select COUNT(*) AS 记录数 FROM Table1'; //建议
//快速有效、只处理一条记录
  Query1.Open;
  vRecordCount := Query1.FieldByName('记录数').AsInteger;
  Query1.Close;

  ShowMessage(IntToStr(vRecordCount));
end;

No.4 字段赋值

begin
  Table1.Edit;
  Table1.FieldByName('姓名').AsString := Edit1.Text; //不建议
  Table1.FieldByName('日期').AsDateTime := Date;
//---
  Table1['姓名'] := Edit1.Text; //建议//简短、扩充性好
  Table1['日期'] := Date;
end;

No.5 使用Self指针

begin
  Edit1.Parent := Form1; //不建议//Form1只是一个变量
//如果没有分配资源怎么办?
//---
  Edit1.Parent := Self; //建议
end;

No.6 遍历数据集

var
  I: Integer;
begin
  Query1.First;
  for I := 0 to Query1.RecordCount - 1 do begin //不建议
//容易被影响
    Query1.Next;
{};
  end;
//---
  Query1.First;
  while not Query1.Eof do begin //建议
{ }
    Query1.Next;
  end;
end;

No.7 利用Sender参数,使代码通用

procedure TForm1.Edit1Change(Sender: TObject);
  begin
    if Edit1.Text = '' then //不建议
      Edit1.Color := clRed;
//---
    if TEdit(Sender).Text = '' then //建议//复制到EditXChange中很方便
      TEdit(Sender).Color := clRed;
  end;

No.8 使用默认转换函数

var
  I: Integer;
begin
  I := StrToInt(Edit1.Text); //不建议
//---
  I := StrToIntDef(Edit1.Text, 0); //建议
//参考StrToFloatDef,StrToDateDef....不过这些只有Delphi6才有
end;

No.9 遍历数组

var
  I: Integer;
  A: array[0..9] of Integer;
begin
  for I := 0 to 9 do //不建议
    A[I] := I;
//---
  for I := Low(A) to High(A) do //建议//扩充性好
    A[I] := I;
end;

No.10 判断逻辑类型

var B: Boolean;
begin
  B := Boolean(2); //这样只是为了调试//B := True;
  if B = True then ShowMessage('B = True'); //不建议//不安全
//---
  if B then ShowMessage('B'); //建议//简短
end;

var B: Boolean;
begin
  if Edit1.Text = '是' then //不建议//烦琐
    B := True
  else B := False;
//---
  B := Edit1.Text = '是'; //建议//简短
end;