Maison > développement back-end > C++ > le corps du texte

Pourquoi les variables non constantes ne peuvent-elles pas être utilisées comme arguments de modèle en C ?

Patricia Arquette
Libérer: 2024-10-29 18:42:00
original
276 Les gens l'ont consulté

Why Can't Non-Constant Variables Be Used as Template Arguments in C  ?

Pourquoi une variable non constante ne peut-elle pas être transmise comme argument de modèle ?

En C, les arguments de modèle doivent être des expressions constantes. Cela signifie que leurs valeurs doivent être connues au moment de la compilation. Le compilateur ne peut pas évaluer une variable non constante dans ce contexte.

Considérez le code :

<code class="cpp">template <int a>
void modify(){}</code>
Copier après la connexion

Pour passer une variable non constante comme argument de modèle, nous pourrions écrire :

<code class="cpp">for(int i = 0; i < 10; i++) {
    modify<i>();
}</code>
Copier après la connexion

Cependant, cela déclenche une erreur car le compilateur ne peut pas déterminer la valeur de i au moment de la compilation. Le corps de la boucle peut s'exécuter plusieurs fois, modifiant la valeur de i.

Atteindre l'objectif sans modifier l'API

Au lieu de transmettre directement une variable non constante, nous pouvons utiliser la spécialisation de modèle pour implémenter un appel itératif :

<code class="cpp">#include <iostream>

template<>
void modify<0>() { std::cout << "modify<0>" << std::endl; }

template<>
void modify<1>() { std::cout << "modify<1>" << std::endl; }

// ...

template<int i>
void modify() {
    std::cout << "modify<" << i << ">" << std::endl;
    modify<i+1>();
}

int main() {
    modify<0>();
}</code>
Copier après la connexion

Appeler Modify avec une valeur dynamique

Pour appeler Modify avec une valeur qui n'est pas connue au moment de la compilation, nous pouvons utiliser une technique appelée métaprogrammation de modèles. Voici un exemple simplifié :

<code class="cpp">#include <tuple>

template <std::tuple<int...>>
struct TupleSize;

template <int... Args>
struct TupleSize<std::tuple<Args...>> {
    static const int value = sizeof...(Args);
};

template <int N>
void callModify(int i) {
    if constexpr (i < N) {
        modify<i>();
        callModify<N>(i+1);
    }
}

int main() {
    int n = 10;
    callModify<TupleSize<std::make_tuple(1,2,3,4,5,6,7,8,9,10)>::value>(0);
}</code>
Copier après la connexion

Dans cet exemple, callModify prend un paramètre N qui est la taille d'un tuple contenant la plage de valeurs souhaitée pour i. La fonction utilise un métaprogramme récursif pour générer les appels à modifier jusqu'à la taille N spécifiée.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!