Non-terminating call

Вызванная функция не возвращается к вызову контекста

Описание

Это начинает работу, вызов функции появляется, когда следующие условия содержат:

  • Вызванная функция не возвращается к своему контексту вызова. Вызов приводит к определенной ошибке времени выполнения или функции завершения процесса как exit() в теле функции.

  • Существуют другие вызовы той же функции, которые не приводят к определенной ошибке или функции завершения процесса в теле функции.

Когда только часть вызовов функционального вывода к определенной ошибке, эта проверка помогает идентифицировать те вызовы функции. В теле функции, даже при том, что определенная ошибка происходит, ошибка появляется в оранжевом вместо красного, потому что результаты верификации в теле функции агрегированы по всем вызовам функции. Чтобы указать, что определенная ошибка произошла, красную проверку вызова Незавершения показывают на вызове функции вместо этого.

В противном случае, если все вызовы функционального вывода к определенной ошибке или функции завершения процесса в теле функции, Не завершающая работу ошибка вызова не отображена. Ошибка появляется в красном в теле функции, и пунктирное красное подчеркивание появляется на вызовах функции. Однако после вызова функции, как другие красные ошибки, Polyspace® не анализирует остающийся код в том же осциллографе как вызов функции.

Можно перейти непосредственно от вызова функции до операции, вызывающей ошибку времени выполнения в теле функции.

  • Чтобы найти источник ошибки, на панели Source, устанавливают ваш курсор на ключевое слово цикла и просматривают подсказку.

  • Перейдите к источнику ошибки в теле функции. Щелкните правой кнопкой по вызову функции и выберите Go to Cause, если опция существует.

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

Примеры

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

#include<stdio.h>
double ratio(int num, int den) {
  return(num/den);
}

void main() {
  int i,j;
  i=2;
  j=0;
  printf("%.2f",ratio(i,j));
}

В этом примере красная ошибка Division by zero появляется в теле ratio. Эта ошибка Division by zero в теле ratio вызывает пунктирное красное подчеркивание на вызове ratio.

#include<stdio.h>
double ratio(int num, int den) {
  return(num/den);
}

int inputCh();

void main() {
  int i,j,ch=inputCh();
  i=2;

  if(ch==1)  {
    j=0;
    printf("%.2f",ratio(i,j));
  }
  else {
    j=2;
    printf("%.2f",ratio(i,j));
  }
}

В этом примере существует два вызова ratio. В первом вызове ошибка Division by zero происходит в теле ratio. Во втором вызове Polyspace не находит ошибки. Поэтому комбинируя два вызова, оранжевая проверка Division by zero появляется в теле ratio. Красный Non-terminating call начинает работу, первый вызов указывает на ошибку.

typedef void (*f)(void);  
// function pointer type 

void f1(void) { 
  int x; 
  x++;   
} 

void f2(void) { } 
void f3(void) { } 

f fptr_array[3] = {f1,f2,f3}; 
unsigned char getIndex(void); 

void main(void) { 
 unsigned char index = getIndex() % 3; 
 // Index is between O and 2 

 fptr_array[index]();  
 fptr_array[index]();  
} 

В этом примере, потому что index может находиться между 0 и 2, первый fptr_array[index]() может вызвать f1, f2 или f3. Если index нуль, оператор вызывает f1. f1 содержит красную ошибку Non-initialized local variable, поэтому, пунктирная красная ошибка появляется на вызове функции. В отличие от других красных ошибок, продолжается верификация.

После этого оператора программное обеспечение рассматривает тот index или 1 или 2. Ошибка не происходит на втором fptr_array[index]().

#include <stdio.h>
#include <stdlib.h>

typedef unsigned char uint8;
typedef unsigned short uint16;
typedef unsigned int uint32;

typedef void (*WrFuncPtr)(const void* src, void* dest);

typedef struct {
    WrFuncPtr pWrFuncPtr;
}FuncPtrStruct;


void Write_8(const void* pSource, void* pDest) {
    *(uint8*)pDest =  *(const uint8*) pSource;
}

void Write_16(const void* pSource, void* pDest) {
    *(uint16*)pDest =  *(const uint16*) pSource;
}

void Write_32(const void* pSource, void* pDest) {
    *(uint32*)pDest =  *(const uint32*) pSource;
}

#define SIZE_ARRAY 3

const FuncPtrStruct FuncPtrArray[SIZE_ARRAY] =
{
    { &Write_8  },
    { &Write_16 },
    { &Write_32 }
};

uint8 source[4];
uint8 dest[2];

void function(int uiSignalType) {
    uint8* srcPtr = &source[0];
    uint8 *destPtr = &dest[0];
    assert (uiSignalType>=0 && uiSignalType < SIZE_ARRAY);
    FuncPtrArray[uiSignalType].pWrFuncPtr(srcPtr, destPtr);
}

В этом примере, указатель функции pWrFuncPtr может указать на одну из трех функций Write_8, Write_16, или Write_32. Только вызов Write_32 содержит возможную ошибку Illegally dereferenced pointer (оранжевая проверка) потому что буферный pDest не может иметь достаточной памяти для записанного содержимого. Поскольку регистрация тела функции является оранжевой, красная ошибка Non-terminating call появляется на вызове функции через указатель функции.

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

Группа: Поток управления
Язык: C | C++
Акроним: NTC