メインコンテンツ

AUTOSAR C++14 Rule M7-5-1

A function shall not return a reference or a pointer to an automatic variable (including parameters), defined within the function.

説明

ルール定義

A function shall not return a reference or a pointer to an automatic variable (including parameters), defined within the function.

根拠

関数のローカル オブジェクトは、関数呼び出しの最後に破棄されます。このようなオブジェクトのアドレスをポインターを介して返すと、破棄されたオブジェクトにアクセスする可能性があります。次に例を示します。

int* foo(int a){
	int b = a^2;
	return &b;
}
関数 foo() は、b へのポインターを返します。変数 b が関数呼び出しの最後でスコープから外れ、foo() から返されるポインターが破棄されたオブジェクトを指します。このポインターにアクセスすると、未定義の動作につながります。

Polyspace 実装

関数呼び出しの最後でスコープから外れる変数への参照またはポインターを関数が返す場合に、Polyspace® は違反を報告します。

トラブルシューティング

ルール違反が想定されるものの、Polyspace から報告されない場合は、コーディング規約違反が想定どおりに表示されない理由の診断を参照してください。

すべて展開する

int gVal;
//...

int* foo(void){
	int val;
	//...
	return &val;//Noncompliant 
}

この例では、関数 foo()val のアドレスを返します。このローカル変数は、関数呼び出しの最後でスコープから外れます。foo() から返されるポインターにアクセスすると、未定義の動作が発生します。Polyspace が違反を報告します。

チェック情報

グループ: 宣言
カテゴリ: Required、Non-automated

バージョン履歴

R2019a で導入

すべて展開する