• Delphi中建议使用的语句


    No.1 利用MaxInt常量

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


    No.2 临时SQL查询

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    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 获取记录数

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    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 字段赋值

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

    No.5 使用Self指针

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

    No.6 遍历数据集

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    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参数,使代码通用

    1
    2
    3
    4
    5
    6
    7
    8
    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 使用默认转换函数

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

    No.9 遍历数组

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    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 判断逻辑类型

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    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.11 用FreeAndNil来释放对象

    使用前不用判断对象是否为空
    使用后,Assigned对象为空


  • 相关阅读:
    pandas DataFrame 数据处理常用操作
    host文件配置 了解
    安装Spring+搭建Spring开发环境
    java 环境配置 maven 环境配置
    Hive SQL 常见问题(转载)
    小结
    SQL 将两个结构相同的表合并到成一个表
    用户画像--初步了解
    hive 提取用户第一次浏览/购买 某商品的 时间
    ES2017 keys,values,entries使用
  • 原文地址:https://www.cnblogs.com/hssbsw/p/2389183.html
Copyright © 2020-2023  润新知