- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在努力摆脱短字符串。当前在我们的程序中使用短字符串的许多地方之一是在记录中。许多这些记录都保存在 AVL 树中。
使用的 AVL 树是一种通用树,它保存一个指向多个字节的指针 (ElemSize
),到目前为止效果良好。AVL树中每条记录的内存通过GetMem
分配,并通过Move
复制。但是,由于字符串是指向引用计数结构的指针,因此将内存复制回记录不再有效,因为引用的字符串通常会被释放(通过引用计数自动释放)。仅使用指针和“数据 block ”的大小,我认为不可能增加字符串的引用计数。
我正在寻找一种方法来获取在 AVL 树中存储记录时要考虑的字符串的引用计数。
我可以将记录类型传递给树构造函数,然后将指针转换为该类型,从而增加引用吗?或者类似的修复,我可以将更改主要隔离在 AVL 单元中并调用其构造函数。
当前在AVL中分配存储记录的空间的代码; XData是指向要存储的记录的指针:
New(RootPtr); { create new memory space }
GetMem(RootPtr^.TreeData, ElemSize);
WITH RootPtr^ DO BEGIN
{ copy data }
Move(XData^, RootPtr^.TreeData^, ElemSize);
最佳答案
本质上,您要问的问题是:
How can I allocate, copy and deallocate a record when all I know about its type is its size?
简单的答案是,只要记录不包含托管类型,您就可以使用 GetMem
、Move
和 FreeMem
。您希望处理包含托管的 Delphi 字符串的记录。因此,您当前使用 GetMem
和 Move
的方法还不够。
有很多方法可以解决这个问题。只要您知道托管类型在记录中的位置,您就可以编写自己的代码来进行引用计数。我不推荐这个。您可以将用户数据作为一个类,并使用多态性来提供帮助。
我想讨论的选项继续支持记录,并且确实允许用户选择他们喜欢的任何类型。推理如下:
如果类型包含托管类型,则对其进行操作需要了解该类型。如果树是通用的,那么它就不可能拥有这些知识。因此,知识必须由树的用户提供。
这将引导您前往事件。让树提供用户可以为其提供处理程序的事件。类型如下所示:
type
PTreeNodeUserData = type Pointer;
TTreeNodeCreateUserDataEvent = function: PTreeNodeUserData of object;
TTreeNodeDestroyUserDataEvent = procedure(Data: PTreeNodeUserData) of object;
TTreeNodeCopyUserDataEvent = procedure(Source, Dest: PTreeNodeUserData) of object;
然后,您可以安排树发布用户可以订阅的这些类型的事件。
重点是,这允许树的用户提供有关用户数据类型的缺失知识。
关于delphi - 记录中的字符串生命周期管理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23466583/
我正在开发一个使用多个 turtle 的滚动游戏。玩家 turtle 根据按键命令在 Y 轴上移动。当危害和好处在 X 轴上移动时,然后循环并改变 Y 轴位置。我尝试定义一个名为 colliding(
我不明白为什么他们不接受这个作为解决方案,他们说这是一个错误的答案:- #include int main(void) { int val=0; printf("Input:- \n
我正在使用基于表单的身份验证。 我有一个注销链接,如下所示: 以及对应的注销方法: public String logout() { FacesContext.getCurren
在 IIS7 应用程序池中有一个设置 Idle-time out 默认是 20 分钟,其中说: Amount of time(in minutes) a worker process will rem
我是一名优秀的程序员,十分优秀!