【发布时间】:2015-02-03 18:46:59
【问题描述】:
我正在尝试为微型 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 }
它不是在没有“&”或“|”的情况下提供下一个命令,而是在 STARTING 行中提供一个。因此我假设解析器只删除了第一个“&”
为了更好的解释,以下是输出(以'>'开头的行表示输入)。抱歉,一些调试语句仍在输出中。
> 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() 或指针,我能学到什么东西来解决这个问题吗?
【问题讨论】:
-
我推荐使用
std::string和string::find和string::substr函数。 C 风格的字符串是不安全的,strtok()函数修改了 C 风格的字符串。 -
@ThomasMatthews
我不喜欢“C 风格的字符串是不安全的”逻辑 - C 风格的字符串肯定更难正确使用,并且有许多程序员需要的潜在误用场景请注意,但这并不意味着他们没有自己的位置,应该被完全抛弃。这种想法会导致“人死于车祸。所以汽车是不安全的。因此,任何人都不应该再使用汽车。”和其他这样的愚蠢。 意见> -
@twalberg 这个问题被专门标记为 C++ 并且可以通过 C++ 方法避免的 C 样式字符串的可能陷阱数量使得 C 字符串方法似乎不是最佳的在这种情况下.
-
感谢大家的cmets,不幸的是我使用的大部分函数都在cstrings中,而且我已经布置的大部分架构都是cstrings,但我一定会使用未来字符串的便利性!
-
findclosest函数有什么作用?它的返回值是什么意思?