当前位置: 首页 > news >正文

delphi关键字

delphi关键字

 

转自:http://www.cnblogs.com/zengyou/p/5842909.html 

absolute:

1
2
3
4
5
6
7
8
9
10
//它使得你能够创建一个新变量, 并且该变量的起始地址与另一个变量相同.
var
  Str: string [ 32 ];
  StrLen: Byte absoluteStr;
//这个声明指定了变量StrLen起始地址与Str相同.
//由于字符串的第0个位置保存了字符串的长度, 所以StrLen的值即字符串长度.
begin
Str := 'abc' ;
Edit1 . Text := IntToStr(StrLen);
end ;

abstract:

1
2
3
4
5
6
7
8
9
10
11
12
13
//它允许你创建抽象的方法, 包括有抽象方法的类称为抽象类.
//Abstract关键字必须与Virtual或Dynamic关键字同时使用, 因为抽象方法必须被覆盖式实现.
//抽象类不能实例化, 抽象方法不能包含方法体.
type
  TDemo = class
   private
   protected
    procedure X; virtual; abstract;
   public
    constructor Create;
    destructor Destroy; override;
   published
  end ;

and:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
//一、表示逻辑与
if (a> 0 ) and (b> 0 ) then
//二、表示位运算
var
a,b,c: Integer ;
begin
c := (a and b);
end ;
//使用And表示逻辑时, And左右的表达式必须用小括号括起, 以避免以生条件的冲突.
//例如:
if a> 0 and b> 0 then
//编译器可能会理解为:
if a>( 0 and b)> 0 then
//或:
if (a> 0 ) and (b> 0 ) then
//但是实际编译时, 编译器会产生一个冲突, 报告错误.
//并且第一种可能包含了a>b>c的形式, 这在Delphi中不被支持.
//所以使用And运算符时必须使用括号, 以区分左右的条件.
//表示位运算时也必须加上括号, 将And以及左右参数括起.

array:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
//Array用于表示数组, 任何的对象都能被声明成数组.数组分为静态和动态的2种.
//静态数组
var
Arr1: array [ 1..10 ] of Integer ;
 
//动态数组, 由于声明时不知其元素个数, 所以必须在后期用SetLength方法设置数组的大小
var
Arr2: array of Integer ;
 
//数组作为参数时, 不能传入数组的大小, 只能传入数组名, 然后用Length方法获取数组的元素个数
function X(A: array of Integer ): Integer ;
var
i: Integer ;
begin
Result := 0 ;
for i := 0 to Length(A)- 1 do
Result := Result + A[i];
end ;

as:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
//As用于将一个对象转换为另一个对象
procedure BtnClick(Sender:TObject);
begin
  (Sender as TButton).Caption := 'Clicked' ;
end ;
//对于对象填充接口的转换, 必须用As进行
(HTTPRIO as IExp).GetConnection;
 
//As不能用于数据类型的转换, 下面的代码是错误的:
var
i: Integer ;
s: string ;
begin
s := (i as string );
end ;
//正确写法是:
s := string (i);

asm:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
//Asm关键字用于插入汇编代码, 使用汇编代码时, 必须使用asm...end;的结构, 而非begin...end;
function IntToHex(Value: Integer ; Digits: Integer ): string ;
asm
  CMP EDX, 32
  JBE @A1
  xor EDX, EDX
  @A1: PUSH ESI
  MOV ESI, ESP
  SUB ESP, 32
  PUSH ECX
  MOV ECX, 16
  CALL CvtInt
  MOV EDX, ESI
  POP EAX
  CALL System.@LStrFromPCharLen
  ADD ESP, 32
  POP ESI
end ;

assembler:

1
2
3
//Assembler关键字用于支持早期的汇编, 如80386等.
//它和Asm的区别:Asm允许使用Win32汇编, 而Assembler只允许80x86汇编, 它不允许Invoke语句的出现.
function IntToHex(AValue: Int64 ): string ; assembler;

automated:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//Automated访问区分符用于描述一个自动类型的成员, 它能够使程序的版本向下兼容.
//ComObj单元内的成员及其实例不能使用Automated访问区分符.
type
  TDemo = class
   automated
    Str: WideString ;
  end ;
//在程序的下一个版本中, 将Str做了修改, 变成
type
TDemo = class
automated
Str: AnsiString ;
end
//则新版本的Str变量能够接受旧版本的WideString型数据, 并自动转换成AnsiString.
//在实际开发中, 如果没有特殊的需要, 一般不用automated访问区分符.

begin:

1
2
3
4
5
6
7
8
9
10
11
//begin关键字用于表示一段程序或一个结构的开始, 必须用end关键字来结束.
procedure X;
begin
  ShowMessage( 'A Demo' );
end ;
//一般的结构, 如If, For, While等也需要用begin关键字来标出结构起始点
for i:= 1 to 100 do
begin
sum := sum + i;
if sum > 1000 then Break;
end ;

case:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
//Case语句用于完成条件选择, Case语句的的被选择对象必须是有序类型, 包括整型, 枚举类型, 字符型等.
//Case语句必须由end结束,如果没有相符合的选择项, 可以加入else来作出通用选择.
function GetDays(AYear,AMonth: Integer ): Integer ;
begin
  case AMonth of
   1 , 3 , 5 , 7 , 8 , 10 , 12 : Result := 31 ;
   4 , 6 , 9 , 11 : Result := 30 ;
   2 : begin
   if IsLeapYear(AYear) then
    Result:= 29
   else
    Result:= 28 ;
   end ;
  else
   Result:= 0 ;
end ;

cdecl

1
2
3
4
5
6
7
8
9
//Cdecl是函数调用协定的一种, 它规定了从C或C++编写的DLL中调用函数所必须遵守的规则.
//它可以将C或C++中的数据类型转换为Delphi的.
//例如C++中的代码:
int X(int i)
{
  return i*2;
}
//这个函数被编译在Demo.dll中, 用Delphi调用时必须使用:
function X(i: Integer ): Integer ; Cdecl; external 'Demo.dll' ;

class:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
//Class关键字用于声明或继承一个类, 也可以使类和接口同时继承.
//另外, Class关键字也能用于声明类通用方法, 使得父类可以从类内访问子类的方法.
type
  ClassDemo = class (TObject)
   private
   public
    constructor Create;
  end ;
//如果用class声明方法, 则该方法在类与相关类中都可以使用, 譬如:
type
ClassA = class
private
public
procedure Y;
end ;
 
type
ClassB = class (ClassA)
private
public
class procedure X;
end ;
//则在使用时ClassA能够直接访问ClassB的X方法
procedure ClassA . Y;
begin
Self . X;
end ;
//此时父类将子类的class方法作为自身的方法进行调用.

const:

1
2
3
4
5
6
7
8
//Const关键字用于声明常量, 使用const声明的数据将不能在程序中被改变.
//也可以用来声明函数参数, 用const指定的参数不允许在函数中改变.
const MyFileName = 'Delphi' ;
const MyInteger = 100 ;
//用Const声明常量不需要指出其数据类型, 系统会自动判断类型, 并作自动调整.
//函数中可以用const声明不可更改的参数
function X( const i: Integer ): string ;
//此时在函数操作过程中, i的值不可改变.

constructor:

1
2
3
4
5
6
7
8
9
10
11
12
13
//constructor关键字用来声明一个类的构造函数, 当类被实例化时, 首先调用此函数
//构造函数一般用Create表示, Create方法能够连带类中存在的CreateWnd方法.
type
  ClassDemo = class (TObject)
   private
    fValue: Integer ;
   public
    constructor Create;
  end ;
constructor ClassDemo . Create;
begin
fValue := 0 ;
end ;

contains:

1
2
3
4
5
6
7
8
//Contains关键字指出了某个包(Package)是否包含某个文件.
//用Contains引入的文件必须被添加到包文件中, 它可以避免关键文件的引用丢失.
package DATAX;
  requires
   rtl, clx;
  contains
   Db, DBLocal, DBXpress;
end .

default:

1
2
3
4
5
6
7
8
9
10
11
//Default关键字用于指出一个属性的默认值
//只有有序类型的属性才允许默认值的存在, 否则必须在构造函数中初始化属性值.
type
  ClassDemo = class
   private
    fValue: Integer ;
   published
    property Value: Integer read fValue write fValue default 0 ;
  end ;
//它也可以指出一个类的默认属性
property strings[Index: Integer ]: string read GetString write PutString; Default;

destructor:

1
2
3
4
5
6
7
8
9
10
//Destructor用于标识析构函数, 析构函数在类被释放时自动调用.
//析构函数只允许覆盖, 再不允许重载.析构函数通常用Destroy作为函数名.
type
  ClassDemo = class (TComponent)
   public
    destructor Destroy;override;
  end ;
//由于TComponent类中也有Destroy方法, 所以要将其重写
//但是若要重载析构函数, 则不允许, 下面代码是错误的:
destructor Destroy; overload;

dispid:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//DispId关键字被用在DispInterface接口中, 用于指定特定的适配序号.
//在DispInterface接口中, 适配序号必须是唯一的,
//如果不指定DispId, 则系统会自动分配适配序号给接口内每一个方法.
//可以通过适配序号访问DispInterface接口中的方法.
type
  IStringsDisp = dispinterface
   [ '{EE05DFE2-5549-11D0-9EA9-0020AF3D82DA}' ]
   property ControlDefault[Index: Integer ]: Olevariant dispid 0 ; default;
   function Count: Integer ; dispid 1 ;
   property Item[Index: Integer ]: Olevariant dispid 2 ;
   procedure Remove(Index: Integer ); dispid 3 ;
   procedure Clear; dispid 4 ;
   function Add(Item: Olevariant): Integer ; dispid 5 ;
   function _NewEnum: IUnknown; dispid - 4 ;
  end ;

dispinterface:

1
2
3
4
5
6
7
//DispInterface用于声明一个特定的适配器接口, 这个适配器能够接受标准系统接口中传入传出的数据.
//用DispInterface声明的接口不能被继承, 只能够被引用.
//DispInterface中方法只能调用, 并且必须被动态绑定.
//可以通过DispId为接口内方汉分配适配序号.
//DispInterface仅能用于Windows平台, 如果在Linux下进行开发, 则此关键字会自动被系统屏蔽.
//通常情况下, 不使用DispInterface.
//实例请参见DispId

div:

1
2
3
4
5
6
7
//Div用于求两数之整数商.用于Div运算的两个数值必须均为整型, 其运算结果也为整型.
var
  a,b,c: Integer ;
begin
  a := 20 ; b := 3 ;
  c := a div b; {6}
end ;

do:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
//Do关键字用于For, While, On, With语句, 构成特定的结构
//For语句:
for i := 1 to 100 do sum:=sum+i;
 
//While语句:
while i < 100 do
begin
 sum := sum + i;
 Inc(i);
end ;
 
//On语句(异常处理):
try
 i := StrToInt(s);
except
  on exception do ShowMessage( 'Error!' );
end ;
 
//With语句:
with Memo1 . Lines do
begin
 Clear;
 Append( 'abc' );
 Append( '123' );
end ;

downto:

1
2
3
4
//DownTo关键字用于For语句, 指明循环变量是递减的.
for i := 100 downto 1 do
ListBox1 . Items . Add(IntToStr(i));
//在For语句中, 循环变量递增用To关键字, 递减用DownTo关键字.

dynamic:

1
2
3
//Dynamic用于声明一个动态的方法,
//动态方法可以被覆盖, 并且可以使代码大小尽可能的减少(区别于Virtual).
procedure X(i: Integer ); dynamic;

else:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
//else用于引导程序的运行方向, 它可以与If, Case和On语句联用, 当条件不满足时, 转到else下运行
//If语句(在If语句中, else前不允许有分号):
if a > b then
c := a
else
c:=b;
 
//Case语句:
case Tag Of
1 :Result:= 1 ;
2 :Result:= 2 ;
3 :Result:= 3 ;
else
Result:= 0 ;
end ;
 
//On语句(异常处理):
try
i := StrToInt(s);
Excpet
on EZeroDivide do Result := 1 ;
on EOverflow do Result := 2 ;
else
Result := 0 ;
end ;

end:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
//End用于结束一个语句块或是一个单元.
//它可以与begin, Case, Class, Interface, Asm, Unit, Package等相匹配.
//对于语句块(局部结束), End后必须添加分号.
//而对于单元或包(全局结束), end后必须添加句号.
//在If语句中else关键字前的End后不允许添加符号.
procedure X;
begin
  with Button1 do
  begin
   if Button1 . ShowHint then
   Button1 . Caption := 'Hinted'
   else
   Button1 . Caption := 'Not Hinted' ;
  end ;
end ;
//在包内使用End来结束:
package DATAX;
requires
rtl,
clx;
contains Db, DBLocal, DBXpress;
end .

except:

1
2
3
4
5
6
//except关键字用于异常处理, 必须用在try语句内, 如果发生异常, 则执行except后的语句
try
  i := StrToInt(s);
except
  ShowMessage( 'Error!' );
end ;

export:

1
2
3
4
5
//Export标明了函数调用协定, 指出函数可以被输出, 输出的函数能被本地或远程调用.
//其他程序可以用dll的形式调用程序内的函数.它是向下兼容的.
function Add(a,b: Integer ): Integer ; export;
//如果这个程序被编译为Demo.exe, 并且另一个程序需要调用这个函数, 可以使用以下语句
function Add(a,b: Integer ): Integer ; stdcall; external 'Demo.exe' ;

exports:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
//exports用于输出对象, 它必须被用在接口和实现之间, 可以同时输出多个项, 项与项之间用逗号分开.
libraryDemo;
function X(i: Integer ): string ; stdcall;
begin
 Result:=IntToStr(i);
end ;
 
exports
 X;
 
begin
end .
 
//如果输出的对象被重载, 则必须给对象起个别名, 并注明参数.
library Demo;
 
function X(i: Integer ): string ; overload; stdcall;
begin
 Result := IntToStr(i);
end ;
 
function X(s: string ): Integer ; overload; stdcall;
begin
 Result := StrToInt(s);
end ;
 
exports
X(i: Integer ) name 'x1' ,
X(s: string ) name 'x2' ;
 
begin
end .

external:

1
2
3
4
5
6
7
8
9
10
11
//External关键字用于引用一个外部的或是OBJ内的方法.
{$L Demo.OBJ}
procedure X(i: Integer );external;
//如果是从dll或外部程序中引用, 则可以使用以下代码:
function A(FileName: string ): string ; external 'Demo.dll' ;
 
//如果被引用的函数被重载, 则必须另外指出引用的名称.
function A(Name: string ): string ; overload; stdcall; external 'Demo.dll' name 'A1' ;
function A(Code: Integer ): string ; overload; stdcall; external 'Demo.dll' name 'A2' ;
 
//使用External关键字时, 必须注意大小写, 否则将出现错误.

far:

1
2
3
4
5
//Far标明了函数调用协定, 指出函数可以被远程调用.
//其他程序可以用dll的形式调用程序内的函数.它是向下兼容的.
functionAdd(a,b: Integer ): Integer ; Far;
//如果这个程序被编译为Demo.exe, 并且另一个处于其他计算机的程序需要调用这个函数, 可以使用以下语句:
function Add(a,b: Integer ): Integer ; stdcall; external 'Demo.exe' ;

file:

1
2
3
4
5
6
7
8
9
//File关键字指出了文件操作类型, 文件必须被声明为File,
//如果在File后追加Of和文件类型, 则文件可以被定义为读写指定类型数据.
type
  TPerson = record
   PName: string [ 32 ];
   PAge: Integer ;
  end ;
var
  PFile: file of TPerson;

finalization:

1
2
3
4
5
6
7
//finalization关键字标识了单元被释放时所要调用的方法,
//通常是释放掉单元中不能自动释放的对象, 也可以不用.
//finalization最常用的情况是对OLE对象做反初始化.
initialization
  ActiveX . OleInitialize( nil );
finalization
  ActiveX . OleUninitialize;

finally:

1
2
3
4
5
6
7
8
//finally关键字指出了异常处理中最后必须要调用的方法,
//不论是否发生异常, finally后的语句总是在try语句结束时执行.
try
  Node := Node . GetNext;
  Edit1 . Text := Node . Text;
finally
 Node := nil ;
end ;

for:

1
2
3
4
//For关键字引出For循环结构, 用于做指定次数的循环.
for i := 1 to 100 dosum := sum + i;
//如果循环变量是递减的, 则可以用DownTo关键字
for i := 100 downto 1 do Inc(sum);

forward:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//Forward关键字用于方法的前置定义.只定义方法声明, 然后在程序的后面对方法进行实现.
//这么做有利于代码的可读性, 可以将所有的声明放在一起, 然后将所有的实现也放在一起.
function X(i: Integer ): Integer ; forward;
procedure Y(s: string ); forward;
...
function X;
begin
  Result := i * 2 ;
end ;
procedure Y;
begin
WriteLn (s);
end ;
 
//用Forward前置声明的方法在实现时不需要再输入方法的参数和返回值, 直接使用方法名即可.

function:

1
2
3
4
5
6
7
//Function用于声明函数
functionX(i: Integer ): Integer ;
//它也可以用于动态函数的声明
type
 TFun = function (i: Integer ): Integer of object ;
 
//动态声明时, 不需要指出函数名, 只需要指出参数和返回类型就可以, 具体的函数名可以在后期绑定.

goto:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
//Goto语句用在跳转行号, 可以跳转到当前结构层内任意位置.
//必须在声明处用label关键字声明行号.
//由于Goto语句会破坏程序的结构, 不推荐使用.
var
 a,b: Integer ;
label
 X,Y;
begin
  if a > b then
   goto X
  else
   goto Y;
X:
  WriteLn ( 'a > b' );
Y:
  WriteLn ( 'b > a' );
end ;

if:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
//If关键字引出If条件语句, 用于对条件进行判断.
var
 a,b: Integer ;
begin
 a := 2 ; b := 3 ;
  if a>b then
   WriteLn ( 'a=' + IntToStr(a))
  else
   WriteLn ( 'b=' + IntToStr(b));
end ;
//If语句的通常结构是If...Then...else, else语句也可以不要.
//在If语句内如果有多个子语句, 则必须用begin...End结构进行区分.
if a > b then
begin
  WriteLn ( 'a>b' );
  WriteLn ( 'a=' + IntToStr(a));
  WriteLn ( 'b=' + IntToStr(b));
End
else
  WriteLn ( 'b>a' );

implementation:

1
2
3
4
5
6
7
8
9
10
//Implementation标识了单元中的实现部分, 单元的基本结构为:
//Unit...Interface...implementation...end.
//函数体, 过程体等必须写在implementation关键字后.
//如果在implementation后引用对象, 则对象是非公开的, 仅能供单元自身使用.
implementation
  uses frmAbout;
begin
  FormAbout . Show;
end ;
//一个完整的单元必须拥有implementation部分.

implements:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
//Implements指出了一个属性从接口继承, 此时属性被转换成接口对象.
//通过接口动态绑定属性, 并动态的设定属性值.
type
 IMyInterface = interface
   procedure P1;
   procedure P2;
  end ;
 TMyImplclass = class
   procedure P1;
   procedure P2;
  end ;
 TMyclass = class (TInterfacedObject, IMyInterface)
  FMyImplClass: TMyImplClass;
   property MyImplClass: TMyImplclass read FMyImplclass implements IMyInterface;
   procedure IMyInterface . P1 = MyP1;
   procedure MyP1;
  end ;
//通过implements声明后, 可以在类声明时指出接口中方法的实体, 如上例中的:
procedure IMyInterface . P1 = MyP1;

in:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
//In用于判断一个集合中是否包含某个元素.被判断的内容必须是单个集合元素和一个集合的实例.
type
 TCol = (cA,cB,cC);
 TCols = set of TCol;
var
 Cols: TCols;
begin
 Cols := [cA,cB];
  if cA in Cols then
  ShowMessage( 'cA in Cols' )
  else
  ShowMessage( 'cA not in Cols' );
end ;
//In也用于工程文件中, 用于标识某个文件是否被工程所引用.
Uses
 Unit1 in 'Unit1.pas' ;
 
//In可以被用在For语句中, 用于循环取出一个集合中的元素.
var
 s: string ;
 sl: TStringList;
begin
 ...
  for s In sl do
  begin
  ShowMessage(s);
  end ;
end ;

index:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
//Index用于在属性中标识序号, 以便用相同的属性方法(Get,Set)对不同的属性进行操作.
type
 TForm1 = class (TForm)
  private
   function GetInfo( const Index: Integer ): Longint ;
   procedure SetInfo( const Index: Integer ; const Value: Longint );
  public
   property iLeft: Longint index 0 read GetInfo write SetInfo;
   property iTop: Longint index 1 read GetInfo write SetInfo;
   property iWidth: Longint index 2 read GetInfo write SetInfo;
   property iHeight: Longint index 3 read GetInfo write SetInfo;
  end ;
function TForm1 . GetInfo( const Index: Integer ): Longint ;
begin
  case Index of
   0 : result := self . Left;
   1 : Result := self . Top;
   2 : result := self . Width;
   3 : result := self . Height;
  end ;
end ;
 
//Index关键字也用于在属性中指出多个元素, 例如:
property Selected[Index: Integer ]: Boolean read GetSelected write SetSelected;

inherited:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//Inherited用于调用父类的方法.
type
 TDemo = class (TComponent)
  public
   constructor Create(AOwner: TComponent); override;
  end ;
constructor TDemo . Create(AOwner: TComponent);
begin
  inherited Create(AOwner);
end ;
 
//如果调用的是与自身同名的方法, 则也可以省去方法名和参数.如上例中的
inherited Create(AOwner);
//可以改成:
Inherited ;

initialization:

1
2
3
4
5
6
7
//initialization关键字标识了单元被载入时所要调用的方法,
//通常是初始化一些不能自动初始化的对象, 也可以不用.
//initialization最常用的情况是对OLE对象做初始化.
initialization
  ActiveX . OleInitialize( nil );
finalization
  ActiveX . OleUninitialize;

inline:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
//InLine关键字用于Asm或assembler结构中,
//用于指出该汇编语句是向下兼容的.它对于程序的编译没有任何影响.
function IntToStr(Value: Integer ): string ;
asm
 InLine;
  PUSH ESI
  MOV  ESI, ESP
  SUB  ESP, 16
  xor  ECX, ECX
  PUSH EDX
  xor  EDX, EDX
  CALL CvtInt
  MOV  EDX, ESI
  POP  EAX
  CALL System.@LStrFromPCharLen
  ADD  ESP, 16
  POP  ESI
end ;

interface:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
//Interface标识了单元中的接口部分, 单元的基本结构为:
//Unit...Interface...implementation...end.
//函数, 过程等的声明必须写在Interface关键字后.
//如果在Interface后引用对象, 则对象是没有实例的, 使用时必须被实例化.
Interface
  uses frmAbout;
var
 FAbout: TFormAbout;
begin
 FAbout := TFormAbout . Create(Self);
 FAbout . Show;
end ;
//一个完整的单元必须拥有Interface部分.
 
//Interface也可以用作接口的声明.
type
 IMalloc = interface (IInterface)
 [ '{00000002-0000-0000-C000-000000000046}' ]
   function Alloc(Size: Integer ): Pointer ; stdcall;
   function Realloc(P: Pointer ; Size: Integer ): Pointer ; stdcall;
   procedure Free(P: Pointer ); stdcall;
   function GetSize(P: Pointer ): Integer ; stdcall;
   function DidAlloc(P: Pointer ): Integer ; stdcall;
   procedure HeapMinimize; stdcall;
  end ;

is:

1
2
3
4
5
6
7
8
//Is关键字用于对象的判断, 有某些情况下, 也可以作"As"使用.
var
  Comp : TComponent;
begin
  ...
  if Comp Is TEdit then
  ( Comp as TEdit).Text := 'Edit' ;
end ;

label:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//label关键字用于声明行号标签, 以便用Goto进行转向, 不推荐使用.
var
 a,b: Integer ;
label
 X,Y;
begin
  if a > b then
   goto X
  else
   goto Y;
X:
  WriteLn ( 'a>b' );
Y:
  WriteLn ( 'b>a' );
end ;

library:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
//Library关键字用于指出一个工程为类库.类库编译后生成DLL文件, 可被其他程序调用.
library Editors;
uses EdInit, EdInOut, EdFormat, EdPrint;
exports
  InitEditors,
  doneEditors name done,
  InsertText name Insert,
  DeleteSelection name Delete,
  FormatSelection,
  PrintSelection name Print,
  SetErrorHandler;
begin
  InitLibrary;
end .

message:

1
2
3
4
5
6
7
8
9
10
11
12
//Message关键字用于声明消息方法,
//带有Message的方法必须指出接收的消息类型, 并通过引用将消息传入方法中, 以便进行处理.
procedure Refresh( var Msg: TMessageRecordtype); messageID_REFRESH;
procedure Refresh( var Msg: TMessageRecordtype);
begin
if Chr(Msg . Code) = # 13 then
...
else
inherited ;
end ;
 
//用户可以自定义消息, 自定义消息也能够被Message接收, 并引发事件.

mod:

1
2
3
4
5
6
7
//Mod用于求两数之整数模, 即余数.用于Mod运算的两个数值必须均为整型, 其运算结果也为整型.
var
 a,b,c: Integer ;
begin
 a := 20 ; b := 3 ;
 c := a mod b; {2}
end ;

name:

 
1
2
3
4
5
//Name关键字用于指出方法的别名,
//对于一个要被外部引用的方法, 建议用Name申请方法别名, 以避免外部程序改动方法的实体内容.
//从外部引用一个方法时, 如果该方法有别名, 则必须用Name进行标识.
function MessageBox(HWnd: Integer ; Text, Caption: PChar ; Flags: Integer ): Integer ;
  stdcall; external 'user32.dll' name 'MessageBoxA' ;

near:

1
2
3
4
5
//Near标明了函数调用协定, 指出函数可以被本地调用.
//其他程序可以用dll的形式调用程序内的函数.它是向下兼容的.
function Add(a,b: Integer ): Integer ; near;
//如果这个程序被编译为Demo.exe, 并且另一个处于本地的程序需要调用这个函数, 可以使用以下语句:
function Add(a,b: Integer ): Integer ; stdcall; external 'Demo.exe' ;

nil:

 
1
2
3
4
5
6
//Nil用于表示一个空指针, 或是没有实例的对象.
while Node <> nil do
begin
 ListBox1 . Items . Add(Node . Text);
 Node := Node . GetNext;
end ;

nodefault:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//NoDefault关键字指出了一个属性不允许有默认值, 这通常用在继承中.
type
 TClassA = class
  private
  fValue: Integer ;
  published
   property Value: Integer read fValue write fValue default 0 ;
  end ;
 TClassB = class (TClassA)
  published
   property Value: Integer read fValue write fValue nodefault;
  end ;
 
//由上例可知, TClassA中的Value有默认值0,
//TClassB继承了TClassA, 所以也继承了其默认值, 在此用NoDefault去掉默认值

not:

 
1
2
3
4
5
6
7
8
9
//Not用于取反, 它否定了原先的结果.例如:
if a > b then
//可以写成:
if not (a < b) then
//Not关键字通常用于切换Boolean型的属性
procedure Button1Click(Sender: TObject);
begin
 StatusBar1 . Visible := not StatusBar1 . Visible;
end ;

object:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
//Object用于声明一个对象, 这个对象可以是任意的, 并且向下兼容.Object只能被Object所继承.
//声明对象的方法与声明类的方法是相同的.
type
 ODemoA = object
  end ;
 ODemoB = object (ODemoA)
  end ;
 
//Object关键字还用于声明动态函数或过程, 例如:
type
 TMyFun = function (i: Integer ): Integer of Object ;
 TMyProc = procedure (s: string ) of object ;
 
//经过object声明的函数或过程可以被动态的绑定到指定的函数体, 或是绑定到控件是事件中.

of:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
//Of关键用于和其他关键字构成指定的结构.Of可以与Case, Class, Array, File, Set, Object连用.
//Case语句:
case Tag Of
  0 : Result := 'a' ;
  1 : Result := 'b' ;
end ;
 
//Class语句:
type
 TDemo = class of TComponent;
 
//Array结构:
var
 MyInt: array of Integer ;
 
//File结构:
var
 MyFile: file of Byte ;
 
//Set语句:
type
 TCol = (cA,cB,cC);
 TCols = set of TCol;
 
//Object结构:
type
 MyFun = function (I: Integer ): Integer of Object ;

on:

 
1
2
3
4
5
6
7
//On关键字用于异常处理, 指出发生的异常, 并获取异常信息.
try
 i := StrToInt(s);
except
  on E: exception do
  ShowMessage(E . Message);
end ;

or:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
//一、表示逻辑或
if (a> 0 ) or (b> 0 ) then
//二、表示位运算
var
a,b,c: Integer ;
begin
c := (a or b);
end ;
 
//使用Or表示逻辑时, Or左右的表达式必须用小括号括起, 以避免以生条件的冲突
//如果在条件语句中使用 Or, 则编辑器不知道用户使用Or做什么
例如:
if a> 0 or b> 0 then
//编译器可能会理解为:
if a>( 0 or b)> 0 then
//或者
if (a> 0 ) or (b> 0 ) then
//但是实际编译时, 编译器会产生一个冲突, 报告错误
//并且第一种可能包含了a>b>c的形式, 这在Delphi中不被支持
//所以使用Or运算符时必须使用括号, 以区分左右的条件.
//表示位运算时也必须加上括号, 将Or以及左右参数括起.

out:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
//Out关键字说明了方法参数的输出方式, 一般的函数只能有一个返回值,
//使用Out可以在一个函数中返回多个结果.
//Out和var不同, Out是以返回值的形式进行参数返回, 而var是直接输入一个参数的地址.
procedure X(out i: Integer ; out s: string );
begin
 i := i * 2 ;
 s := s + 'abc' ;
end ;
procedure TForm1 . Button1Click(Sender: TObject);
var
 i: Integer ;
 s: string ;
begin
 i := 20 ;
 s := 'xxx' ;
 X(i,s);
end ;

overload:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
//Overload关键字指出了用于重载的方法, 重载即方法名相同,
//但是参数数量, 类型或顺序不同, 满足此条件的构成重载.
function X(i: Integer ): string ; overload;
function X(s: string ): string ; overload;
//从父类继承时, 如果子类拥有和父类相同的方法, 则也必须用overload构成重载,
//但是此类重载也必须满足重载的要求.
type
 TDemo = class (TComponent)
  public
   procedure CreateWnd(AOwner: TWinControl); overload;
  end ;
 
//如上例, 子类拥有的方法为:
procedure CreateWnd; {继承自父类}
procedure CreateWnd(AOwner: TWinControl); {子类声明}
//共两个CreateWnd方法.
 
//如果不使用重载, 则在子类中可以覆盖父类的方法.

override:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
//Override用于覆盖一个Virtual或是Dynamic形式的方法.
//覆盖时必须沿用被覆盖方法的声明, 并且不允许修改原方法的参数和返回类型.
procedure Create(AOwner: TComponent); override;
//Override多用于继承, 用子类覆盖掉父类的方法.
type
 TClassA = class
   procedure X; virtual;
  end ;
 
 TClassB = class (TClassA)
   procedure X; override;
  end ;
 
//如上例, 子类拥有的方法为:
procedure X; {从父类覆盖}
//父类拥有的方法为:
procedure X; {父类自身方法, 未被覆盖}
 
//如果父类的方法未用Virtual或Dynamic声明,
//或是有修改参数的需要, 则必须用Reintroduce关键字进行覆盖.

package:

 
1
2
3
4
5
6
7
8
9
//Package关键字用于指出一个工程为控件库.
//控件库编译后生成BPL文件, 可被安装到Delphi的控件库中, 从而在以后的开发中使用控件.
package DATAX;
  requires
   rtl,
   clx;
  contains
   MyUnit in 'C:\MyProject\MyUnit.pas' ;
end .

packed:

 
1
2
3
4
5
6
7
//Packed关键字用于对结构体记录或数组进行打包, 打包后被打包对象的体积能显著减小.
type
 TPerson = packed Record
  PName: string [ 32 ];
  PAge: Integer ;
  end ;
 MyArray: packed array of PChar ;

pascal:

 
1
2
3
4
5
6
7
//Pascal标明了函数调用协定,
//指出函数在调用时遵循Pascal原因, 即先对所有的变量进行初始化,
//避免因异步线程调用而产生的错误.它是向下兼容的.
function X(i: Integer ): Integer ; Pascal;
begin
 Result := i * 2 ;
end ;

private:

 
1
//Private标明了类内元素的访问区分权限, 被Private区分的元素只能被本类内部访问.

procedure:

 
1
2
3
4
5
6
7
//Procedure用于声明过程
procedureX(i: Integer );
//它也可以用于动态函数的声明
type
 TProc = procedure (i: Integer ) of object ;
 
//动态声明时, 不需要指出过程名, 只需要指出参数就可以, 具体的过程名可以在后期绑定.

program:

1
2
3
4
5
6
7
8
9
10
11
//Program关键字用于指出一个工程为应用程序.控件库编译后生成exe文件, 可以直接执行
program Project1;
uses
  Forms,
  Unit1 in 'Unit1.pas' ;
{$R *.res}
begin
  Application . Initialize;
  Application . CreateForm(TForm1, Form1);
  Application . Run;
end .

property:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
//Property关键字用于声明属性, 属性分为显式属性和隐式属性两种,
//只有声明在published访问区分符下的属性才是显式属性, 可以直接在对象查看器中查看.
type
 TDemo = class
  Private
  fValue: Integr;
  Published
   property Value: Integer read fValue write fValue;
  end ;
//事件也是属性的一种, 可以在published区分符下用Property进行声明
type
 TOnTextChange= procedure (Sender: TObject) of object ;
 TDemo = class
  private
  fEvent: TOnTexChange;
  published
   property OntextChange: TOnTextChange read fEvent write fEvent;
  end ;

protected:

 
1
//Protected标明了类内元素的访问区分权限, 被Protected区分的元素只能被本类内部和其子类访问.

public:

 
1
//Public标明了类内元素的访问区分权限, 被Public区分的元素能够被类内和类外任何对象访问.

published:

 
1
2
3
//Published标明了类内元素的访问区分权限.
//被Published区分的元素能够被类内和类外任何RTTI对象访问
//只在声明在Published区分符下的属性才能够成为显式属性并在对象查看器中显示.

raise:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//Raise语句用于抛出异常,
//如果希望通过外部程序处理异常, 或是在异常发生时重新将异常抛出, 可以使用Raise语句.
function GetString(i: Integer ): string ;
begin
  if i < 0 then
   raise exception . Create( 'Integer Cannot smaller than 0' );
 Result := IntToStr(i);
end ;
//在异常处理中, 可以重新抛出异常
try
 i := StrToInt(s);
except
  on E: exception do
   raise exception . Create(E . Message);
end ;

read:

 
1
2
3
4
5
6
//Read用于标识属性中读取所使用的成员或方法.
private
 fValue: Integer ;
published
  property Value: Integer readfValue;
//上例中即表明Value属性的值从fValue成员上读取.

readonly:

 
1
2
3
//ReadOnly关键字用于标识一个对象是否只读.
propertyReadOnly;
//当ReadOnly设为True时, 不允许用户手动修改属性, 只能通过其他对象来操作.

record:

 
1
2
3
4
5
6
7
//Record关键字用于声明一个结构体记录,
//一个结构体可以视为一个不需要实例化的对象, 拥有自己的成员.
type
 TPerson = record
  PName: string [ 32 ];
  PAge: Integer ;
  end ;

register:

 
1
2
3
4
5
6
7
//Register标明了函数调用协定, 指出函数在被调用时可以在注册表内留下记录.它是向下兼容的.
functionAdd(a,b: Integer ): Integer ; Register; Register
//关键字还用于向控件库或是IDE注册控件或是专家工具.
procedure Register;
begin
 RegisterComponents( 'Sample' , [TDemo]);
end ;

reintroduce:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
//Reintroduce用于重新发布方法, 通常用于继承时,
//如果要覆盖的方法是静态方法, 或是需要修改方法的参数等, 必须用Reintroduce进行重发布.
//对于Virtual或Dynamic方法, 可以直接用Override进行覆盖.
type
 TClassA = class
   procedure X;
  end ;
 TClassB = class (TClassA)
   procedure X; reintroduce;
  end ;
 TClassC = class (TClassB)
   procedure X(i: Integer ); reintroduce;
  end ;

repeat:

 
1
2
3
4
5
6
7
//repeat关键字用于引出repeat循环结构,
//该循环必须先执行一次循环体, 然后再对循环条件进行判断.repeat必须与Until关键字联合使用.
i := 0 ;
repeat
 sum := sum + i;
 Inc(i);
until (i >= 100 );

requires:

 
1
2
3
4
5
6
//Requires关键字指出了编译Package时的必备条件.若Requires的条件未满足, 则不允许编译包.
package DATAX;
  requires
   rtl,
   clx;
end .

resourcestring:

 
1
2
3
4
5
6
7
//ResourceString用于声明资源字符串, 资源字符串可以在被声明的结构内使用.
ResourceString
 CreateError = 'Cannot create file %s' ;
 OpenError = 'Cannot open file %s' ;
 LineTooLong = 'Line too long' ;
 ProductName = 'Borland Rocks' ;
 SomeResourceString = SomeTrueConstant;

safecall:

 
1
2
3
4
5
//Safecall是函数调用协定的一种, 它规定了被COM调用的函数所必须遵守和规则.
//在编译时, Safecall声明的函数被编译成COM接口兼容的.
procedure X(s: WideString ); safecall;
//在编译后成为:
procedure X(s: PAnsiString );

set:

 
1
2
3
4
5
6
7
8
9
10
//Set关键字用于声明集合类, 集合类允许用集合运算符, 如in等进行操作.
type
 TCol = (cA,cB,cC);
 TCols = set ofTCol;
//操作时允许使用加减符号来添加或删除某个集合元素
var
 Cols: Tcols;
begin
 Cols := Cols + [cA,cB];
end ;

shl:

 
1
2
3
4
5
6
//SHL表示向左移位, 左移的位数即乘以2的幂数
var
 x: Integer ;
begin
 X := 2 shl 3 ; {16}
end ;

shr:

 
1
2
3
4
5
6
//SHR表示向右移位, 右移的位数即除以2的幂数
var
 x: Integer ;
begin
 X := 16 shr 2 ; {4}
end ;

stdcall:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
//Stdcall是函数调用协定的一种, 它规定了能让程序调用的函数所应遵守的规则.
//Stdcall关键字必须在主调方和被调方之间形成配对.
//例如, 被调方函数:
Library Demo;
function X(i: Integer ): Integer ; stdcall;
begin
 Result := i * 2 ;
end ;
exports
 X;
begin
end .
 
//主调方函数:
function X(i: Integer ): Integer ; stdcall; external 'Demo.dll' ;
 
//同时需要注意, 使用Stdcall关键字时, 被调函数是大小写敏感的, 此处极容易出错.

stored:

 
1
2
//Stored用于指出一个属性的值是否能被保留, 若指定了True, 则允许对属性值进行赋值撤销的操作.
property Value: string read fValue write fValue stored True ;

string:

 
1
2
3
//String是一个数据类型, 它代表了字符串.
var
 Str: string ;

then:

 
1
2
3
4
5
6
7
8
9
//Then关键字用于If语句中, 当If条件成立时, 执行Then后的语句.
var
 a,b: Integer ;
begin
  if a > b then
   WriteLn ( 'a' )
  else
   WriteLn ( 'b' );
end ;

threadvar:

 
1
2
3
4
5
6
//Threadvar标识了一个随线程启动而创建的变量,
//如果用Threadvar声明变量, 则在程序结束前必须手动释放其占用的空间.
threadvar S: AnsiString ;
S := 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' ;
S := '' ;
//S := ''; 即释放变量S所占用的内存.

to:

1
2
3
4
//To关键字用于For语句, 指明循环变量是递增的.
for i := 10 to 100 do
 ListBox1 . Items . Add(IntToStr(i));
//在For语句中, 循环变量递增用To关键字, 递减用DownTo关键字.

try:

 
1
2
3
4
5
6
//try语句用于异常处理, 对于有可能发生异常的语句, 可以放在try结构下, 以便对其进行异常保护.
try
 i := StrToInt(s);
except
 ShowMessage( 'Error' );
end ;

type:

 
1
2
3
4
5
6
7
8
//Type关键字用于声明各种对象, 用Type关键字声明的对象, 在传递时按引用传递.
type
 TDemo = class
  end ;
//type也用来声明枚举类型或是按引用传递的变量.
type
 TCol = (cA,cB,cC);
 TInt = Integer ;

unit:

 
1
2
3
4
5
6
7
//Unit标识了单元的开头, 单元的基本结构为 Unit...Interface...implementation...end.
Unit Unit1;
Interface
  uses Classes;
implementation
end .
//一个完整的单元必须拥有Unit作为开头.

until:

 
1
2
3
4
5
6
7
//Until关键字用于判断repeat循环结构的循环条件,
//如果循环条件为真, 则退出循环.Until必须与repeat关键字联合使用.
i := 0 ;
repeat
 sum := sum + i;
 Inc(i);
until (i >= 100 );

uses:

 
1
2
3
4
5
6
//Uses用于引用一个外部的单元, 并且能够使用该单元中的公共部分.
//Uses语句通常放在一个单元的接口或是实现部分.
Interface
  uses Classes;
Implemention
  uses frmAbout;

var:

 
1
2
3
4
5
6
7
8
//var关键字用于声明一个变量或是对象, 用var声明的变量接值传递.
var
 i: Integer ;
 s: string ;
//var也可以用于标识按引用传递的方法参数
function X( var i: Integer ): Integer ;
 
//上述函数中的参数i即按引用传递, 它的值可以在函数执行时被改变, 并返回主调函数.

varargs:

 
1
2
3
//varArgs标识了引用参数, 它必须和Cdecl关键字联用, 表明允许调用的函数使用引用传递.
function printf(Format: PChar ): Integer ; cdecl; varargs;
//上述代码从C++的类库中引用了Printf函数, 并允许按引用的方式传入参数.

virtual:

?
1
2
3
//Virtual用于声明一个虚方法,
//虚方法可以被覆盖, 并且可以使程序运行速度尽可能的快(区别于Dynamic).
procedure X(i: Integer ); virtual;

while:

 
1
2
3
4
5
6
7
//While关键字用于引出While循环语句, 循环前先进行循环条件的判断, 如果条件为真则执行循环.
i := 0 ;
while i < 100 do
begin
 sum := sum + i;
 Inc(i);
end ;

with:

 
1
2
3
4
5
6
7
8
9
10
11
12
13
//With关键字用于将相同的对象集合起来处理, 它可以省去输入大量重复的代码, 使代码看上去比较精简.
with Form1 . Memo1 . Lines do
begin
 Clear;
 Append( 'abc' );
 Append( 'def' );
 SaveToFile( 'C:\demo.txt' );
end ;
//上面这段代码如果不使用With语句, 则显得非常冗余复制内容到剪贴板代码:
Form1 . Memo1 . Lines . Clear;
Form1 . Memo1 . Lines . Append( 'abc' );
Form1 . Memo1 . Lines . Append( 'def' );
Form1 . Memo1 . Lines . SaveToFile( 'C:\demo.txt' );

write:

 
1
2
3
4
5
6
//Write用于标识属性中写入所使用的成员或方法.
private
 fValue: Integer ;
published
  property Value: Integer writefValue;
//上例中即表明Value属性的值写入到fValue成员上.

writeonly:

 
1
2
3
//writeonly关键字用于标识一个对象是否只写.
property writeonly;
//当writeonly设为True时, 不允许用户读取属性, 只能通过其他对象来操作.

xor:

 
1
2
3
4
5
6
7
8
9
10
11
12
//Xor用于取异或, 当两个操作数相等时, 返回False, 不等时返回True.
var
 a,b: Integer ;
begin
 a := 2 ; b := 3 ;
  if a xor b then
   WriteLn ( 'a xor b' )
  else
   WriteLn ( 'a not xor b' );
end ;
//Xor也用于计算异或值
WriteLn (IntToStr( 3 xor 5 )); {6}
1
2
3
4
5
6
//Write用于标识属性中写入所使用的成员或方法.
private
 fValue: Integer ;
published
  property Value: Integer writefValue;
//上例中即表明Value属性的值写入到fValue成员上.

writeonly:

 
1
2
3
//writeonly关键字用于标识一个对象是否只写.
property writeonly;
//当writeonly设为True时, 不允许用户读取属性, 只能通过其他对象来操作.

xor:

 
1
2
3
4
5
6
7
8
9
10
11
12
//Xor用于取异或, 当两个操作数相等时, 返回False, 不等时返回True.
var
 a,b: Integer ;
begin
 a := 2 ; b := 3 ;
  if a xor b then
   WriteLn ( 'a xor b' )
  else
   WriteLn ( 'a not xor b' );
end ;
//Xor也用于计算异或值
WriteLn (IntToStr( 3 xor 5 )); {6}
posted on 2016-09-06 09:25 yoyo_zeng 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/zengyou/p/5842909.html

相关文章:

  • JavaScript之面向对象学习五(JS原生引用类型Array、Object、String等等)的原型对象介绍...
  • Bootstrap结合BootstrapTable的使用,分为两种模试显示列表。 自适应表格,自定义行列...
  • Zabbix监控之Redis自动发现并监控(python)
  • SQLServer · 特性分析 · SQL Server 2012的分析函数未必都理解透了(1)
  • 重定向Http status code 303 和 302
  • 输入一组数组,回车结束
  • Java反射在JVM的实现
  • 腾讯优测优分享 | 你是否体验过Android手机插入耳机后仍外放的尴尬?
  • Android IOS WebRTC 音视频开发总结(八十五)-- 使用WebRTC广播网络摄像头视频(下)...
  • jdbc conn.commit()提交事务和 rollback()使用
  • 每天一个linux命令:mkdir命令
  • 程序(进程)内存分布解析【转】
  • jenkins updatecenter更新插件有问题
  • Django+uwsgi+Nginx安装部署
  • 基于人脸识别的商业大数据4
  • 《用数据讲故事》作者Cole N. Knaflic:消除一切无效的图表
  • 【MySQL经典案例分析】 Waiting for table metadata lock
  • 【许晓笛】 EOS 智能合约案例解析(3)
  • flutter的key在widget list的作用以及必要性
  • Java 网络编程(2):UDP 的使用
  • MySQL Access denied for user 'root'@'localhost' 解决方法
  • mysql_config not found
  • mysql外键的使用
  • PermissionScope Swift4 兼容问题
  • React-Native - 收藏集 - 掘金
  • Spring Cloud Feign的两种使用姿势
  • Wamp集成环境 添加PHP的新版本
  • XForms - 更强大的Form
  • 从0实现一个tiny react(三)生命周期
  • 后端_ThinkPHP5
  • 类orAPI - 收藏集 - 掘金
  • 要让cordova项目适配iphoneX + ios11.4,总共要几步?三步
  • 原生JS动态加载JS、CSS文件及代码脚本
  • 做一名精致的JavaScripter 01:JavaScript简介
  • Nginx实现动静分离
  • 阿里云服务器如何修改远程端口?
  • ​ 无限可能性的探索:Amazon Lightsail轻量应用服务器引领数字化时代创新发展
  • ​​​​​​​​​​​​​​汽车网络信息安全分析方法论
  • # 20155222 2016-2017-2 《Java程序设计》第5周学习总结
  • # 学号 2017-2018-20172309 《程序设计与数据结构》实验三报告
  • ###STL(标准模板库)
  • #考研#计算机文化知识1(局域网及网络互联)
  • #我与Java虚拟机的故事#连载02:“小蓝”陪伴的日日夜夜
  • (10)Linux冯诺依曼结构操作系统的再次理解
  • (C++17) optional的使用
  • (更新)A股上市公司华证ESG评级得分稳健性校验ESG得分年均值中位数(2009-2023年.12)
  • (转)chrome浏览器收藏夹(书签)的导出与导入
  • (转)全文检索技术学习(三)——Lucene支持中文分词
  • (轉貼) 寄發紅帖基本原則(教育部禮儀司頒布) (雜項)
  • ../depcomp: line 571: exec: g++: not found
  • ./configure,make,make install的作用
  • .Net - 类的介绍
  • .Net FrameWork总结
  • .Net Web项目创建比较不错的参考文章
  • /*在DataTable中更新、删除数据*/