Format 函数
Delphi 支持“开参数”和动态数组,变体数组,使用时的语法类似 Delphi 中的集合:采用两个方括号把不同类型的变量括起来(这太方便了啊),也可以采用声明一个 TVarRec 类型的数组来容纳不同的类型变量(具体请参阅其帮助文档)
Format函数声明比较
function Format(const Format: string; const Args: array of const): string; overload;
extern DELPHI_PACKAGE UnicodeString __fastcall Format(const UnicodeString Format, TVarRec const *Args, const int Args_High)/* overload */;
C++Builder 中,没有像 Delphi 中的那中语法特性,BCB 中的 Format 函数其第一个参数与 Delphi 的 Format
是类似的(一个格式化描述字符串),而后面有两个参数,第二个参数是一个 TVarRec
类型的数组指针,第三个参数是这个数组的最后一个元素的索引值!因为 C++
不支持动态数组语法,也没有什么“开参数”之类的怪异特性,所以当你传递数组时,你必须同时传递数组的大小(Format
要求的是数组的最后一个元素的索引值,因此大同小异)。刚才我说过,在 Delphi 中也可以用 TVarRec
数组代替方括号的方法,其实本质是一样的。当然了,在 C++Builder 中,我们没有必要在每次使用 Format 函数时都先声明一个
TVarRec 数组,然后再把要用于输出的变量赋给 TvarRec 数组的每一个元素,最后还要传递 TVarRec
数组的最后元素索引。其实,我们可以使用一个 C++Builder 预先声明好的宏 ARRAYOFCONST,直接传入要格式化输出的变量
C++builder中的Format函数ARRAYOFCONST参数
Format( "My name is %s, I'm %d years old.", ARRAYOFCONST(("Phoenix2000", 22)) ); //注意两个括号
FDQuery1.Open函数声明比较
procedure TFDRdbmsDataSet.Open(const ASQL: String; const AParams: array of Variant);
FDQuery1.Open('select * from tt where id=:id',[0]);
HIDESBASE void __fastcall Open(const UnicodeString ASQL, Variant const *AParams, const int AParams_High)/* overload */;
Variant locvalues[1];
locvalues[0] = Variant("01");
FDQuery1->Open("select * from table where id=:id", locvalues, 0);
TCustomDataSet.Locate函数声明比较
Delphi
function Locate(const KeyFields: string; const KeyValues: Variant; Options: TLocateOptions): Boolean; override;
CustTable.Locate('Company;Contact;Phone', VarArrayOf(['Sight Diver', 'P', '408-431-1000']), [loPartialKey]);
CustTable.Locate('ID', 1001, []);
C++
virtual bool __fastcall Locate(const UnicodeString KeyFields, const Variant &KeyValues, TLocateOptions Options);
三个字段搜索
TLocateOptions Opts; Variant locvalues[3]; locvalues[0] = Variant("Sight Diver"); locvalues[1] = Variant("P"); locvalues[2] = Variant("408-431-1000"); CustTable->Locate("Company;Contact;Phone", VarArrayOf(locvalues, 2), Opts);
二个字段搜索
Variant locvalues[2]; locvalues[0] = Variant("Sight Diver"); locvalues[1] = Variant("P"); CustTable->Locate("Company;Contact", VarArrayOf(locvalues, 1), TLocateOptions());
一个字段搜索
FDMemTable1->Locate("fieldName", strVar, TLocateOptions());
TLocateOptions ()<<loCaseInsensitive
if (ds1->LocateEx("DM", "001", TFDDataSetLocateOptions() << lxoCheckOnly))