OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4572|回复: 10

使用sprintf,程序进入 hardfault handler

[复制链接]

15

主题

69

帖子

0

精华

初级会员

Rank: 2

积分
123
金钱
123
注册时间
2015-3-20
在线时间
5 小时
发表于 2015-8-6 08:50:56 | 显示全部楼层 |阅读模式
5金钱
[mw_shl_code=c,true]程序没有运行,一开始就进入了 hardfault handler,如果把中间两个sprintf注释掉,只留第一个和第四个sprintf,就不会错,不知道什么原因[/mw_shl_code] [mw_shl_code=c,true][/mw_shl_code] [mw_shl_code=c,true][/mw_shl_code] [mw_shl_code=c,true][/mw_shl_code] [mw_shl_code=c,true]char file_data1[56]={0}; char file_data2[56]={0}; char file_data3[128]={0}; char file_data4[512]={0}; sprintf(file_data1 ,"%02d:%02d:%02d" //时间 ,bcd2int(fstime.Hour) ,bcd2int(fstime.Minute) ,bcd2int(fstime.Second) ); sprintf(file_data2 ,"Latitude %02d.%d Longitude %03d.%d " //纬度 ,GPSData_GetLatitude()/1000000 ,GPSData_GetLatitude()-(GPSData_GetLatitude()/1000000)*1000000 //经度 ,GPSData_GetLongitude()/1000000 ,GPSData_GetLongitude()-(GPSData_GetLongitude()/1000000)*1000000 ); // sprintf(file_data3 // ,"speed %03d.%d soot %ld corona %02.02f temperature %03.01f NOx %04.1f O2 %f" // //时间 // // //速度 // ,GPSData_GetSpeed()/10 // ,GPSData_GetSpeed()-GPSData_GetSpeed()/10*10 // //CAN设备ID // //Soot current烟尘电流 // //Corona current // //内部温度 // ,Get_OBD_soot() // ,Get_OBD_corona() // ,Get_OBD_temperature() // ,Get_NOx() // ,Get_O2() // ); sprintf(file_data4 ,"MAF %lf ALD %d IAT %d MAP %d RPM %d NowSpd %d ENGLOAD %d WATER_TEMPER %d VOLTAGE %d TotalMileage %lf \r\n" //OBD数据 //1.OBD进气量值 ,Get_OBDCAR_MAF() //2.绝对负荷值 ,Get_OBDCAR_ALD() //3.OBD进气温度 ,Get_OBDCAR_IAT() //4.进气歧管压 ,Get_OBDCAR_MAP() //5.发动机转速 ,Get_OBDCAR_RPM() //6. 当前车速 ,Get_OBDCAR_NowSpd() //7. 发动机负荷 ,Get_OBDCAR_ENGLOAD() //8. 发动机冷却液温度 ,Get_OBDCAR_WATER_TEMPER() //9.汽车电瓶电压 ,Get_OBDCAR_VOLTAGE() //10.当前行驶里程 ,Get_OBDCAR_TotalMileage() );[/mw_shl_code]

最佳答案

查看完整内容[请看2#楼]

局部变量太多了,死了正常。 把你前面那一堆数组,全放全局变量先。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2015-8-6 08:50:57 | 显示全部楼层
局部变量太多了,死了正常。
把你前面那一堆数组,全放全局变量先。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

21

主题

124

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
260
金钱
260
注册时间
2013-1-10
在线时间
10 小时
发表于 2015-8-6 08:53:36 | 显示全部楼层
sprintf()没有定义重新写一遍  或者检查一下串口相关函数
个人博客www.xiaovdiy.cn
https://shop100764513.taobao.com/
回复

使用道具 举报

15

主题

69

帖子

0

精华

初级会员

Rank: 2

积分
123
金钱
123
注册时间
2015-3-20
在线时间
5 小时
 楼主| 发表于 2015-8-6 09:00:29 | 显示全部楼层
回复【2楼】雨山:
---------------------------------
没有定义,编译都过不了了。。。
回复

使用道具 举报

1

主题

72

帖子

0

精华

初级会员

Rank: 2

积分
115
金钱
115
注册时间
2015-7-16
在线时间
3 小时
发表于 2015-8-6 09:14:32 | 显示全部楼层
回复【3楼】runfan:
--------------------------------
数组越界?
回复

使用道具 举报

15

主题

69

帖子

0

精华

初级会员

Rank: 2

积分
123
金钱
123
注册时间
2015-3-20
在线时间
5 小时
 楼主| 发表于 2015-8-6 09:20:35 | 显示全部楼层
回复【4楼】joe_knight:
---------------------------------
我把数组调大了,还是这样。。。
回复

使用道具 举报

1

主题

72

帖子

0

精华

初级会员

Rank: 2

积分
115
金钱
115
注册时间
2015-7-16
在线时间
3 小时
发表于 2015-8-6 09:43:00 | 显示全部楼层
GPSData_GetLatitude,GPSData_GetLongitude,GPSData_GetSpeed这系列函数确定运行正确?它们的返回值类型?
回复

使用道具 举报

14

主题

1592

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
2622
金钱
2622
注册时间
2014-7-17
在线时间
350 小时
发表于 2015-8-6 10:09:24 | 显示全部楼层
帮顶、。。。。
回复

使用道具 举报

2

主题

239

帖子

0

精华

高级会员

Rank: 4

积分
545
金钱
545
注册时间
2015-6-5
在线时间
110 小时
发表于 2015-8-6 10:35:24 | 显示全部楼层
印浮點數你有單測過能用嗎?
回复

使用道具 举报

0

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
76
金钱
76
注册时间
2015-4-3
在线时间
8 小时
发表于 2016-3-18 15:46:45 | 显示全部楼层
怎么解决的呢
感谢这个平台,感谢大家的阅览!
回复

使用道具 举报

6

主题

1097

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3571
金钱
3571
注册时间
2014-12-2
在线时间
365 小时
发表于 2016-3-18 15:59:21 | 显示全部楼层
可能是堆栈溢出了,默认栈只有1k,
可以去启动文件里把Stack_Size调大点儿
坚决不用寄存器,拒绝重复造轮子。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-19 22:28

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表