delphi6常用快捷键及惯用法

本文分享了Delphi编程中的实用快捷键及代码编写建议,包括窗口切换、代码编辑、对象检查等功能键,以及提高代码效率和质量的实用编程技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

常用快捷键
1. F12 窗口与代码编辑器的切换
2. F11 显示Object Inspector
3. Ctrl+上下箭头 在过程声明和实现间切换
4. Ctrl+Shift+C 按当前过程声明自动生成实现头
5. Ctrl+Shift+U 选中代码左偏移
6. Ctrl+Shift+I 选中代码右偏移
7. Ctrl+Backspace 删除一个单词
8. Ctrl+Alt+鼠标选取 以列块方式选择
9. F3,Ctrl+F 查找
10. Ctrl+R 替换
11. Alt+左右箭头 返回前一个或后一个视图
12. Ctrl+鼠标左键 转到指定的单元文件或过程声明
13.Ctrl+Alt+S 函数调用堆栈
使用建议
No.1简短判断逻辑类型
No.2临时SQL查询使用完后就关闭
No.3使用Count函数获取记录数
No.4 字段赋值使用名称索引
No.5使用self指针
No.6以not Eof判断遍历数据集
No.7利用Sender参数,使代码通用
No.8 使用默认转换函数
No.9 遍历数组使用Low,High函数
No.12 必须执行的代码、使用try ... finally ... end语句 
                                             Delphi中建议使用的语句 
 
{ 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:/temp.txt'');
ShowMessage(vStringList.Text);
vStringList.Free; //不建议//如果出现异常资源将无法释放
///////
vStringList := TStringList.Create;
try
vStringList.LoadFromFile(''c:/temp.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;
  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值