純粋関数の利点 質問する

純粋関数の利点 質問する

今日、純粋関数について読んでいたのですが、その使い方に混​​乱してしまいました。

関数が同じ入力セットに対して同じ値セットを返し、観察可能な副作用がない場合、その関数は純粋であると言われます。

たとえば、strlen()は純粋関数ですが、rand()は不純関数です。

__attribute__ ((pure)) int fun(int i)
{
    return i*i;
}

int main()
{
    int i=10;
    printf("%d",fun(i));//outputs 100
    return 0;
}

http://ideone.com/33XJU

上記のプログラムは宣言がない場合と同じように動作しますpure

関数をpure[出力に変更がない場合] として宣言する利点は何ですか?

ベストアンサー1

pureコンパイラに関数について特定の最適化を行えることを知らせます。次のようなコードを想像してください。

for (int i = 0; i < 1000; i++)
{
    printf("%d", fun(10));
}

純粋関数の場合、コンパイラはfun(10)1000 回ではなく 1 回だけ評価する必要があることを認識できます。複雑な関数の場合、これは大きな利点です。

おすすめ記事