首页 > 解决方案 > strtok_r 在标记化后返回不正确的数据

问题描述

下面是我尝试使用 strtok_r() 来标记我的字符串以获取第一个标记的代码,即在这种情况下为 38。
如果您以某种方式观察输出,我的令牌被错误地提取(参考输出:38 被提取为 8)
这是一个间歇性问题,并非每次都会发生。我无法找到任何解决方案。

PS忽略我用来打印输出的logger函数,它只是类似于printf()的东西

char cDelimeter = ',';
char *pRecordString = NULL;
char *pRemainString = NULL;
char szMsgBuff[MAX_BUFFER];

/*some code*/

LOG2(INF,"#ONLINEREQ : <%s>", szMsgBuff);
LOG3(INF,"#ONLINEREQ Before tokenizing: pRecordString<%s> pRemainString<%s>", pRecordString,pRemainString);
pRecordString = strtok_r(szMsgBuff,&cDelimeter,&pRemainString);
LOG3(INF,"#ONLINEREQ After tokenizing: pRecordString<%s> pRemainString<%s>", pRecordString,pRemainString);

输出

#ONLINEREQ : <38,CM|Member Name|Total ED|Net Buy Premium|Init Margin|ELMMargin|PreExpMargin|AdhocMargin|DeliveryMargin|UNDirectionalMRGN|CONMRGN|Crystallised MTM|Fwd Init Margin|Fwd Mntnce Margin|Total Utilization|Free Capital|MTM P/L|%ofEffectiveloss,^M
>
#ONLINEREQ Before tokenizing: pRecordString<(null)> pRemainString<(null)>
#ONLINEREQ After tokenizing: pRecordString<8> pRemainString<CM|Member Name|Total ED|Net Buy Premium|Init Margin|ELMMargin|PreExpMargin|AdhocMargin|DeliveryMargin|UNDirectionalMRGN|CONMRGN|Crystallised MTM|Fwd Init Margin|Fwd Mntnce Margin|Total Utilization|Free Capital|MTM P/L|%ofEffectiveloss,^M
>

标签: c++cc-stringsstrtok

解决方案


根据手册页strtok_r有一个const char *分隔符。我猜你是通过指向一个随机终止的字符串来搞砸操作,即&cDelimeter.

尝试 ...

const char *cDelimeter = ",";

...

pRecordString = strtok_r(szMsgBuff,cDelimeter,&pRemainString);

推荐阅读