- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个客户端-服务器应用程序。客户端(TCP Client)是一个Delphi应用程序,它向服务器(TCP Server,C++ Builder应用程序)发送命令。
它们都是用 Rad Studio XE2 编写的。
服务器响应命令,从 SQL Server 获取数据并将其发送到客户端。
服务器使用TClientDataSet并将其保存到发送给客户端的TMemoryStream。
客户端还使用 TClientDataSet 并对从服务器接收的流调用 TClientDataSet.LoadFromStream()。
这很好用。
但有一种情况是数据大小较大(~160 MB),有时会在调用 TClientDataSet.LoadFromStream() 时抛出 "Error creating variant or safe array"> 在客户端。
服务器通过这种方式向客户端发送流:
//...
FContext->Connection->IOHandler->LargeStream = true;
FContext->Connection->IOHandler->Write(Stream, 0, true);
客户端是这样接收的:
AClient.IOHandler.LargeStream := True;
AClient.IOHandler.ReadStream(Stream, -1, False);
客户端收到后,将流的位置改为18。
因为实际数据是在 18 字节之后开始的。然后调用 TClientDataSet.LoadFromStream()。
//...
MemTable.LoadFromStream(Stream);
LoadFromStream() 抛出“创建变体或安全数组时出错”。但在某些情况下它可以正常工作。
有人知道吗?
最佳答案
根据 Delphi 10 的源代码,问题来自 SafeArrayCreate
失败,很可能是因为 EOutOfMemory 异常。
SafeArrayCreate
尝试分配 160MB 的内存,这需要是连续的。进程的虚拟内存中可能没有足够大的“洞”来容纳那么多内存。在 32 位进程中,我猜这不太可能。
稍微缓解此问题的一种方法可能是激活/LARGEADDRESSAWARE 标志。但这只会稍微降低错误发生的可能性,并可能在未来很快再次出现。
其他选项包括:
编译为 64 位应用程序。
使用适当的数据库而不是内存中的数据集。
关于c++ - Delphi 中的 TClientDataSet.LoadFromStream() 中的 "Error creating variant or safe array",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41616773/
我偶然发现了 Wikipedia 上的线程安全文章;它区分了几个安全级别,尤其是: Thread safe: Implementation is guaranteed to be free of ra
当我启动 Rails 时,如何摆脱这个警告/错误。 在没有 :safe 选项的情况下调用“加载”——默认为安全模式。 => Booting Thin => Rails 3.2.13 applicati
当我启动 Rails 时,如何摆脱这个警告/错误。 在没有 :safe 选项的情况下调用“加载”——默认为安全模式。 => Booting Thin => Rails 3.2.13 applicati
我正在尝试使用 FCM 和 https://www.simplifiedcoding.net/firebase-cloud-messaging-android/ 上提供的教程向我的应用程序添加通知服务
我正在 VB.net 中寻找“安全”点符号。这样的事情是否存在——在 VB.NET 或任何语言中?我希望能够做的是,在使用 non-nullable 遗留对象时,解决如下问题: “如果有计划,如果有案
我在我的机器上使用 Windows 10 家庭单语言版,这是一个 64 位操作系统。 我已经安装了最新版本的 XAMPP,它在我的机器上安装了 PHP 7.2.7。 我是根据摘自 PHP Manual
我在 XmlDocument class documentation 中看到在 MSDN 上 Any public static ( Shared in Visual Basic) members o
例如,我经常想用 SELECT whatever FROM questions WHERE views * N + votes * M > answers AND NOT(answered) O
在DataStax收购Aurelius之后,自从Titan 1.0.0在2015年9月发布以来,自那时以来几乎没有提交过,所以我想知道在生产中使用TitanDB是否安全。谁能给我一些见识? 最佳答案
给定一个文件: dept4.abc.edu dept3.abc.edu dept2.abc.edu dept1.abc.edu 我知道如何使用以下命令获取从底部开始的第三行: tail -3 file
SELECT TO_NUMBER('*') FROM DUAL 这显然给了我一个异常(exception): ORA-01722: invalid number 有没有办法“跳过”它并获取 0 或 N
我不是在问这些是否真的是随机的。我只是想知道如果两个用户同时点击一个页面他们可以获得相同的随机数吗?我在想,如果我在多核服务器上运行它,我会因为同步或其他原因在很长一段时间内生成相同的随机数吗? pu
我有一个服务器存储来自客户端的数据。每个客户端都在自己的线程中工作,并且拥有一个数据对象。 这个数据对象是一个自定义类,让我们调用包含非特定数据的 Data.java,这可能是一些字节,但通常约为 1
我正在开发一个应用程序,其中我有一个包含 5000 行和 4 列的数据库。 problem_id (int) problem_no (string) problem_title (string) da
我有一个表,其中每行的字段数据都不完整,我想要修复。 这就是我的意思: mysql> CREATE TABLE test ( key INT a CHAR(1),
这个问题已经有答案了: How do JavaScript closures work? (86 个回答) 已关闭 6 年前。 所以,这个代码片段工作起来非常方便,但我对它的工作方式感到有点惊讶。 v
我想 compile C++ extensions to SQL Server , 来自文档 Safe mode: Run verifiably typesafe code; compiled wit
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。为了帮助澄清这个问题以便它可以重新打开,visit the help center。 关
这种互斥模式是否像我认为的那样安全?如果是这样,你怎么调用它? lock (_lock) { if (_flag) return; else _flag = true; } try {
假设您使用 EntityFramework 作为 ORM,所有这些都封装在一个单独的 DAL 类库中。 您在另一个“公共(public)”类库中有以下 POCO 对象,它在您的 DAL、SL 和表示层
我是一名优秀的程序员,十分优秀!