Outils pour utilisateurs

Outils du site


lang:cpp:variable

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentesRévision précédente
Prochaine révision
Révision précédente
lang:cpp:variable [2020/03/05 22:37] – Déplacement de "Pointer vers une classe template depuis une classe sans template" rootlang:cpp:variable [2025/02/06 10:12] (Version actuelle) – Ajout de "Variable optionnelle" root
Ligne 1: Ligne 1:
-===Initialisation complexe d'une variable constante===+====Déclaration des variables==== 
 +===Pointeur sur la méthode d'une classe===
  
-Plutôt que+{{gh>https://github.com/bansan85/wiki_le_garrec_fr/blob/master/cpp/variable/pointer_function.cpp}} 
 + 
 +Exemple avec une fonction utilisant des template avec auto déduction. Dans ce cas, il faudra faire un cast pour donner le type des éléments déduits.
  
 <code cpp> <code cpp>
-std::string str; +struct S5 { 
-if (i == 1) +  template <typename... T, typename... U> 
-  str = "un"+  void f(U&&...) const { 
-else if (i == 2) +    std::cout << "S5" << sizeof...(T<< "-<< sizeof...(U<< "\n"; 
-  str = "deux"; +  
-else +}; 
-  str = "trois";+ 
 +auto ptr = static_cast<void (S5::*)(int&&, char&&) const>(&S5::f<int, double, char>)
 </code> </code>
 +
 +[[https://stackoverflow.com/questions/17874489/disambiguate-overloaded-member-function-pointer-being-passed-as-template-paramet|Disambiguate overloaded member function pointer being passed as template parameter]] {{ :lang:cpp:variable:c_-_disambiguate_overloaded_member_function_pointer_being_passed_as_template_parameter_-_stack_overflow_2021-05-29_08_00_38_.html |Archive du 26/07/2013 le 29/05/2021}}
 +
 +===Variable optionnelle===
 +
 +Création une variable ''field'' de type ''void*'' si ''T'' est de type ''int''.
 +
 +<code cpp>
 +std::conditional_t<std::is_integral_v<T>, int, void*> field;
 +</code>
 +
 +====Programmation fonctionnelle====
 +
 +===Initialisation complexe d'une constante===
 +
 +Plutôt que
 +
 +{{gh>https://github.com/bansan85/wiki_le_garrec_fr/blob/master/cpp/variable/const_variable_bad.cpp}}
  
 écrire écrire
 +
 +{{gh>https://github.com/bansan85/wiki_le_garrec_fr/blob/master/cpp/variable/const_variable_good.cpp}}
 +
 +====Erreurs====
 +
 +  * ''non-const lvalue reference to type 'X<...>' cannot bind to a temporary of type 'X<...>%%'%%''
 +
 +Parfois, il n'est pas possible de faire:
  
 <code cpp> <code cpp>
-const std::string str = [&i]() +int i; 
-+int& j = i;
-  if (i == 1) +
-    return "un"; +
-  else if (== 2) +
-    return "deux"; +
-  else +
-    return "trois"; +
-}()// Ne pas oublier les parenthèses pour l'exécution de l'opérateur ().+
 </code> </code>
  
-===Pointeur sur la méthode d'une classe===+Il faut alors soit passer par une référence constante : 
 <code cpp> <code cpp>
-// La classe +int i; 
-class Classe +const int& j = i; 
-+</code>
-public: +
-  // Pas ici. +
-  const Classe* function(size_t i) const +
-  { return this} +
-  // Ici. +
-  const Classe* function2(size_t i) const +
-  { return this} +
-};+
  
-int main() +ou passer par un pointeur : 
-{ + 
-  // Le pointeur de nom ptr. +<code cpp> 
-  const Classe* (Classe::*ptr)(size_t i) const = &Classe::function2+int i; 
-  Classe c; +intj = &i;
-  (c.*ptr)(2); +
-}+
 </code> </code>
 +
 +[[https://stackoverflow.com/questions/18565167/non-const-lvalue-references|Non const lvalue references]] {{ :lang:cpp:variable:c_-_non_const_lvalue_references_-_stack_overflow_2021-11-05_23_19_03_.html |Archive du 02/09/2013 le 05/11/2021}}
lang/cpp/variable.1583444270.txt.gz · Dernière modification : 2020/03/05 22:37 de root