免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3930 | 回复: 13
打印 上一主题 下一主题

atol遇到的问题,急求正解 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-01-13 09:25 |只看该作者 |倒序浏览
先上代码

  1. AreaCode1 = atol(pMsg->strAreaCode);
  2. Areacode2 = atol(m_sMsg[i].strAreaCode);

  3. printf("OpMsg [%s:%d][%s:%d]",pMsg->strAreaCode,lAreaCode1,m_sMsg[i].strAreaCode,lAreacode2);
复制代码


程序运行正常一段时间之后,打印出来的突然就如下
OpMsg [0415:415][24:24]
OpMsg [0415:415][411:411]
OpMsg [0415:415][412:412]
OpMsg [0415:415][413:413]
OpMsg [0415:415][414:414]
OpMsg [0415:415][415:415]

OpMsg [0415:-1431655760][24:18666672]
OpMsg [0415:-1431655760][411:40566672]
OpMsg [0415:-1431655760][412:40666672]
OpMsg [0415:-1431655760][413:40766672]
OpMsg [0415:-1431655760][414:40866672]
OpMsg [0415:-1431655760][415:40966672]
OpMsg [0415:-1431655760][416:41066672]
OpMsg [0415:-1431655760][417:41166672]
OpMsg [0415:-1431655760][418:41266672]
OpMsg [0415:-1431655760][419:41366672]
OpMsg [0415:-1431655760][410:40466672]
OpMsg [0415:-1431655760][421:41566672]
OpMsg [0415:-1431655760][427:42166672]

重启之后,正常一段时间,又会出现这个问题

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
2 [报告]
发表于 2010-01-13 09:39 |只看该作者
是说负数么?你用%u来输出吧

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
3 [报告]
发表于 2010-01-13 09:39 |只看该作者
出现什么问题了?

论坛徽章:
0
4 [报告]
发表于 2010-01-13 09:42 |只看该作者
超过最大int值了吧?? 你这个i最大是多少啊

论坛徽章:
0
5 [报告]
发表于 2010-01-13 10:15 |只看该作者
原帖由 cjaizss 于 2010-1-13 09:39 发表
出现什么问题了?


我下一步的操作,是要比较这两个值是否相同,但是从日志可以看出来,出问题之后的肯定无法比较了

论坛徽章:
0
6 [报告]
发表于 2010-01-13 10:20 |只看该作者
原帖由 wuexp 于 2010-1-13 09:42 发表
超过最大int值了吧?? 你这个i最大是多少啊


这个i是放在一个循环里面的,for(i=0;i < 50)的,从日志也可以看到,打印出来的,字符串类型数据是正确的,只是转换之后的数值异常了

论坛徽章:
0
7 [报告]
发表于 2010-01-13 10:31 |只看该作者
方便的话  贴出所有代码...

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
8 [报告]
发表于 2010-01-13 10:33 |只看该作者
atol与打印之间应该还有别的代码吧,内存可能有溢出

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
9 [报告]
发表于 2010-01-13 10:40 |只看该作者
对atol这个函数不懂,我并不知道
atol("0405")出来一个多少

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
10 [报告]
发表于 2010-01-13 10:50 |只看该作者

你保证字符串结尾有'\0'么?

pMsg->strAreaCode有'\0'结尾么
m_sMsg.strAreaCode'\0'结尾么

不保证的话,atol干出啥事只有鬼知道
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP