C++ est un langage typé statiquement, donc toutes ses variables doivent déclarer les types de données à l'avance. Un type de données indique le type de valeur qu'une variable contient. En C++, les variables contenant des valeurs numériques sont int, long, float et double. int et long sont utilisés pour représenter des valeurs entières, tandis que float et double sont utilisés pour représenter des valeurs décimales. int et long contiennent tous deux des valeurs entières, mais avec une différence, la taille de int est de 4 octets et celle de long est de 8 octets.
La conversion de int en long peut être effectuée de différentes manières, nous n'en avons discuté que de deux. La première consiste à effectuer une conversion implicite et la seconde utilise une conversion explicite. La conversion de type explicite nécessite de mentionner le type de données résultant dans le code, la conversion de type implicite est effectuée par le compilateur lui-même. La conversion de type explicite peut être réalisée de deux manières décrites plus loin. Nous avons déjà décrit les conversions implicites.
Conversion implicite d'une variable de type int en long -
int a; long b = a;
Les conversions implicites sont entièrement gérées par le compilateur et le programmeur n'a pas besoin de déployer d'efforts supplémentaires pour la conversion. Attribuez simplement la variable source à la variable cible.
#include <iostream> using namespace std; long solve(int var2) { return var2; } int main() { long var1; int var2 = 4103; var1 = solve(var2); cout<< "The value of var1 is: "<< var1 <<endl; cout<< "The size of var1 is: " << sizeof(var1) <<endl; cout<< "The size of var2 is: " << sizeof(var2) <<endl; return 0; }
The value of var1 is: 4103 The size of var1 is: 8 The size of var2 is: 4
Comme le montre l'exemple, la variable var1 est de type int, tandis que la variable var2 est de type long. La valeur 4103 est utilisée pour initialiser la variable var2 puis l'affecter à var1. Il est évident que le compilateur a effectué une conversion de type implicite et a enregistré la valeur sous forme d'entier dans la variable var1. La taille de la variable est également affichée dans la sortie pour vérifier la conversion, bien que cela soit uniquement à des fins de démonstration et qu'il n'est pas nécessaire de l'appliquer à chaque fois. En C++, il existe deux manières d'effectuer des conversions de type explicites : en appliquant un opérateur de conversion et en déclarant explicitement le type de données de la variable de résultat lors de l'affectation.
En C++, il existe quatre types différents d'opérateurs de diffusion disponibles. L'opérateur de conversion statique est le seul opérateur utilisé dans cet article.
int a; long b = static_cast<long> (a);
#include <iostream> using namespace std; long solve(int var2) { return static_cast<long> (var2); } int main() { long var1; int var2 = 257; var1 = solve(var2); cout<< "The value of var1 is: "<< var1 <<endl; cout<< "The size of var1 is: " << sizeof(var1) <<endl; cout<< "The size of var2 is: " << sizeof(var2) <<endl; return 0; }
The value of var1 is: 257 The size of var1 is: 8 The size of var2 is: 4
Les résultats sont comparables aux extraits de code tentés précédemment. La conversion de type explicite accomplit la même chose, sauf que l'utilisateur doit maintenant spécifier la méthode de conversion.
Semblable à la méthode précédente, nous plaçons également le type de données du résultat avant la variable source à droite lors de la conversion. Aucun opérateur supplémentaire n'est requis dans ce cas.
int a; long b = (long) a;
#include <iostream> using namespace std; long solve(int var2) { return (long) var2; } int main() { long var1; int var2 = 37857; var1 = solve(var2); cout<< "The value of var1 is: "<< var1 <<endl; cout<< "The size of var1 is: " << sizeof(var1) <<endl; cout<< "The size of var2 is: " << sizeof(var2) <<endl; return 0; }
The value of var1 is: 37857 The size of var1 is: 8 The size of var2 is: 4
Étant donné que différents types de données fournissent différentes représentations et méthodes pour fonctionner sur le même type de données, la conversion entre eux est très courante en C++ et dans d'autres langages informatiques. Pour convertir entre long et int, nous utilisons principalement deux types de conversions appelées conversions implicites et types de conversion explicites. Cette conversion est logique lorsque des données de type int sont requises pour des calculs plus volumineux et plus complexes.
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!