gpt4 book ai didi

c++ - Strtok_r() 并移动保存指针

转载 作者:行者123 更新时间:2023-11-28 06:27:18 26 4
gpt4 key购买 nike

我正在尝试为微型 cstrings“&&”和“||”标记一个字符串。我一直在使用 strtok_r() 取得一些成功,但由于对 strtok_r() 缺乏理解,或者可能是对指针的误解,我似乎无法让解析器正常运行。

代码

121         char *cstr3;
122 char* sp;
123 int fc = findclosest(cstr2);
124 switch (fc){
125 case 0:
126 std::cout << "that's it"; //debug
127 cstr3 = strtok_r(cstr2, ";", &sp);
128 break;
129
130 case 1:
131 std::cout << ";"; //debug
132 cstr3 = strtok_r(cstr2, ";", &sp);
133 break;
134
135 case 2:
136 std::cout << "&&"; //debug
137 cstr3 = strtok_r(cstr2, "&", &sp);
138 break;
139
140 case 3:
141 std::cout << "||"; //debug
142 cstr3 = strtok_r(cstr2, "|", &sp);
143 break;
144
145 default:
146 break;
147 }
148
149 puts(cstr3);//debug
150 while(cstr3 != NULL)
151 {
152 char mustfail =0;
153 char mustpass =0;
154
155 int a = fcall(breakitup(cstr3));
156
157 if (a > 0){
158 delete[] cstr;
159 goto skippy;
160 }
161
162 fc = findclosest(cstr3);
163
164 switch (fc){
165 case 0:
166 cstr3 = strtok_r(NULL, ";", &sp);
167 break;
168
169 case 1:
170 std::cout << ";"; //debug
171 cstr3 = strtok_r(NULL, ";", &sp);
172 break;
173
174 case 2:
175 std::cout << "&&"; //debug
176 cstr3 = strtok_r(NULL, "&", &sp );
177 break;
178
179 case 3:
180 std::cout << "||"; //debug
181 cstr3 = strtok_r(NULL, "|", &sp);
182 break;
183
184 default:
185 break;
186 }
187 if (cstr3 != NULL){ //debug
188 puts(cstr3);
189 }
190 }

它不是提供没有“&”或“|”的下一个命令,而是提供以一个开始的行。因此我假设解析器只删除了第一个“&”

为了更好地解释,以下是输出(以“>”开头的行表示输入)。抱歉,一些调试语句仍在输出中。

> pwd; ls

;pwd //debug
/folder/folder/folder/project //function works properly
ls //debug
notrshell README.md rshell.cpp shelly supershell

> pwd && ls

&&pwd //debug
/folder/folder/folder/project
& ls //debug

由于那个额外的“&”,下一个命令被错误地解释,有没有一种简单的方法可以跳过那个“&”?

我试过再次调用完全相同的命令,例如:

176                 cstr3 =  strtok_r(NULL, "&", &sp );
177 cstr3 = strtok_r(NULL, "&", &sp );

假设它会简单地删除另一个 &,但这没有用。

我也试过移动指针来偷偷跳过额外的&,

176                 cstr3 =  1+ strtok_r(NULL, "&", &sp );

但这不仅完全俗气,而且也行不通。

有什么关于 strtok_r() 或指针的知识可以解决这个问题吗?

最佳答案

考虑这个输入:pwd && ls

在第一个 switch 语句中,您进行:

cstr3 = strtok_r(cstr2, "&", &sp);

在这个调用之后,cstr3 指向字符串:"pwd ",因为,根据手册:

Each call to strtok() returns a pointer to a null-terminated string containing the next token. This string does not include the delimiting byte.

sp 指向...好吧,手册并没有按字面意思说明,但它很可能指向它在上次调用中完成的位置 - 在我们的例子中,就在定界符之后,这是&。因此,它指向我们字符串的一部分:& ls。这就是在第二次 strtok_r 调用中被标记化的内容。

我不能确定,但​​我想 findclosest 函数有问题 - 你能确认它在这里返回了正确的值吗?

无论如何,从手册:

The delim argument specifies a set of bytes that delimit the tokens in the parsed string.

这意味着您应该能够使用 "&&" 作为分隔符。这应该可以解决问题。

当您调用系统函数时,请记住,对于某些(大多数?)shell,命令末尾的单个 & 会将其执行置于后台。

关于c++ - Strtok_r() 并移动保存指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28306462/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com