Есть функция проверяющяя является ли её первый аргумент закрывающим тегом для второго аргумента. В первом сравнении я хочу проверить аргументы, а заодно передвинуться на один символ вперёд, но second почему-то не увеличивается. Что я не так делаю?
int isclose (char *first, char *second) { if (*(first++) != '<' && *(second++) != '<') // Проверяю являются ли аргументы тегами вообще return 0;
if (*(first++) != '/') return 0;
while (*(first++) && *(second++)) if (*first != *second) return 0;
Как только значение выражения становится известным (а значение FALSE && что_угодно уже известно, это FALSE в любом случае), вычисление выражения прекращается. То есть, до второго сравнения дело даже не доходит...
Кстати, конкретно в твоем случае && - это ошибка. Для того, чтоб уйти из функции, достаточно, чтоб ОДИН из ее аргументов не начинался с '<', то есть, поставь ||, и в этом случае (в первом условии) у тебя будет все нормально. Дальше, в цикле while все-таки придется переделать... Например, так:
while (*first && *second) if (*first++ != *second++) return 0;
Игорь
4.11.2011 11:33
Да, спасибо, опять глупая ошибка, прям как с тем калькулятором...
Кстати, уменя проблема с программой, где используюется список (ошибка сегментирования), а в gdb тяжело работать с адресами, есть ли какие нибудь альтернативы или плагины к нему облегчающие это.
IUnknown
4.11.2011 13:29
Цитата
в gdb тяжело работать с адресами
Не замечал особых проблем... Если хочешь - присоедини программу (можно в приват), я помогу найти, где происходит ошибка.
Игорь
4.11.2011 15:14
Не, спасибо, я сам. В крайнем случае возьму лист и карандаш.
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.