exponenta event banner

CERT C: EXP43-C правил

Избегать неопределенного поведения при использовании ограниченных указателей

Описание

Определение правила

Избегайте неопределенного поведения при использовании ограниченных указателей. [1 ]

Внедрение Polyspace

Эта проверка проверяет назначение между restrict-квалифицированные указатели.

Примеры

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

Проблема

Назначение между restrict- квалифицированные указатели возникают при назначении restrict квалифицированный указатель на другой restrict квалифицированный указатель, так что они оба пытаются указать на один и тот же объект.

Риск

restrict квалификатор на указателе подразумевает, что внутри блока только этот указатель (или другие указатели, созданные из этого указателя) могут получить доступ к указанному объекту. Нельзя создать второй указатель независимо от restrict- квалифицированный указатель для указания на объект.

Эта спецификация требует, чтобы два restrict-квалифицированные указатели не могут указывать на одни и те же или перекрывающиеся объекты.

Зафиксировать

При назначении restrict-квалифицированный указатель на другой указатель, убедитесь, что сам указатель назначения не является restrict-квалифицирован.

Пример - Перекрывающаяся копия
int *restrict rptr1;   
int *restrict rptr2;  
int *         ptr; 
extern int arr[];

void func (void)
{
  arr[0] = 0;
  arr[1] = 1;
  rptr1 = &arr[0];
  rptr2 = &arr[1];
  rptr2 = rptr1;  //Non-compliant
  ptr   = rptr1;  //Compliant
  /* ... */

}

В этом примере: rptr1 и rptr2 являются restrict- квалифицированные указатели, указывающие на различные расположения в одном массиве, arr. Назначение одного такого restrict-квалифицированный указатель на другое вызывает нарушение правила.

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

Группа: Правило 03. Выражения (EXP)
Представлен в R2019a

[1] Данное программное обеспечение было создано компанией MathWorks и включает в себя следующие компоненты: «Веб-сайт SEI CERT-C», © 2017 Университет Карнеги-Меллон, веб-сайт SEI CERT-C + + © 2017 Университет Карнеги-Меллон, "Стандарт кодирования SEI CERT C - Правила разработки безопасных, Надежные и безопасные системы - 2016 Edition ", © 2016 Университет Карнеги-Меллон, и "Стандарт кодирования SEI CERT C++ - Правила разработки безопасных, Надежные и безопасные системы в C++ - 2016 Edition "© 2016 Университет Карнеги-Меллон, со специальным разрешением от его Института программного обеспечения.

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

Данное программное обеспечение и связанная с ним документация не были рассмотрены и не одобрены Университетом Карнеги-Меллона или его Институтом разработки программного обеспечения.