MISRA C++:2008 Rule 2-13-5

Узкие и широкие строковые литералы не должны быть конкатенированы

Описание

Примечание

Используйте Bug Finder вместо Code Prover для проверки правил кодирования. Поддержка кодирования правил, регистрируясь в Code Prover будет удалена в будущем релизе. См. Вопросы совместимости.

Управляйте определением

Узкие и широкие строковые литералы не должны быть конкатенированы.

Объяснение

Узкие строковые литералы заключены в двойные кавычки без префикса. Широкие строковые литералы заключены в двойные кавычки с префиксным L вне кавычек. Смотрите строковые литералы.

Конкатенация узких и широких строковых литералов может привести к неопределенному поведению.

Поиск и устранение проблем

Если вы ожидаете нарушение правила, но не видите его, относитесь, чтобы Диагностировать, Почему Кодирующие Стандартные Нарушения Не Появляются как ожидалось.

Примеры

развернуть все

char array[] = "Hello" "World";
wchar_t w_array[] = L"Hello" L"World";
wchar_t mixed[] = "Hello" L"World"; //Noncompliant

В этом примере, в инициализации массива mixed, узкий строковый литерал "Hello" конкатенирован с широким строковым литералом L"World".

Проверяйте информацию

Группа: лексические соглашения
Категория: необходимый

Вопросы совместимости

развернуть все

Не рекомендуемый запуск в R2021b

Введенный в R2013b