zoukankan      html  css  js  c++  java
  • 翻箱倒柜,《Delphi中建议使用的语句》

    (*//
    标题:Delphi中建议使用的语句
    整理:Zswang
    连接:http://www.csdn.net/Expert/TopicView1.asp?id=724036
    日期:2002-06-22
    支持:wjhu111#21cn.com
    //*)

    { No.1 判断逻辑类型 }
    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;

    { 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.Fieldvalues['姓名'] := Edit1.Text; //Borland建议的方法。以及ParamValues[]
      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 利用MaxInt常量 }
    begin
      Caption := Copy(Edit1.Text, 3, Length(Edit1.Text) - 3 + 1); //不建议
      ///////
      Caption := Copy(Edit1.Text, 3, MaxInt); //建议//嘻嘻,少计算一次
    end;

    { No.11 Result函数指针 }
    function FuncName: Boolean;
    begin
      FuncName := True; //不建议//并且放在赋值号右边不能当普通变量
      ///////
      Result := True; //建议//扩充性好
    end;

    function FuncSum(A: array of Integer): Integer;
    var I: Integer;
    begin
      Result := 0;
      for I := Low(A) to High(A) do
        Result := Result + A[I]; //可不能用 FuncSum := FuncSum + A[I];
    end;

    { No.12 必须执行的代码、使用try ... finally ... end语句 }
    var
      vStringList: TStringList;
    begin
      vStringList := TStringList.Create;
      vStringList.LoadFromFile('c: emp.txt');
      ShowMessage(vStringList.Text);
      vStringList.Free; //不建议//如果出现异常资源将无法释放
      ///////
      vStringList := TStringList.Create;
      try
        vStringList.LoadFromFile('c: emp.txt');
        ShowMessage(vStringList.Text);
      finally //建议//即使出现Exit都会执行
        vStringList.Free;
      end;
    end;

    //其他情况1
    begin
      Screen.Cursor := crHourGlass;
      try
      { 耗时操作 }
      finally
      Screen.Cursor := crDefault;
      end;
    end;
    //其他情况2
    begin
      Query1.DisableControls;
      try
      { 操作数据集 }
      finally
        Query1.EnableControls;
      end;
    end;

  • 相关阅读:
    sql
    Java后台通过传参得到对应的坐标值的方法
    运行第一个大型项目工程时出现的问题
    对sqlserver存储过程合游标循环中的一点心得
    (基于Java)算法之动态规划——矩阵连乘问题
    算法之线性时间选择(最坏情况下)
    算法之快速排序
    算法之合并排序
    算法之二分搜索法
    设计模式之装饰者模式
  • 原文地址:https://www.cnblogs.com/wwsuhyuan/p/3525743.html
Copyright © 2011-2022 走看看