开发中遇到的问题(2015-05-25)

1.修改程序要注意代码的上下文。

eg 1:

ERR:

			if (GetTimeOverFlag(&g_sRentalReturnlBikeTime))//超时
			{
				CardReaderBuzzer(piFileHandleDEF_CARD_SET_BUZZER_ERR_TIME);//读卡器蜂鸣器
				_rf_sleep(piFileHandle);
				FPR("0 _rfsleep");
#if DEF_ENABLE_NET_RENTAL_BIKE  		==			DEF_ENABLE_NET_RENTAL_BIKE_WRITE_CARD
 
#else
				ComPlayWave(__FILE__, __LINE__, __FUNCTION__, DEF_WAVE_NO_DKSBDEF_TYPE_WAV);//请重新刷卡,卡片停留在读卡区域5秒钟				
#endif
				_printf("++++++ 刷卡网络等待超时 return ++++++");
				//设置卡是没有注册的,所以这里判断是否是设置ip的卡
				iRetCode = readCardType(piFileHandle);
				return DEF_FAILURE_REASON_NET_RENTAL_BIKE_TIMEOUT;//后台返回超时
			}

OK:

			if (GetTimeOverFlag(&g_sRentalReturnlBikeTime))//超时
			{
				CardReaderBuzzer(piFileHandleDEF_CARD_SET_BUZZER_ERR_TIME);//读卡器蜂鸣器
				_rf_sleep(piFileHandle);
				FPR("0 _rfsleep");
#if DEF_ENABLE_NET_RENTAL_BIKE  		==			DEF_ENABLE_NET_RENTAL_BIKE_WRITE_CARD
				//设置卡是没有注册的,所以这里判断是否是设置ip的卡
				iRetCode = readCardType(piFileHandle);
#else
				ComPlayWave(__FILE__, __LINE__, __FUNCTION__, DEF_WAVE_NO_DKSBDEF_TYPE_WAV);//请重新刷卡,卡片停留在读卡区域5秒钟				
#endif
				_printf("++++++ 刷卡网络等待超时 return ++++++");
 
				return DEF_FAILURE_REASON_NET_RENTAL_BIKE_TIMEOUT;//后台返回超时
			}


2.调试某个模块,最好是有测试函数。

在整体调试程序时,因为某个模块有问题,影响了整体的调试,最好将出错的模块找出来,单独调试。

嵌入式linux调试app每次都要重新编译,编译后要下载文件到测试板运行调试,费时。

while (1)//test
{
	iRetCode = rf_m1_init(piFileHandle);
	if (iRetCode == DEF_STATUE_M1_INIT_OK)
	{
		CCardInfo CardInfoTmp;
		statue = ProcessRentalBikeWrite(piFileHandle, &CardInfoTmpDEF_RENTAL_FLAG); //借车时的刷卡写卡流程
	}
	else
	{
	}
	sleep(5);
}
int ProcessRentalBikeWrite(intpiFileHandleCCardInfopCardInfoTmpchar cflag)//借车时的刷卡写卡流程
{
	int iRetCode = 0;
	int iCount = 0;
	int i = 0;
	int iTryMaxTimes = 0;
 
	if (cflag == DEF_RENTAL_FLAG)//正常的借车,短信借车是不用写卡的
	{
		int iTryMaxTimes = 10;
		for (i = 0; i < iTryMaxTimesi++)
		{
#if 0
			int iRetCode = unionpay_m1_init(piFileHandle);//写卡是有问题的,这个是针对银行卡
#else
			iRetCode = rf_m1_init(piFileHandle);
#endif
			if (iRetCode == DEF_STATUE_M1_INIT_OK)
			{
				iRetCode = 0;
				iRetCode = ProcessBikeWriteM1(piFileHandlepCardInfoTmpDEF_RENTAL_FLAG); //用户刷卡后,初始化数据
				if (iRetCode != DEF_STATUE_M1_WRITE_OK)

 一下就发现unionpay_m1_init 是这个函数的问题。




3.for函数的基本要素,每次记得最后要添加break continue还有最后一次的处理

int iTryMaxTimes = 10;
for (i = 0; i < iTryMaxTimesi++)
{
	XXX;
	break;
}
else
{
	if (i >= (iTryMaxTimes-1))
	{//最后一次也不成功
		PRERR("最后一次写M1卡不成功");
		iRetCode = DEF_STATUE_M1_ICODE2_WRITE_FAIL;
		return iRetCode;
	}
	usleep(100 * 1000);
}




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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值