1

我有两个 .dll,其中一个必须在两个或多个显式加载的实例之间交换数据。其中第二个具有来自具有共享内存段的库的发送模式和侦听模式。

它如下所示:

#pragma data_seg("sh")

float Highs[20][100] = {0};
float Lows[20][100] = {0};
int HighCount[20][100] = {0};
int LowCount[20][100] = {0};
int HStackTip[20] = {0};
int LStackTip[20] = {0};
float AloneHighs[20][100] = {0};
float AloneLows[20][100] = {0};
int AloneHighCount[20][100] = {0};
int AloneLowCount[20][100] = {0};
BOOL isCompletelySent[20] = {FALSE};

#pragma data_seg()
#pragma comment(linker, "/SECTION:sh,RWS")

第一个(或唯一的)数组索引是通道,它允许多达 20 个独立的对(发送者-侦听器)。在每个变量中都存在 setter 和 getter,像这样

    extern "C" __declspec(dllexport) void __stdcall SetDataSendingFinished(int channel)
{
    isCompletelySent[channel] = 1;
}
extern "C" __declspec(dllexport) BOOL __stdcall IsDataComplete(int channel)
{
    return isCompletelySent[channel];
}
extern "C" __declspec(dllexport) void __stdcall SetHigh(int channel, float value, int count)
{
    Highs[channel][HStackTip[channel]] = value;
    HighCount[channel][HStackTip[channel]] = count;
    AloneHighs[channel][HStackTip[channel]] = value;
    AloneHighCount[channel][HStackTip[channel]] = count;
    HStackTip[channel]++;
}

但是,当我尝试设置数据时出现了我的问题(没问题),并且,从第二个实例是“监听”模式(它必须主动调用 getter,但此时没关系)来获取它,我接收零或初始化为的值,而无需任何更改。

我的调试非常详细的日志很好地证明了这一点:

发送实例在其通道上设置的整个变量上进行任务重置(置零),然后置入一些高点(高点的值和高点的计数)以及低点,然后设置一个标志,指示所有发送的数据并完成。

日志看起来不错,如果我尝试调用它的 getter (例如,HStack 提示:getter 值,Lows:getter 值):

Chart:  #2 | Study: PrecHLCD | Library on channel 0 reset. HStack tip: 0 | 2015-09-17  16:31:03
Chart:  #2 | Study: PrecHLCD | High set | 2015-09-17  16:31:03
Chart:  #2 | Study: PrecHLCD | Low set | 2015-09-17  16:31:03
Chart:  #2 | Study: PrecHLCD | Finish flag set: 1. Stack tips Lows: 1, Highs: 1 | 2015-09-17  16:31:03

但是,当我尝试获取相同的数据时(正如我对共享段库所期望的那样),我只接收零,或者(正如我尝试的那样)首先初始化值,如日志所述:

Chart:  #1 | Study: PrecHLCD | loop. On channel 0 data sending status: 0 (HST 0, LST 0) | 2015-09-17  16:31:26

共享库中的函数照常导入:

    #pragma comment(lib, "C:\\SierraChart\\Data\\IntercomSingleton.lib")

    extern "C" __declspec(dllimport) void __stdcall SetHigh(int channel, float value, int count);
    extern "C" __declspec(dllimport) void __stdcall SetLow(int channel, float value, int count);
    extern "C" __declspec(dllimport) void __stdcall ResetLibrary(int channel);
    extern "C" __declspec(dllimport) int __stdcall BroadcastedHighs(int channel, float value);
.
.
.

你能告诉我有什么问题吗?非常感谢

PS 重要说明:我早期使用的这种库,setter/getter 较少,运行良好,可以处理数据,我很高兴,但是发生了一些事情,我找不到什么和原因,我很担心第二天

4

1 回答 1

0

解决了!!dll 的变量在其函数调用、完成工作和卸载时不是持久的。

导致解决方案的整个研究将通过编辑这篇文章在这里,我现在没有足够的时间来描述它。

于 2015-09-21T08:39:53.780 回答