CERT C: Rule DCL41-C

Не объявляйте переменные в операторе switch перед первой меткой случая

Описание

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

Не объявляйте переменные в операторе switch перед первым случаем label.[1]

Реализация Polyspace

Это средство проверки проверяет на объявление переменной перед первым case метка.

Примеры

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

Проблема

Проблема происходит, когда вы задаете переменную в switch блокируйтесь перед первым case метка.

Риск

В switch блокируйте, управляйте скачками к одному из case метки или default пометьте, в зависимости от выражения управления switch оператор. Если вы задаете переменную перед первым case пометьте, компилятор игнорирует объявление переменной. Операции чтения на этой переменной могут привести к неопределенным значениям.

Пример — несовместимое объявление переменной
void bar(int iTemp){
	//...
}
void foo(){
	//...
	int bFlag;
	//...
	switch(bFlag){
		int temp;  //Noncompliant
		bar (temp);
	case 0:
            //...
		break;
	case 1:
            //...
		break;	
		
	}
	
}

В этом примере, переменной temp объявляется перед первым case метка. Компилятор игнорирует это объявление. Если вы выполняете операцию чтения на temp в одном из блоков случая операция может привести к неопределенным значениям. Polyspace® отмечает объявление переменной.

Пример — совместимый switch Оператор

Чтобы устранить предыдущую проблему, переместите объявление переменной из switch оператор.

void bar(int iTemp){
	//...
}
void foo(){
	//...
	int bFlag;
	//...
	int temp;//Compliant  
	bar (temp);	
	switch(bFlag){

	case 0://...
		break;
	case 1:
		break;			
	}	
}

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

Группа: правило 02. Объявления и инициализация (DCL)
Введенный в R2019a

[1]  Это программное обеспечение было создано MathWorks, включающим фрагменты: “Веб-сайт SEI CERT-C”, © 2017 Carnegie Mellon University, веб-сайт SEI CERT-C © 2017 Carnegie Mellon University”, CERT SEI C Кодирование Стандарта – Правил для Разработки безопасных, Надежных и Защищенных систем – 2 016 Выпусков”, © 2016 Carnegie Mellon University, and “CERT SEI Стандарт Кодирования C++ – Правил для Разработки безопасных, Надежных и Защищенных систем на C++ – 2 016 Выпусков” © 2016 Carnegie Mellon University, со специальным разрешением от его Института программной инженерии.

ЛЮБОЙ МАТЕРИАЛ УНИВЕРСИТЕТА КАРНЕГИ-МЕЛЛОН И/ИЛИ ЕГО ИНСТИТУТА ПРОГРАММНОЙ ИНЖЕНЕРИИ СОДЕРЖАЛ, ЗДЕСЬ ПРЕДОСТАВЛЯЕТСЯ НА БАЗИСЕ "ASIS". УНИВЕРСИТЕТ КАРНЕГИ-МЕЛЛОН НЕ ДАЕТ ГАРАНТИЙ НИКАКОГО ВИДА, ИЛИ ОПИСАЛ ИЛИ ПОДРАЗУМЕВАЛ, ОТНОСИТЕЛЬНО ЛЮБОГО ВОПРОСА ВКЛЮЧАЯ, НО НЕ ОГРАНИЧИЛ, ГАРАНТИЯ ПРИГОДНОСТИ ДЛЯ ЦЕЛИ ИЛИ ВЫСОКОГО СПРОСА, ИСКЛЮЧИТЕЛЬНОСТИ, ИЛИ ЗАКАНЧИВАЕТСЯ ПОЛУЧЕННЫЙ ИЗ ИСПОЛЬЗОВАНИЯ МАТЕРИАЛА. УНИВЕРСИТЕТ КАРНЕГИ-МЕЛЛОН НЕ ДАЕТ ГАРАНТИИ НИКАКОГО ВИДА ОТНОСИТЕЛЬНО СВОБОДЫ ОТ ПАТЕНТА, ТОВАРНОГО ЗНАКА ИЛИ НАРУШЕНИЯ АВТОРСКОГО ПРАВА.

Это программное обеспечение и сопоставленная документация не были рассмотрены, ни являются подтвержденным Университетом Карнеги-Меллон или его Институтом программной инженерии.