C++结构体数组拷贝问题

先描述问题:

dll库中定义的全局变量,在调用程序中只能使用,不能查看(显示未定义),怎样将dll中的全局变量结构体数组,拷贝到调用程序中?其中数组类型和长度知道。

除了在调用程序中先定义一个较大的同类型结构体数组(确保数组长度比dll中全局变量结构体数组长),然后拷贝原数组长度的结构体变量外,是否可以用先申请一块和全局变量数组同样大小的内存,然后拷贝原数组这种方法呢?

测试发现好像是不行的。为什么呢?

我们先试试本地结构体数组这种拷贝:

#include <stdio.h>
#include <stdint.h>


typedef struct _tagQrsData
{
	long long dwRpos;  // R峰位置,即数据点数,从1开始计,16个字节
	float fRvalue;  // R峰值,4个字节
	uint8_t bRreliability;  // R峰可信度 可信:1,可能不可信:0  1个字节
	uint8_t bRflag;  // R峰方向 正向:1,负向:0  1个字节
	// 16+4+1*2 = 22字节 

	short sRR;  // RR间期   2个字节
	uint8_t bRRstate;  // RR间期类型  1个字节

	short sEPoint;  //	E点,和当前R波的相对位置(点数)  2个字节
	short sJPoint;  // J点,和当前R波的相对位置(点数)  2个字节
	short sSTPoint;  // ST测量点, 和当前R波的相对位置(点数)  2个字节
	float fSTValue;  // ST测量点和E点电压差值  4个字节
	// 2*3+4 = 10字节 
	char cHeartBeatType;  // 心拍类型  1字节
}QRSDATA; // 22+2+1+10+1 = 36个字节


int main()
{
	int i;
	QRSDATA qrsdata[10] = {0};
	for (i=0;i<10;i++)
	{
		qrsdata[i].bRflag = i;
	}

	for ( i = 0; i < 10; i++)
	{
		printf("qrsdata[i].bRflag=%d\n", qrsdata[i].bRflag);
	}

	QRSDATA* qrsdata1 = (QRSDATA*)malloc(10 * sizeof(QRSDATA));
	if (qrsdata1 == NULL) {
		printf("动态内存qrsdata1分配失败\n");
		return NULL;
		exit(1);
	}
	printf("动态内存qrsdata1分配成功\n");
	memset(qrsdata1, 0, 10 * sizeof(QRSDATA));
	memcpy(qrsdata1, qrsdata, 10 * sizeof(QRSDATA));

	for (i = 0; i < 10; i++)
	{
		printf("qrsdata1[i].bRflag=%d\n", qrsdata1[i].bRflag);
	}

	return 0;
}

x64平台,编译通过,运行时内存拷贝语句直接报错。换成x86平台,则运行正常。

进一步,测试x64平台,直接拷贝数值数组:

#include <stdio.h>
#include <stdint.h>


int main()
{
	int i;
	int qrsdata[10] = {0};
	for (i=0;i<10;i++)
	{
		qrsdata[i] = i;
	}

	for ( i = 0; i < 10; i++)
	{
		printf("qrsdata[i]=%d\n", qrsdata[i]);
	}

	int* qrsdata1 = (int*)malloc(10 * sizeof(int));
	if (qrsdata1 == NULL) {
		printf("动态内存qrsdata1分配失败\n");
		return NULL;
		exit(1);
	}
	printf("动态内存qrsdata1分配成功\n");
	memset(qrsdata1, 0, 10 * sizeof(int));
	memcpy(qrsdata1, qrsdata, 10 * sizeof(int));

	for (i = 0; i < 10; i++)
	{
		printf("qrsdata1[i]=%d\n", qrsdata1[i]);
	}

	return 0;
}

没想到还是一样报错!x64平台无法使用memcpy?实在不理解,网上也没查到答案。姑且记在这里吧。

对于x86平台,是可以的。完全能随意拷贝,程序改成下面这样都行,循环拷贝,两种都可以:

#include <stdio.h>
#include <stdint.h>


int main()
{
	int i;
	int qrsdata[10] = {0};
	for (i=0;i<10;i++)
	{
		qrsdata[i] = i;
	}

	for ( i = 0; i < 10; i++)
	{
		printf("qrsdata[i]=%d\n", qrsdata[i]);
	}

	int* qrsdata1 = (int*)malloc(10 * sizeof(int));
	if (qrsdata1 == NULL) {
		printf("动态内存qrsdata1分配失败\n");
		return NULL;
		exit(1);
	}
	printf("动态内存qrsdata1分配成功\n");
	memset(qrsdata1, 0, 10 * sizeof(int));
	//int qrsdata1[10] = {0};
	//memcpy(qrsdata1, qrsdata, 10 * sizeof(int));

	for (i = 0; i < 10; i++)
	{
		memcpy(&qrsdata1[i], &qrsdata[i], sizeof(int));
		printf("qrsdata1[i]=%d\n", qrsdata1[i]);
		/* memcpy(qrsdata1, &qrsdata[i], sizeof(int));
		 printf("qrsdata1[i].bRflag=%d\n", qrsdata1->bRflag);
         qrsdata1++; */		
	}

	return 0;
}

所以,开篇的问题,应该是跟平台有关。

但是,再次调试程序,发现貌似可以。拷贝过去的内存完全可以当原数组一样使用,这是为什么呢?

QRSDATA* qrsdata1 = (QRSDATA*)malloc(QRS_cnt * sizeof(QRSDATA));
if (qrsdata1 == NULL) {
	printf("动态内存qrsdata1分配失败\n");
	return NULL;
	exit(1);
}
printf("动态内存qrsdata1分配成功\n");
memset(qrsdata1, 0, QRS_cnt * sizeof(QRSDATA));
memcpy(qrsdata1, qrsdata, QRS_cnt * sizeof(QRSDATA));

对比被拷贝的:

找不到原因......

  • 8
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值