先有Delphi内存对象,后有句柄(如果需要的话),最后再显示

在设计期放上一个Panel1和Button1,然后设置Panel1.Visible:=False

这时候执行:

procedure TForm1.Button4Click(Sender: TObject);
begin
  ShowMessage(IntToStr(panel1.InstanceSize));
end;

得到552,说明这个Panel1这个内存对象已经存在了。再把它的visible改成true,还是得到552。说明这个内存对象已经存在,且大小没区别(其内容可能会有所不同)。

再重新把visible改成false,测试以下代码:

procedure TForm1.Button1Click(Sender: TObject);
begin
  if (panel1.Handle=0) then
    ShowMessage(‘no handle‘)
  else
    ShowMessage(‘handled‘);
end;

结果总是显示已经有句柄了。这是为什么呢?明明还没有显示控件,理应执行HandleNeeded

procedure TWinControl.HandleNeeded;
begin
  if FHandle = 0 then
  begin
    if Parent <> nil then Parent.HandleNeeded;
    CreateHandle;
  end;
end;

function TWinControl.GetHandle: HWnd;
begin
  HandleNeeded;
  Result := FHandle;
end;

这是因为使用Handle属性时,使用了GetHandle函数,瞬间就把句柄给创建了,所以怎么测试都是已经有句柄。

所以要测,就应该测试FHandle。这就需要把FHandle从private改成public。然后测试:

procedure TForm1.Button1Click(Sender: TObject);
var
  panel1 : TPanel;
begin
  panel1:=TPanel.Create(nil);
  panel1.Left:=100;
  panel1.top:=100;
  if (panel1.FHandle=0) then
    ShowMessage(‘no handle‘)
  else
    ShowMessage(‘handled‘);
end;

这时候的结果就是no handle了。

设计期把Panel1.visible改成false,再测试:

procedure TForm1.Button1Click(Sender: TObject);
begin
  if (panel1.FHandle=0) then
    ShowMessage(‘no handle‘)
  else
    ShowMessage(‘handled‘);
end;

其结果也是no handle

------------------------------------------------------------------------------------------------------------------------------------------

再来一个出错的代码:

procedure TForm1.Button1Click(Sender: TObject);
var
  panel1 : TPanel;
begin
  panel1:=TPanel.Create(nil);
  panel1.Left:=100;
  panel1.top:=100;
  if (panel1.Handle=0) then
    ShowMessage(‘no handle‘)
  else
    ShowMessage(‘handled‘);
end;

顿时出错。因为还没有指定父控件,却在执行Handle属性的GetHandle方法时出错。其实我是从这个错误的例子中,忽然明白,直接使用Panel1.handle=0还没那么简单,是有问题的,不可以使用这种方法来判断。

------------------------------------------------------------------------------------------------------------------------------------------

再来一个问题,设计期放置Image1并载入图片,然而visible设为false,此时Image1在内存中的状态会怎么样呢?目前还不清楚。。。

时间: 2024-09-30 10:51:16

先有Delphi内存对象,后有句柄(如果需要的话),最后再显示的相关文章

多线程的基本概念和Delphi线程对象Tthread介绍

多线程的基本概念和Delphi线程对象Tthread介绍 作者:xiaoru WIN 98/NT/2000/XP是个多任务操作系统,也就是:一个进程可以划分为多个线程,每个线程轮流占用CPU运行时间和资源,或者说,把CPU 时间划成片,每个片分给不同的线程,这样,每个线程轮流的“挂起”和“唤醒”,由于时间片很小,给人的感觉是同时运行的. 多线程带来如下好处: 1)避免瓶颈: 2)并行操作: 3)提高效率:多线程的两个概念: 1) 进程:也称任务,程序载入内存,并分配资源,称为“一个进程”. 注意

Windows对象、句柄与MFC对象

windowsmfc编程c 目录(?)[-] Windows对象句柄与MFC对象 windows对象 句柄 mfc对象 杂谈 Windows对象.句柄与MFC对象 (2009-04-28 22:11:34) 转载 标签: windows对象 句柄 mfc对象 杂谈 分类: MFC以及Windows编程 Windows对象是以句柄来标识的,对应的MFC类就是这些句柄的C++包装.内存中的Windows对象一定有唯一的句柄来标识,但不 一定有对应的MFC类对象在内存中.当需要获取Windows对象的

Delphi中对象的创建,理解对象名与对象实体的本质区别

2015.08.06我总结的关于New和指针的问题(见此博客),最近在使用Delphi的面向对象的时候,发现很多类似的问题,现在也要总结一下. 目前以下的总结是针对Delphi的,对于C++我还没有实验过. 情况一:对一个对象变量多次Create 首先说一下对象声明的时候 var ObjectA: ClassA; 比如有一个类ClassA,用它来声明一个变量 ObjectA: ClassA; 注意这个时候的ObjectA相当于一个空指针,因为此时并没有创建一个对象实体(参看博客:http://w

C++——内存对象 禁止产生堆对象 禁止产生栈对象

用C或C++写程序,需要更多地关注内存,这不仅仅是因为内存的分配是否合理直接影响着程序的效率和性能,更为主要的是,当我们操作内存的时候一不小心就会出现问题,而且很多时候,这些问题都是不易发觉的,比如内存泄漏,比如悬挂指针. 我们知道,C++将内存划分为三个逻辑区域:堆.栈和静态存储区.既然如此,我称位于它们之中的对象分别为堆对象,栈对象以及静态对象.那么这些不同的内存对象有什么区别了?堆对象和栈对象各有什么优劣了?如何禁止创建堆对象或栈对象了? 一.基本概念 先来看看栈. 栈,一般用于存放局部变

java虚拟机2.运行时内存对象

对象的创建 虚拟机遇到一条new指令时,首先去检查这个指令的参数是否能在常量池中定位到一个类的符号引用,并且检查这个符号引用代表的类是否已被加载.解析和初始化过. 在类加载检查通过后,接下来虚拟机将为新生对象分配内存.对象所需内存的大小在类加载完成后便可完全确定,为对象分配空间的任务等同于把一块确定大小的内存从java堆中划分出来. 假设java堆中内存是绝对规整的,所有用过的内存都放在一边,空闲的内存放在另一边,中间放着一个指针作为分界点的指示器,那分配内存就仅仅是把那个指针向空闲空间那边挪动

关于Delphi内存表的使用说明

关于Delphi内存表的使用说明: 1.建立临时表  数据输入是开发数据库程序的必然环节.在Client/Server结构中,客户端可能要输入一批数据后,再向服务器的后台数据库提交,这就需要在本地(客户端)建立临时数据表来存储用户输入的数据,待提交后,清除本地表数据. 2 建立临时表如下: function CreateTableInMemory(const AFieldDefs:TFieldDefs):TDataSet; var TempTable:TClientDataSet; begin 

高性能的分布式内存对象缓存系统Memcached

Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memcached基于一个存储键/值对的hashmap.其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信. 外文名 memcached 所    属 缓存系统 编写语言 不限 通信手段 memcached协议 目录 1功能 2特征 ? 协议 ? 事件处

delphi 内存申请和释放

2012-02-22 12:421 内存分配常见函数GetMem和FreeMem.GetMemory和FreeMemory.New和Dispose.StrAlloc和StrDispose.AllocMem.SysGetMem和SysFreeMem. 2 GetMem和FreeMem.GetMemory和FreeMemory由于DELPHI的内存管理都知道分配内存的大小,因此在释放内存的时候,只要给指针地址不用给出长度就可以了.另外提倡用GetMemory和FreeMemory来代替GetMem和

powershell中使用超大内存对象

简单介绍了powershell中超大内存对象的用途,开启powershell超大内存对象的办法. powershell 传教士 原创文章 2016-12-31 允许转载,但必须保留名字和出处,否则追究法律责任 powershell 2GB large object .net 大对象 前 言 问:powershell中,哪些对象有可能会占用大内存? 答: stringbuilder对象,大数组arraylist,hashset等. 问:powershell中,stringbuildr对象有什么用?