在尝试通过DLL运行函数时,我遇到了一些麻烦。 执行函数时,我得到以下错误(它正常编译):
无效的类别类别
以下是代码:
#include <fmx.h>
#define CRIPTNSDLL_EXPORTS
#include "CriptLib.h"
#include <FMX.Memo.hpp>
#include <System.Classes.hpp>
#include <string.h>
#pragma hdrstop
#pragma argsused
//---------------------------------------------------------------------------
void Cript_BasicoM (String Original, String Chave, TMemo* Memo){
if (Original.Length() != Chave.Length()) {
throw Exception (L"Não é possível encriptar o conteúdo.\nO tamanho das palaras chave e original não podem ser diferentes.");
}
for (int i = 0; i < Chave.Length(); i++) {
for (int p = 0; p < Chave.Length(); p++) {
if (Chave.c_str()[i] == Chave.c_str()[p] && p != i) {
throw Exception (L"Não é possível encriptar o conteúdo.\nA chave não pode ter dois caracteres iguais.");
}
}
}
for (int i = 0; i < Original.Length(); i++) {
for (int p = 0; p < Original.Length(); p++) {
if (Original.c_str()[i] == Original.c_str()[p] && p != i) {
throw Exception (L"Não é possível encriptar o conteúdo.\nA palavra original não pode ter dois caracteres iguais.");
}
}
}
String Linha = NULL;
Memo->BeginUpdate();
for (int i = 0; i < Original.Length(); i++) {
for (int k = 0; k < Memo->Lines->Count; k++) {
Linha = Memo->Lines->Strings[k];
for (int l = 0; l < Linha.Length(); l++) {
if (Linha.c_str()[l] == Original.c_str()[i]) Linha.c_str()[l] = Chave.c_str() [i];
else if (Linha.c_str()[l] == Chave.c_str()[i]) Linha.c_str()[l] = Original.c_str() [i];
}
Memo->Lines->Strings[k] = Linha;
}
}
Memo->Lines->Add(Original);
Memo->Lines->Add("CriptB");
Memo->EndUpdate();
Memo->Repaint();
}
标题文件:
#ifndef CriptLibH
#define CriptLibH
#ifdef CRIPTNSDLL_EXPORTS
#define CRIPTLIB_API __declspec(dllexport)
#else
#define CRIPTLIB_API __declspec(dllimport)
#endif
#ifdef __cplusplus
#include <fmx.h>
#include <FMX.Dialogs.hpp>
#include <System.Classes.hpp>
#include <string.h>
#include <FMX.Memo.hpp>
extern "C" {
#endif
CRIPTLIB_API void Cript_BasicoM(String Original, String Chave, TMemo* Memo);
CRIPTLIB_API void Cript_BasicoL(String Original, String Chave, TStringList* Lista);
CRIPTLIB_API void Cript_BasicoS(String Original, String Chave, String Linha);
CRIPTLIB_API void Decript_BasicoM(String Chave, TMemo* Memo);
CRIPTLIB_API void Decript_BasicoL(String Chave, TStringList* Lista);
CRIPTLIB_API void Decript_BasicoS(String Original, String Chave, String Linha);
CRIPTLIB_API String VerProg();
#ifdef __cplusplus
}
namespace CriptLib
{
class Encriptar
{
public:
static void Subst(String Original, String Chave, TMemo* Memo) { Cript_BasicoM(Original, Chave, Memo); }
static void Subst(String Original, String Chave, TStringList* Lista) { Cript_BasicoL(Original, Chave, Lista); }
static void Subst(String Original, String Chave, String Linha) { Cript_BasicoS(Original, Chave, Linha); }
};
class Decriptar
{
public:
static void Subst(String Chave, TMemo* Memo) { Decript_BasicoM(Chave, Memo); }
static void Subst(String Chave, TStringList* Lista) { Decript_BasicoL(Chave, Lista); }
static void Subst(String Original, String Chave, String Linha) { Decript_BasicoS(Original, Chave, Linha); }
};
class Info
{
public:
static String Ver() { return VerProg(); }
};
}
#endif
#endif
唤起函数(也抛出异常的地方):
CriptLib::Encriptar::Subst(edtOriginal->Text, edtKey->Text, memoContent);
Debuger说明:
第一次机会异常,价格为77303E28美元。异常类EInvalidCast with 消息&#39;无效的类类型转换&#39;。处理Project1.exe(7476)
我找到了问题的确切位置。当使用Memo-&gt; Lines-&gt; Count进行for结构比较时。为了确保我创建了一个整数变量并尝试与Count属性进行均衡并将其用于for(甚至像int(Memo-&gt; Lines-&gt; Count))。但是我也得到了错误。 (现在使用调试器)。一旦属性Count返回一个整数值(我多次使用这个表达式),我坚信它不应该发生。
从现在开始,感谢很多。
答案 0 :(得分:0)
这是一个RTL错误。由于我使用的是XE8版本,因此它附带了System.Classes文件中的错误。你可以在这里查看:
您必须搜索QP#(RSP-11445)
我很抱歉打扰你。