Arduino функция String.indexOf - странное поведение.

Обсуждаем контроллеры компании Atmel.
Ответить
Друг Кота
Аватара пользователя
Сообщения: 3487
Зарегистрирован: Вт окт 22, 2013 04:37:23
Откуда: Казань

Сообщение smacorp »

Кто-нибудь сталкивался с таким странным поведением функции String.indexOf ?

Широко известный модуль SIM800 после выполнения AT команды возвращает ответ.
Ответ забирается в String переменную, где потом функцией indexOf ищется последовательность символов.

И эта примитивная конструкция не работает - последовательность символов точно присутствует в строке, но indexOf возращает -1.

Ломая голову, выяснил, что SIM800 по какой-то причине в ответе первым символом возвращает 0. Причём, не символ 0 (цифра), а именно ASCII с кодом 0.

Почему SIM800 так делает отдельный разговор (от этой китайской херни можно ожидать чего угодно), а вот почему indexOf ничего не находит в такой строке - загадка.

И ещё можно было бы понять такое поведение, если бы наличие нуля означало бы для indexOf конец строки, как в стандартных статических строках C\C++, так хрен там - функция length показывает правильную длину строки, но увеличенную на 1 - тот самый \0 в начале. И, если этот \0 удалить, indexOf начинает работать правильно.

Почему indexOf этот \0 не игнорирует? В документации об этом ни слова. Чего я не понимаю?
Платы для HLDI - установки лазерной засветки фоторезиста.
Фоторезист Ordyl Alpha 350
Жидкое олово для лужения плат (видео) - самое лучшее и только у меня.
Паяльные маски XV501T-4 и KSM-S6189 (5 цветов).
Заказ печатных плат - pcbsmac@gmail.com
Реклама
Поставщик валерьянки для Кота
Сообщения: 1916
Зарегистрирован: Сб май 05, 2012 20:24:52
Откуда: KN34PC, Болгария

Сообщение veso74 »

indexOf(...): для того, чтобы функция давала -1, есть две причины:

Код: Выделить всё

1. if (found == NULL) return -1;
2. if (fromIndex >= len) return -1;
для len:

Код: Выделить всё

unsigned int len;       // the String length (not counting the '\0')
Все это видно в папках Arduino:

Код: Выделить всё

C:\Program Files (x86)\Arduino\hardware\arduino\avr\cores\arduino\
файлы: WString.cpp и WString.h
---
Упс ... для AVR в Arduino IDE или для "чистого" AVR? Думаю, что то же самое с AVR.
Контактная информация:
Реклама
Друг Кота
Аватара пользователя
Сообщения: 3487
Зарегистрирован: Вт окт 22, 2013 04:37:23
Откуда: Казань

Сообщение smacorp »

veso74, ну, с fromIndex всё просто - я его не передаю в функцию вообще, поэтому он никак не может быть больше len.

Но вот указание файла исходника помогло разобраться, спасибо.

Я грешным делом думал, что String.indexOf - самостоятельная реализация, а это оказалась тупо обёртка над классической функцией strchr, которая, разумеется, видя \0 первым символом, считает строку нулевой таки длины и понятно что ничего не находит.

Мда, бывает же.
Платы для HLDI - установки лазерной засветки фоторезиста.
Фоторезист Ordyl Alpha 350
Жидкое олово для лужения плат (видео) - самое лучшее и только у меня.
Паяльные маски XV501T-4 и KSM-S6189 (5 цветов).
Заказ печатных плат - pcbsmac@gmail.com
Поставщик валерьянки для Кота
Сообщения: 1916
Зарегистрирован: Сб май 05, 2012 20:24:52
Откуда: KN34PC, Болгария

Сообщение veso74 »

String в Arduino уже String class. Многие вещи там сделаны для "пользы пользователя".
А если привыкли к старым способам "сделай сам", это становится путаницей :).
Контактная информация:
Реклама
Эиком - электронные компоненты и радиодетали
Ответить

Вернуться в «AVR»