java中的反射机制使我们能够在运行期间获取运行期类的信息,那么在delphi中有没有这样的功能呢?答案是有,实现这种功能的机制在delphi中叫做RTTI,废话少说,先来一段demo:

1.先定义一个demo类,注意这个类必须要以TPersistent为基类,代码如下:

  1. unit Unit2;
  2. interface
  3. { TDemo }
  4. uses  Classes ;
  5. type
  6. TDemo = class(TPersistent)
  7. private
  8. protected
  9. public
  10. FName : string;
  11. FAge : Integer;
  12. constructor Create;
  13. destructor Destroy; override;
  14. published
  15. property Name : string read FName write FName;
  16. property Age : Integer read FAge write FAge;
  17. end;
  18. implementation
  19. { TDemo }
  20. constructor TDemo.Create;
  21. begin
  22. FName := 'peirenlei';
  23. end;
  24. destructor TDemo.Destroy;
  25. begin
  26. inherited;
  27. end;
  28. end.

2.接下来,创建一个这个类的实例:

  1. ADemo := TDemo.Create;
  2. ADemo.Name := 'peirenlei';
  3. ADemo.Age := 0;

3.获取该实例的属性列表:

  1. var
  2. APropList:PPropList;
  3. ATypeInfo:PTypeInfo;
  4. AClasDateInfo:PTypeData;
  5. I : Integer;
  6. begin
  7. ATypeInfo := ADemo.ClassInfo;
  8. AClasDateInfo := GetTypeData(ATypeInfo);
  9. if AClasDateInfo.PropCount <> 0 then
  10. begin
  11. //分配空间
  12. GetMem(APropList,sizeof(PPropInfo)*AClasDateInfo.PropCount);
  13. try
  14. GetPropInfos(ADemo.ClassInfo,APropList);  //得到类的属性列表
  15. for I := 0 to AClasDateInfo.PropCount - 1 do
  16. begin
  17. if APropList[I]^.PropType^.Kind <> tkMethod then
  18. mmo.Lines.Add(Format('%s:%s',[APropList[I]^.Name,APropList[I]^.PropType^.Name]));
  19. end;
  20. finally
  21. FreeMem(APropList,sizeof(APropList)*AClasDateInfo.PropCount);
  22. end;
  23. end;
  24. end;

输出:

  1. Name:string
  2. Age:Integer

3. 获取类的方法列表:

  1. var
  2. APropList:PPropList;
  3. ATypeInfo:PTypeInfo;
  4. AClasDateInfo:PTypeData;
  5. I ,NumPro : Integer;
  6. begin
  7. ATypeInfo := ADemo.ClassInfo;
  8. AClasDateInfo := GetTypeData(ATypeInfo);
  9. if AClasDateInfo.PropCount <> 0 then
  10. begin
  11. //分配空间
  12. GetMem(APropList,sizeof(PPropInfo)*AClasDateInfo.PropCount);
  13. try
  14. NumPro := GetPropList(ADemo.ClassInfo,[tkMethod],APropList);
  15. if NumPro <> 0 then
  16. begin
  17. mmo.Lines.Add('-----events-------');
  18. for I := 0 to NumPro - 1 do //获得事件属性的列表
  19. begin
  20. mmo.Lines.Add(Format('%s:%s',[APropList[i]^.Name,APropList[i]^.PropType^.Name]));
  21. end;
  22. end;
  23. finally
  24. FreeMem(APropList,sizeof(PPropInfo)*AClasDateInfo.PropCount);
  25. end;
  26. end;
  27. end;

4.获取实例类的属性和属性值:

  1. var
  2. AProperInfo:PPropInfo;
  3. AValue:string;
  4. begin
  5. AValue := GetPropValue(ADemo,'Name');
  6. mmo.Lines.Add('Name='+AValue);
  7. AValue := GetPropValue(ADemo,'Age');
  8. mmo.Lines.Add('Age='+AValue);
  9. SetPropValue(ADemo,'Name','zengzhen');
  10. SetPropValue(ADemo,'Age',100);
  11. AValue := GetPropValue(ADemo,'Name');
  12. mmo.Lines.Add('Name='+AValue);
  13. AValue := GetPropValue(ADemo,'Age');
  14. mmo.Lines.Add('Age='+AValue);
  15. end;

输出:

  1. Name=peirenlei
  2. Age=0
  3. Name=zengzhen
  4. Age=100

http://peirenlei.iteye.com/blog/378465

delpi中的RTTI初试的更多相关文章

  1. C++中的RTTI机制解析

    RTTI RTTI概念 RTTI(Run Time Type Identification)即通过运行时类型识别,程序能够使用基类的指针或引用来检查着这些指针或引用所指的对象的实际派生类型. RTTI ...

  2. C++ 中的RTTI机制详解

    前言 RTTI是”Runtime Type Information”的缩写,意思是运行时类型信息,它提供了运行时确定对象类型的方法.RTTI并不是什么新的东西,很早就有了这个技术,但是,在实际应用中使 ...

  3. Java中的RTTI

    RTTI可以帮助我们在运行时识别对象和类的信息. 一般传统的RTTI有三种实现方式: 1. 向上转型或向下转型(upcasting and downcasting),在java中,向下转型(父类转成子 ...

  4. Delphi中的Rtti函数

    TTypeKind,类型类别,tkclass,tkinteger,tkstring等.类,属性都是一种类型. ttypedata,是一个record包括ttypekind.是一个类的描述.TTypeK ...

  5. Delphi中关于Rtti的一些操作(一)

    function TForm1.ShowMethodAddress(aObj: TDerived; const sData: String) : Pointer;var  aPtr : Pointer ...

  6. Java系列笔记(2) - Java RTTI和反射机制

    目录 前言 传统的RTTI 反射 反射的实现方式 反射的性能 反射与设计模式 前言 并不是所有的Class都能在编译时明确,因此在某些情况下需要在运行时再发现和确定类型信息(比如:基于构建编程,),这 ...

  7. UE4 中Struct Emum 类型的定义方式 笔记

    UE4 基础,但是不经常用总是忘记,做个笔记加深记忆: 图方便就随便贴一个项目中的STRUCT和 Enum 的.h 文件 Note:虽然USTRUCT可以定义函数,但是不能加UFUNCTION 标签喔 ...

  8. Java RTTI机制与反射机制

    1.1 什么是RTTI? 维基百科的定义:In computer programming, RTTI (Run-Time Type Information, or Run-Time Type Iden ...

  9. RTTI (Run-Time Type Identification,通过运行时类型识别) 转

    参考一: RTTI(Run-Time Type Identification,通过运行时类型识别)程序能够使用基类的指针或引用来检查这些指针或引用所指的对象的实际派生类型.   RTTI提供了以下两个 ...

随机推荐

  1. android 判断网络连接的工具类

    package com.way.util; import android.content.Context; import android.net.ConnectivityManager; import ...

  2. 触发器应用 trigger

    首先有一张表: create table T_SALARY ( name VARCHAR2(20), age NUMBER(2), salary NUMBER(5) ); insert into t_ ...

  3. datetime.timedelta

    from django.utils import timezoneimport datetime timezone.now()datetime.datetime(2014, 7, 18, 9, 42, ...

  4. Chapter 4.开放-封闭原则

    开放-封闭原则:是说软件实体应该可以扩展,但不可修改. 设计人员必须对于他设计的模块应该对哪种变化封闭做出选择,先猜测出最有可能发生的变化种类,然后构造抽象来隔离那些变化. 面对需求,对程序的改动是通 ...

  5. Python 2.7 学习笔记 内置语句、函数、标准库

    使用任何开发语言进行软件开发,都离不开语言提供的内置库(或Api),甚至说内置库的强大及使用是否方便都会影响大家对开发语言的选择. python语言,一样提供了很多内置的功能,可供开发时使用.主要有如 ...

  6. php 父类调用子类方法和成员

    在C和C++里,父类都不允许调用子类的方法,但在php里可以.下面是一个调用的例子: <?php abstract class Animal { protected $name; public ...

  7. HTTP 301 跳转和302跳转的区别

    常用的重定向方式有: 301 redirect, 302 redirect 与 meta fresh: 301 redirect::301代表永久性转移(Permanently Moved),301重 ...

  8. Android内存泄漏简介

    前言 不少人认为JAVA程序,因为有垃圾回收机制,应该没有内存泄露. 其实如果我们一个程序中,已经不再使用某个对象,但是因为仍然有引用指向它,垃圾回收器就无法回收它,当然该对象占用的内存就无法被使用, ...

  9. linux下ip命令用法

    配置数据转发,可以通过 1.路由转发即用用路由器实现: 2.使用NAT转发: 简单的说: 路由表内的信息只是指定数据包在路由器内的下一个去处.并不能改变数据包本身的地址信息.即它只是“换条路而已,目的 ...

  10. Android中的单元测试

    2015年5月19日 23:10     在Android中,已经内置了Junit所以不需要在导包.只要继承AndroidTestCase类就可以了.     首先需要修改AndroidManifes ...