Groovy - Guide rapide
Groovy est un langage orienté objet basé sur la plateforme Java. Groovy 1.0 est sorti le 2 janvier 2007 avec Groovy 2.4 comme version majeure actuelle. Groovy est distribué via la licence Apache v 2.0.
Caractéristiques de Groovy
Groovy a les caractéristiques suivantes -
- Prise en charge du typage statique et dynamique.
- Prise en charge de la surcharge des opérateurs.
- Syntaxe native pour les listes et les tableaux associatifs.
- Prise en charge native des expressions régulières.
- Prise en charge native de divers langages de balisage tels que XML et HTML.
- Groovy est simple pour les développeurs Java car la syntaxe de Java et Groovy est très similaire.
- Vous pouvez utiliser les bibliothèques Java existantes.
- Groovy étend le java.lang.Object.
Le site officiel de Groovy est http://www.groovy-lang.org/
Il existe différentes manières d'obtenir la configuration de l'environnement Groovy.
Binary download and installation- Allez sur le lien www.groovy-lang.org/download.html pour obtenir la section Windows Installer. Cliquez sur cette option pour démarrer le téléchargement du programme d'installation de Groovy.
Une fois que vous lancez le programme d'installation, suivez les étapes ci-dessous pour terminer l'installation.
Step 1 - Sélectionnez le programme d'installation de la langue.
Step 2 - Cliquez sur le bouton Suivant dans l'écran suivant.
Step 3 - Cliquez sur le bouton «J'accepte».
Step 4 - Acceptez les composants par défaut et cliquez sur le bouton Suivant.
Step 5 - Choisissez le dossier de destination approprié, puis cliquez sur le bouton Suivant.
Step 6 - Cliquez sur le bouton Installer pour démarrer l'installation.
Step 7 - Une fois l'installation terminée, cliquez sur le bouton Suivant pour démarrer la configuration.
Step 8 - Choisissez les options par défaut et cliquez sur le bouton Suivant.
Step 9 - Acceptez les associations de fichiers par défaut et cliquez sur le bouton Suivant.
Step 10 - Cliquez sur le bouton Terminer pour terminer l'installation.
Une fois les étapes ci-dessus suivies, vous pouvez démarrer le shell groovy qui fait partie de l'installation Groovy qui aide à tester nos différents aspects du langage Groovy sans avoir besoin d'un environnement de développement intégré à part entière pour Groovy. Cela peut être fait en exécutant la commande groovysh à partir de l'invite de commande.
Si vous souhaitez inclure les binaires groovy dans le cadre de votre build maven ou gradle, vous pouvez ajouter les lignes suivantes
Gradle
'org.codehaus.groovy:groovy:2.4.5'
Maven
<groupId>org.codehaus.groovy</groupId>
<artifactId>groovy</artifactId>
<version>2.4.5</version>
Afin de comprendre la syntaxe de base de Groovy, examinons d'abord un simple programme Hello World.
Création de votre premier programme Hello World
Créer votre premier programme hello world est aussi simple que d'entrer simplement la ligne de code suivante -
class Example {
static void main(String[] args) {
// Using a simple println statement to print output to the console
println('Hello World');
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Hello World
Déclaration d'importation dans Groovy
L'instruction import peut être utilisée pour importer les fonctionnalités d'autres bibliothèques qui peuvent être utilisées dans votre code. Cela se fait en utilisant leimport mot-clé.
L'exemple suivant montre comment utiliser une importation simple de la classe MarkupBuilder qui est probablement l'une des classes les plus utilisées pour créer un balisage HTML ou XML.
import groovy.xml.MarkupBuilder
def xml = new MarkupBuilder()
Par défaut, Groovy inclut les bibliothèques suivantes dans votre code, vous n'avez donc pas besoin de les importer explicitement.
import java.lang.*
import java.util.*
import java.io.*
import java.net.*
import groovy.lang.*
import groovy.util.*
import java.math.BigInteger
import java.math.BigDecimal
Jetons à Groovy
Un jeton est soit un mot-clé, un identificateur, une constante, une chaîne littérale ou un symbole.
println(“Hello World”);
Dans la ligne de code ci-dessus, il y a deux jetons, le premier est le mot-clé println et le suivant est la chaîne littérale de «Hello World».
Commentaires dans Groovy
Les commentaires sont utilisés pour documenter votre code. Les commentaires dans Groovy peuvent être sur une seule ligne ou sur plusieurs lignes.
Les commentaires sur une seule ligne sont identifiés en utilisant le // à n'importe quelle position de la ligne. Un exemple est montré ci-dessous -
class Example {
static void main(String[] args) {
// Using a simple println statement to print output to the console
println('Hello World');
}
}
Les commentaires multilignes sont identifiés par / * au début et * / pour identifier la fin du commentaire multiligne.
class Example {
static void main(String[] args) {
/* This program is the first program
This program shows how to display hello world */
println('Hello World');
}
}
Point virgule
Contrairement au langage de programmation Java, il n'est pas obligatoire d'avoir des points-virgules après la fin de chaque instruction, c'est facultatif.
class Example {
static void main(String[] args) {
def x = 5
println('Hello World');
}
}
Si vous exécutez le programme ci-dessus, les deux instructions de la méthode main ne génèrent aucune erreur.
Identifiants
Les identificateurs sont utilisés pour définir des variables, des fonctions ou d'autres variables définies par l'utilisateur. Les identificateurs commencent par une lettre, un dollar ou un trait de soulignement. Ils ne peuvent pas commencer par un nombre. Voici quelques exemples d'identifiants valides -
def employeename
def student1
def student_name
où def est un mot-clé utilisé dans Groovy pour définir un identifiant.
Voici un exemple de code de la façon dont un identifiant peut être utilisé dans notre programme Hello World.
class Example {
static void main(String[] args) {
// One can see the use of a semi-colon after each statement
def x = 5;
println('Hello World');
}
}
Dans l'exemple ci-dessus, la variable x est utilisé comme identifiant.
Mots clés
Les mots clés comme le nom l'indique sont des mots spéciaux réservés dans le langage de programmation Groovy. Le tableau suivant répertorie les mots-clés définis dans Groovy.
comme | affirmer | Pause | Cas |
capture | classe | const | continuer |
def | défaut | faire | autre |
énumération | étend | faux | finalement |
pour | aller à | si | met en oeuvre |
importer | dans | exemple de | interface |
Nouveau | tirer | paquet | revenir |
super | commutateur | ce | jeter |
jette | trait | vrai | essayer |
tandis que |
Espaces blancs
L'espace blanc est le terme utilisé dans un langage de programmation tel que Java et Groovy pour décrire les espaces, les tabulations, les caractères de nouvelle ligne et les commentaires. L'espace blanc sépare une partie d'une instruction d'une autre et permet au compilateur d'identifier l'emplacement d'un élément dans une instruction.
Par exemple, dans l'exemple de code suivant, il y a un espace blanc entre le mot clé defet la variable x. C'est pour que le compilateur sache quedef est le mot-clé qui doit être utilisé et que x doit être le nom de la variable à définir.
def x = 5;
Littéraux
Un littéral est une notation pour représenter une valeur fixe dans groovy. Le langage groovy a des notations pour les entiers, les nombres à virgule flottante, les caractères et les chaînes. Voici quelques exemples de littéraux dans le langage de programmation Groovy -
12
1.45
‘a’
“aa”
Dans n'importe quel langage de programmation, vous devez utiliser diverses variables pour stocker différents types d'informations. Les variables ne sont rien d'autre que des emplacements de mémoire réservés pour stocker des valeurs. Cela signifie que lorsque vous créez une variable, vous réservez de l'espace en mémoire pour stocker la valeur associée à la variable.
Vous pouvez souhaiter stocker des informations de différents types de données comme une chaîne, un caractère, un caractère large, un entier, une virgule flottante, une valeur booléenne, etc. En fonction du type de données d'une variable, le système d'exploitation alloue de la mémoire et décide de ce qui peut être stocké dans le fichier réservé Mémoire.
Types de données intégrés
Groovy propose une grande variété de types de données intégrés. Voici une liste des types de données définis dans Groovy -
byte- Ceci est utilisé pour représenter une valeur d'octet. Un exemple est 2.
short- Ceci est utilisé pour représenter un nombre court. Un exemple est 10.
int- Ceci est utilisé pour représenter des nombres entiers. Un exemple est 1234.
long- Ceci est utilisé pour représenter un nombre long. Un exemple est 10000090.
float- Ceci est utilisé pour représenter des nombres à virgule flottante de 32 bits. Un exemple est 12.34.
double- Ceci est utilisé pour représenter des nombres à virgule flottante de 64 bits qui sont des représentations de nombres décimaux plus longs qui peuvent parfois être nécessaires. Un exemple est 12.3456565.
char- Ceci définit un seul caractère littéral. Un exemple est «a».
Boolean - Cela représente une valeur booléenne qui peut être vraie ou fausse.
String - Ce sont des textes littéraux qui sont représentés dans the formde chaîne de caractères. Par exemple «Hello World».
Valeurs liées
Le tableau suivant montre les valeurs maximales autorisées pour les littéraux numériques et décimaux.
octet | -128 à 127 |
court | -32 768 à 32 767 |
int | -2 147 483 648 à 2 147 483 647 |
longue | -9,223,372,036,854,775,808 à +9,223,372,036,854,775,807 |
flotte | 1.40129846432481707e-45 à 3.40282346638528860e + 38 |
double | 4,94065645841246544e-324d à 1,79769313486231570e + 308d |
Numérique de classe
Types En plus des types primitifs, les types d'objets suivants (parfois appelés types wrapper) sont autorisés -
- java.lang.Byte
- java.lang.Short
- java.lang.Integer
- java.lang.Long
- java.lang.Float
- java.lang.Double
De plus, les classes suivantes peuvent être utilisées pour prendre en charge l'arithmétique de précision arbitraire -
Nom | La description | Exemple |
---|---|---|
java.math.BigInteger | Nombres entiers signés de précision arbitraire immuables | 30g |
java.math.BigDecimal | Nombres décimaux signés à précision arbitraire immuables | 3,5 g |
L'exemple de code suivant montre comment les différents types de données intégrés peuvent être utilisés -
class Example {
static void main(String[] args) {
//Example of a int datatype
int x = 5;
//Example of a long datatype
long y = 100L;
//Example of a floating point datatype
float a = 10.56f;
//Example of a double datatype
double b = 10.5e40;
//Example of a BigInteger datatype
BigInteger bi = 30g;
//Example of a BigDecimal datatype
BigDecimal bd = 3.5g;
println(x);
println(y);
println(a);
println(b);
println(bi);
println(bd);
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
5
100
10.56
1.05E41
30
3.5
Les variables dans Groovy peuvent être définies de deux manières - en utilisant le native syntax pour le type de données ou le suivant est by using the def keyword. Pour les définitions de variables, il est obligatoire de fournir un nom de type explicitement ou d'utiliser "def" en remplacement. Cela est requis par l'analyseur Groovy.
Il existe les types de variables de base suivants dans Groovy, comme expliqué dans le chapitre précédent -
byte- Ceci est utilisé pour représenter une valeur d'octet. Un exemple est 2.
short- Ceci est utilisé pour représenter un nombre court. Un exemple est 10.
int- Ceci est utilisé pour représenter des nombres entiers. Un exemple est 1234.
long- Ceci est utilisé pour représenter un nombre long. Un exemple est 10000090.
float- Ceci est utilisé pour représenter des nombres à virgule flottante de 32 bits. Un exemple est 12.34.
double- Ceci est utilisé pour représenter des nombres à virgule flottante de 64 bits qui sont des représentations de nombres décimaux plus longs qui peuvent parfois être nécessaires. Un exemple est 12.3456565.
char- Ceci définit un seul caractère littéral. Un exemple est «a».
Boolean - Cela représente une valeur booléenne qui peut être vraie ou fausse.
String - Ce sont des textes littéraux qui sont représentés dans the formde chaîne de caractères. Par exemple «Hello World».
Groovy permet également des types supplémentaires de variables telles que des tableaux, des structures et des classes que nous verrons dans les chapitres suivants.
Déclarations variables
Une déclaration de variable indique au compilateur où et combien créer le stockage pour la variable.
Voici un exemple de déclaration de variable -
class Example {
static void main(String[] args) {
// x is defined as a variable
String x = "Hello";
// The value of the variable is printed to the console
println(x);
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Hello
Nommer les variables
Le nom d'une variable peut être composé de lettres, de chiffres et du caractère de soulignement. Il doit commencer par une lettre ou un trait de soulignement. Les lettres majuscules et minuscules sont distinctes car Groovy, tout comme Java, est un langage de programmation sensible à la casse.
class Example {
static void main(String[] args) {
// Defining a variable in lowercase
int x = 5;
// Defining a variable in uppercase
int X = 6;
// Defining a variable with the underscore in it's name
def _Name = "Joe";
println(x);
println(X);
println(_Name);
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
5
6
Joe
On peut voir ça x et X sont deux variables différentes en raison du respect de la casse et dans le troisième cas, nous pouvons voir que _Name commence par un trait de soulignement.
Variables d'impression
Vous pouvez imprimer la valeur actuelle d'une variable avec la fonction println. L'exemple suivant montre comment cela peut être réalisé.
class Example {
static void main(String[] args) {
//Initializing 2 variables
int x = 5;
int X = 6;
//Printing the value of the variables to the console
println("The value of x is " + x + "The value of X is " + X);
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
The value of x is 5 The value of X is 6
Un opérateur est un symbole qui indique au compilateur d'effectuer des manipulations mathématiques ou logiques spécifiques.
Groovy propose les types d'opérateurs suivants -
- Opérateurs arithmétiques
- Opérateurs relationnels
- Opérateurs logiques
- Opérateurs au niveau du bit
- Opérateurs d'affectation
Opérateurs arithmétiques
Le langage Groovy prend en charge les opérateurs arithmétiques normaux comme n'importe quel langage. Voici les opérateurs arithmétiques disponibles dans Groovy -
Afficher l'exemple
Opérateur | La description | Exemple |
---|---|---|
+ | Ajout de deux opérandes | 1 + 2 donnera 3 |
- | Soustrait le deuxième opérande du premier | 2 - 1 donnera 1 |
* | Multiplication des deux opérandes | 2 * 2 donnera 4 |
/ | Division du numérateur par dénominateur | 3/2 donnera 1,5 |
% | Opérateur de module et reste après une division entière / flottante | 3% 2 donnera 1 |
++ | Opérateurs incrémentaux utilisés pour incrémenter la valeur d'un opérande de 1 | int x = 5; x ++; x donnera 6 |
- | Opérateurs incrémentaux utilisés pour décrémenter la valeur d'un opérande de 1 | int x = 5; X--; x donnera 4 |
Opérateurs relationnels
Les opérateurs relationnels permettent de comparer des objets. Voici les opérateurs relationnels disponibles dans Groovy -
Afficher l'exemple
Opérateur | La description | Exemple |
---|---|---|
== | Teste l'égalité entre deux objets | 2 == 2 donnera vrai |
! = | Teste la différence entre deux objets | 3! = 2 donnera vrai |
< | Vérifie si les objets de gauche sont inférieurs à l'opérande de droite. | 2 <3 donnera vrai |
<= | Vérifie si les objets de gauche sont inférieurs ou égaux à l'opérande de droite. | 2 <= 3 donnera vrai |
> | Vérifie si les objets de gauche sont supérieurs à l'opérande de droite. | 3> 2 donnera vrai |
> = | Vérifie si les objets de gauche sont supérieurs ou égaux à l'opérande de droite. | 3> = 2 donnera vrai |
Opérateurs logiques
Les opérateurs logiques sont utilisés pour évaluer les expressions booléennes. Voici les opérateurs logiques disponibles dans Groovy -
Afficher l'exemple
Opérateur | La description | Exemple |
---|---|---|
&& | Il s'agit de l'opérateur logique «et» | vrai && vrai donnera vrai |
|| | Il s'agit de l'opérateur logique «ou» | vrai || vrai donnera vrai |
! | C'est l'opérateur logique «non» | ! faux donnera vrai |
Opérateurs au niveau du bit
Groovy fournit quatre opérateurs au niveau du bit. Voici les opérateurs bit à bit disponibles dans Groovy -
Afficher l'exemple
Sr.Non | Opérateur et description |
---|---|
1 | & Il s’agit de l’opérateur «et» au niveau du bit |
2 | | Il s’agit de l’opérateur «ou» au niveau du bit |
3 | ^ Il s’agit de l’opérateur «xor» ou exclusif ou au niveau du bit |
4 | ~ C'est l'opérateur de négation au niveau du bit |
Voici la table de vérité présentant ces opérateurs.
p | q | p & q | p | q | p ^ q |
---|---|---|---|---|
0 | 0 | 0 | 0 | 0 |
0 | 1 | 0 | 1 | 1 |
1 | 1 | 1 | 1 | 0 |
1 | 0 | 0 | 1 | 1 |
Opérateurs d'affectation
Le langage Groovy fournit également des opérateurs d'affectation. Voici les opérateurs d'affectation disponibles dans Groovy -
Afficher l'exemple
Opérateur | La description | Exemple |
---|---|---|
+ = | Cela ajoute l'opérande droit à l'opérande gauche et affecte le résultat à l'opérande gauche. | def A = 5 A + = 3 La sortie sera 8 |
- = | Cela soustrait l'opérande droit de l'opérande gauche et affecte le résultat à l'opérande gauche | def A = 5 A- = 3 La sortie sera 2 |
* = | Ceci multiplie l'opérande droit par l'opérande gauche et affecte le résultat à l'opérande gauche | def A = 5 A * = 3 La sortie sera de 15 |
/ = | Cela divise l'opérande gauche avec l'opérande droit et affecte le résultat à l'opérande gauche | def A = 6 A / = 3 La sortie sera 2 |
% = | Cela prend le module en utilisant deux opérandes et affecte le résultat à l'opérande gauche | def A = 5 Un% = 3 La sortie sera 2 |
Opérateurs de gamme
Groovy prend en charge le concept de plages et fournit une notation des opérateurs de plage à l'aide de la notation ... Un exemple simple de l'opérateur de plage est donné ci-dessous.
def range = 0..5
Cela définit simplement une simple plage d'entiers, stockée dans une variable locale appelée plage avec une limite inférieure de 0 et une limite supérieure de 5.
L'extrait de code suivant montre comment les différents opérateurs peuvent être utilisés.
class Example {
static void main(String[] args) {
def range = 5..10;
println(range);
println(range.get(2));
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Du println , vous pouvez voir que toute la plage de nombres définie dans l'instruction de plage est affichée.
L'instruction get est utilisée pour obtenir un objet de la plage définie qui prend une valeur d'index comme paramètre.
[5, 6, 7, 8, 9, 10]
7
Priorité de l'opérateur
Le tableau suivant répertorie tous les opérateurs groovy par ordre de priorité.
Sr.Non | Opérateurs et noms |
---|---|
1 | ++ -- + - pré incrément / décrément, unaire plus, unaire moins |
2 | * / % multiplier, div, modulo |
3 | + - addition soustraction |
4 | == != <=> égal, pas égal, comparer à |
5 | & binaire / bit à bit et |
6 | ^ xor binaire / bit à bit |
sept | | binaire / bit à bit ou |
8 | && logique et |
9 | || logique ou |
dix | = **= *= /= %= += -= <<= >>= >>>= &= ^= |= Divers opérateurs d'affectation |
Jusqu'à présent, nous avons vu des instructions qui ont été exécutées les unes après les autres de manière séquentielle. En outre, des instructions sont fournies dans Groovy pour modifier le flux de contrôle dans la logique d'un programme. Ils sont ensuite classés en flux d'énoncés de contrôle que nous verrons en détail.
S.No. | Déclarations et description |
---|---|
1 | Déclaration While L'instruction while est exécutée en évaluant d'abord l'expression de condition (une valeur booléenne), et si le résultat est vrai, alors les instructions de la boucle while sont exécutées. |
2 | pour Statement L'instruction for est utilisée pour parcourir un ensemble de valeurs. |
3 | Déclaration for-in L'instruction for-in est utilisée pour parcourir un ensemble de valeurs. |
Déclarations de contrôle de boucle
S.No. | Déclarations et description |
---|---|
1 | Déclaration de rupture L'instruction break est utilisée pour modifier le flux de contrôle à l'intérieur des boucles et des instructions switch. |
2 | Continuer la déclaration L'instruction continue complète l'instruction break. Son utilisation est limitée aux boucles while et for. |
Les structures de prise de décision exigent que le programmeur spécifie une ou plusieurs conditions à évaluer ou à tester par le programme, ainsi qu'une ou plusieurs instructions à exécuter si la condition est déterminée comme étant true, et éventuellement d'autres instructions à exécuter si la condition est déterminée false.
Sr.No. | Déclarations et description |
---|---|
1 | if Déclaration Le fonctionnement général de cette instruction est que tout d'abord une condition est évaluée dans l'instruction if. Si la condition est vraie, il exécute alors les instructions. |
2 | Instruction if / else Le fonctionnement général de cette instruction est que tout d'abord une condition est évaluée dans l'instruction if. Si la condition est vraie, il exécute les instructions par la suite et s'arrête avant la condition else et sort de la boucle. Si la condition est fausse, elle exécute alors les instructions dans le bloc d'instructions else, puis quitte la boucle. |
3 | Instruction If imbriquée Parfois, il est nécessaire d'avoir plusieurs instructions if imbriquées l'une dans l'autre. |
4 | Instruction Switch Parfois, l'instruction if-else imbriquée est si courante et utilisée si souvent qu'une instruction plus simple a été conçue, appelée instruction switch. |
5 | Instruction de commutateur imbriqué Il est également possible d'avoir un ensemble imbriqué d'instructions switch. |
Une méthode est dans Groovy est définie avec un type de retour ou avec le defmot-clé. Les méthodes peuvent recevoir n'importe quel nombre d'arguments. Il n'est pas nécessaire que les types soient explicitement définis lors de la définition des arguments. Des modificateurs tels que public, privé et protégé peuvent être ajoutés. Par défaut, si aucun modificateur de visibilité n'est fourni, la méthode est publique.
Le type de méthode le plus simple est celui sans paramètres comme celui indiqué ci-dessous -
def methodName() {
//Method code
}
Voici un exemple de méthode simple
class Example {
static def DisplayName() {
println("This is how methods work in groovy");
println("This is an example of a simple method");
}
static void main(String[] args) {
DisplayName();
}
}
Dans l'exemple ci-dessus, DisplayName est une méthode simple qui se compose de deux instructions println qui sont utilisées pour sortir du texte vers la console. Dans notre méthode principale statique, nous appelons simplement la méthode DisplayName. Le résultat de la méthode ci-dessus serait -
This is how methods work in groovy
This is an example of a simple method
Paramètres de méthode
Une méthode est plus généralement utile si son comportement est déterminé par la valeur d'un ou plusieurs paramètres. Nous pouvons transférer des valeurs vers la méthode appelée en utilisant des paramètres de méthode. Notez que les noms de paramètres doivent différer les uns des autres.
Le type le plus simple d'une méthode avec des paramètres comme celui indiqué ci-dessous -
def methodName(parameter1, parameter2, parameter3) {
// Method code goes here
}
Voici un exemple de méthode simple avec des paramètres
class Example {
static void sum(int a,int b) {
int c = a+b;
println(c);
}
static void main(String[] args) {
sum(10,5);
}
}
Dans cet exemple, nous créons une méthode de somme avec 2 paramètres, a et b. Les deux paramètres sont de typeint. Nous appelons ensuite la méthode sum de notre méthode principale et transmettons les valeurs aux variablesa et b.
La sortie de la méthode ci-dessus serait la valeur 15.
Paramètres par défaut
Il existe également une disposition dans Groovy pour spécifier des valeurs par défaut pour les paramètres dans les méthodes. Si aucune valeur n'est transmise à la méthode pour les paramètres, les valeurs par défaut sont utilisées. Si des paramètres non par défaut et par défaut sont utilisés, il convient de noter que les paramètres par défaut doivent être définis à la fin de la liste des paramètres.
Voici un exemple de méthode simple avec des paramètres -
def someMethod(parameter1, parameter2 = 0, parameter3 = 0) {
// Method code goes here
}
Regardons le même exemple que nous avons vu précédemment pour l'ajout de deux nombres et créons une méthode qui a un paramètre par défaut et un autre paramètre non par défaut -
class Example {
static void sum(int a,int b = 5) {
int c = a+b;
println(c);
}
static void main(String[] args) {
sum(6);
}
}
Dans cet exemple, nous créons une méthode de somme avec deux paramètres, a et b. Les deux paramètres sont de type int. La différence entre cet exemple et l'exemple précédent est que dans ce cas, nous spécifions une valeur par défaut pourb comme 5. Ainsi, lorsque nous appelons la méthode sum de notre méthode principale, nous avons la possibilité de simplement passer une valeur qui est 6 et celle-ci sera affectée au paramètre a dans le sum méthode.
La sortie de la méthode ci-dessus serait la valeur 11.
class Example {
static void sum(int a,int b = 5) {
int c = a+b;
println(c);
}
static void main(String[] args) {
sum(6,6);
}
}
Nous pouvons également appeler la méthode sum en passant 2 valeurs, dans notre exemple ci-dessus, nous passons 2 valeurs de 6. La deuxième valeur de 6 remplacera en fait la valeur par défaut qui est affectée au paramètre b.
La sortie de la méthode ci-dessus serait la valeur 12.
Valeurs de retour de méthode
Les méthodes peuvent également renvoyer des valeurs au programme appelant. Cela est nécessaire dans le langage de programmation moderne dans lequel une méthode effectue une sorte de calcul, puis renvoie la valeur souhaitée à la méthode appelante.
Voici un exemple de méthode simple avec une valeur de retour.
class Example {
static int sum(int a,int b = 5) {
int c = a+b;
return c;
}
static void main(String[] args) {
println(sum(6));
}
}
Dans notre exemple ci-dessus, notez que cette fois, nous spécifions un type de retour pour notre méthode sum qui est du type int. Dans la méthode, nous utilisons l'instruction return pour envoyer la valeur de la somme au programme principal appelant. Puisque la valeur de la méthode est maintenant disponible pour la méthode principale, nous utilisons leprintln fonction pour afficher la valeur dans la console.
La sortie de la méthode ci-dessus serait la valeur 11.
Méthodes d'instance
Les méthodes sont normalement implémentées dans les classes de Groovy, tout comme le langage Java. Une classe n'est rien d'autre qu'un plan ou un modèle pour créer différents objets qui définissent ses propriétés et ses comportements. Les objets de classe présentent les propriétés et les comportements définis par sa classe. Ainsi, les comportements sont définis en créant des méthodes à l'intérieur de la classe.
Nous verrons les classes plus en détail dans un chapitre ultérieur, mais voici un exemple d'implémentation de méthode dans une classe. Dans nos exemples précédents, nous avons défini notre méthode comme des méthodes statiques, ce qui signifiait que nous pouvions accéder à ces méthodes directement depuis la classe. L'exemple suivant de méthodes est celui des méthodes d'instance dans lesquelles les méthodes sont accessibles en créant des objets de la classe. Encore une fois, nous verrons les classes dans un chapitre ultérieur, pour l'instant nous montrerons comment utiliser les méthodes.
Voici un exemple de la façon dont les méthodes peuvent être implémentées.
class Example {
int x;
public int getX() {
return x;
}
public void setX(int pX) {
x = pX;
}
static void main(String[] args) {
Example ex = new Example();
ex.setX(100);
println(ex.getX());
}
}
Dans notre exemple ci-dessus, notez que cette fois, nous ne spécifions aucun attribut statique pour nos méthodes de classe. Dans notre fonction principale, nous créons en fait une instance de la classe Example, puis nous invoquons la méthode de l'objet 'ex'.
La sortie de la méthode ci-dessus serait la valeur 100.
Noms des paramètres locaux et externes
Groovy fournit la possibilité, tout comme Java, d'avoir des paramètres locaux et globaux. Dans l'exemple suivant,lx est un paramètre local qui a une portée uniquement dans la fonction de getX() et xest une propriété globale accessible dans toute la classe Example. Si nous essayons d'accéder à la variablelx en dehors du getX() fonction, nous obtiendrons une erreur.
class Example {
static int x = 100;
public static int getX() {
int lx = 200;
println(lx);
return x;
}
static void main(String[] args) {
println(getX());
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant.
200
100
cette méthode pour les propriétés
Tout comme en Java, groovy peut accéder à ses membres d'instance en utilisant le thismot-clé. L'exemple suivant montre comment lorsque nous utilisons l'instructionthis.x, il fait référence à son instance et définit la valeur de x en conséquence.
class Example {
int x = 100;
public int getX() {
this.x = 200;
return x;
}
static void main(String[] args) {
Example ex = new Example();
println(ex.getX());
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat de 200 imprimé sur la console.
Groovy fournit un certain nombre de méthodes d'assistance lors de l'utilisation d'E / S. Groovy fournit des classes plus simples pour fournir les fonctionnalités suivantes pour les fichiers.
- Lecture de fichiers
- Écriture dans des fichiers
- Traverser les arborescences de fichiers
- Lire et écrire des objets de données dans des fichiers
En plus de cela, vous pouvez toujours utiliser les classes Java normales répertoriées ci-dessous pour les opérations d'E / S de fichiers.
- java.io.File
- java.io.InputStream
- java.io.OutputStream
- java.io.Reader
- java.io.Writer
Lecture de fichiers
L'exemple suivant affichera toutes les lignes d'un fichier texte dans Groovy. La méthodeeachLine est intégré à la classe File de Groovy dans le but de garantir que chaque ligne du fichier texte est lue.
import java.io.File
class Example {
static void main(String[] args) {
new File("E:/Example.txt").eachLine {
line -> println "line : $line";
}
}
}
La classe File est utilisée pour instancier un nouvel objet qui prend le nom de fichier comme paramètre. Il prend ensuite la fonction de eachLine, la place dans une variable appelée line et l'imprime en conséquence.
Si le fichier contient les lignes suivantes, elles seront imprimées.
line : Example1
line : Example2
Lecture du contenu d'un fichier sous forme de chaîne entière
Si vous souhaitez obtenir l'intégralité du contenu du fichier sous forme de chaîne, vous pouvez utiliser la propriété text de la classe de fichier. L'exemple suivant montre comment cela peut être fait.
class Example {
static void main(String[] args) {
File file = new File("E:/Example.txt")
println file.text
}
}
Si le fichier contient les lignes suivantes, elles seront imprimées.
line : Example1
line : Example2
Écriture dans des fichiers
Si vous souhaitez écrire dans des fichiers, vous devez utiliser la classe writer pour générer du texte dans un fichier. L'exemple suivant montre comment cela peut être fait.
import java.io.File
class Example {
static void main(String[] args) {
new File('E:/','Example.txt').withWriter('utf-8') {
writer -> writer.writeLine 'Hello World'
}
}
}
Si vous ouvrez le fichier Example.txt, vous verrez les mots «Hello World» imprimés dans le fichier.
Obtenir la taille d'un fichier
Si vous souhaitez obtenir la taille du fichier, vous pouvez utiliser la propriété length de la classe de fichier pour obtenir la taille du fichier. L'exemple suivant montre comment cela peut être fait.
class Example {
static void main(String[] args) {
File file = new File("E:/Example.txt")
println "The file ${file.absolutePath} has ${file.length()} bytes"
}
}
Le code ci-dessus afficherait la taille du fichier en octets.
Tester si un fichier est un répertoire
Si vous voulez voir si un chemin est un fichier ou un répertoire, vous pouvez utiliser le isFile et isDirectoryoption de la classe File. L'exemple suivant montre comment cela peut être fait.
class Example {
static void main(String[] args) {
def file = new File('E:/')
println "File? ${file.isFile()}"
println "Directory? ${file.isDirectory()}"
}
}
Le code ci-dessus afficherait la sortie suivante -
File? false
Directory? True
Créer un annuaire
Si vous souhaitez créer un nouveau répertoire, vous pouvez utiliser le mkdirfonction de la classe File. L'exemple suivant montre comment cela peut être fait.
class Example {
static void main(String[] args) {
def file = new File('E:/Directory')
file.mkdir()
}
}
Le répertoire E: \ Directory sera créé s'il n'existe pas.
Supprimer un fichier
Si vous souhaitez supprimer un fichier, vous pouvez utiliser la fonction de suppression de la classe File. L'exemple suivant montre comment cela peut être fait.
class Example {
static void main(String[] args) {
def file = new File('E:/Example.txt')
file.delete()
}
}
Le fichier sera supprimé s'il existe.
Copie de fichiers
Groovy fournit également la fonctionnalité pour copier le contenu d'un fichier à un autre. L'exemple suivant montre comment cela peut être fait.
class Example {
static void main(String[] args) {
def src = new File("E:/Example.txt")
def dst = new File("E:/Example1.txt")
dst << src.text
}
}
Le fichier Example1.txt sera créé et tout le contenu du fichier Example.txt sera copié dans ce fichier.
Obtention du contenu du répertoire
Groovy fournit également la fonctionnalité permettant de répertorier les lecteurs et les fichiers d'un lecteur.
L'exemple suivant montre comment les lecteurs d'une machine peuvent être affichés à l'aide de listRoots fonction de la classe File.
class Example {
static void main(String[] args) {
def rootFiles = new File("test").listRoots()
rootFiles.each {
file -> println file.absolutePath
}
}
}
Selon les lecteurs disponibles sur votre machine, la sortie peut varier. Sur une machine standard, la sortie serait similaire à la suivante -
C:\
D:\
L'exemple suivant montre comment répertorier les fichiers dans un répertoire particulier à l'aide du eachFile fonction de la classe File.
class Example {
static void main(String[] args) {
new File("E:/Temp").eachFile() {
file->println file.getAbsolutePath()
}
}
}
La sortie afficherait tous les fichiers dans le répertoire E: \ Temp
Si vous souhaitez afficher de manière récursive tous les fichiers d'un répertoire et de ses sous-répertoires, vous utiliserez le eachFileRecursefonction de la classe File. L'exemple suivant montre comment cela peut être fait.
class Example {
static void main(String[] args) {
new File("E:/temp").eachFileRecurse() {
file -> println file.getAbsolutePath()
}
}
}
La sortie afficherait tous les fichiers dans le répertoire E: \ Temp et dans ses sous-répertoires s'ils existent.
Groovy est un langage typé «facultativement», et cette distinction est importante pour comprendre les principes fondamentaux de la langue. Par rapport à Java, qui est un langage typé «fortement», dans lequel le compilateur connaît tous les types de chaque variable et peut comprendre et honorer les contrats au moment de la compilation. Cela signifie que les appels de méthode peuvent être déterminés au moment de la compilation.
Lors de l'écriture de code dans Groovy, les développeurs ont la possibilité de fournir un type ou non. Cela peut offrir une certaine simplicité dans la mise en œuvre et, lorsqu'il est exploité correctement, peut servir votre application de manière robuste et dynamique.
Dans Groovy, la saisie facultative se fait via le mot clé «def». Voici un exemple de l'utilisation dudef méthode -
class Example {
static void main(String[] args) {
// Example of an Integer using def
def a = 100;
println(a);
// Example of an float using def
def b = 100.10;
println(b);
// Example of an Double using def
def c = 100.101;
println(c);
// Example of an String using def
def d = "HelloWorld";
println(d);
}
}
À partir du programme ci-dessus, nous pouvons voir que nous n'avons pas déclaré les variables individuelles comme Integer, float, double ou string même si elles contiennent ces types de valeurs.
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
100
100.10
100.101
HelloWorld
Le typage facultatif peut être un utilitaire puissant pendant le développement, mais peut entraîner des problèmes de maintenabilité au cours des dernières étapes du développement lorsque le code devient trop vaste et complexe.
Pour comprendre comment vous pouvez utiliser la saisie facultative dans Groovy sans mettre votre base de code dans un désordre impossible à entretenir, il est préférable d'adopter la philosophie du «typage canard» dans vos applications.
Si nous réécrivons le code ci-dessus en utilisant le typage canard, il ressemblera à celui donné ci-dessous. Les noms de variables reçoivent des noms qui ressemblent le plus souvent au type qu'ils représentent, ce qui rend le code plus compréhensible.
class Example {
static void main(String[] args) {
// Example of an Integer using def
def aint = 100;
println(aint);
// Example of an float using def
def bfloat = 100.10;
println(bfloat);
// Example of an Double using def
def cDouble = 100.101;
println(cDouble);
// Example of an String using def
def dString = "HelloWorld";
println(dString);
}
}
Dans Groovy, les nombres sont en fait représentés comme des objets, tous étant une instance de la classe Integer. Pour qu'un objet fasse quelque chose, nous devons invoquer l'une des méthodes déclarées dans sa classe.
Groovy prend en charge les nombres entiers et flottants.
- Un entier est une valeur qui n'inclut pas de fraction.
- Un nombre à virgule flottante est une valeur décimale qui comprend une fraction décimale.
Un exemple de nombres dans Groovy est montré ci-dessous -
Integer x = 5;
Float y = 1.25;
Où x est du type Integer et y est le flotteur.
La raison pour laquelle les nombres dans groovy sont définis comme des objets est généralement parce qu'il y a des exigences pour effectuer des opérations sur les nombres. Le concept de fournir une classe sur des types primitifs est connu sous le nom de classes wrapper.
Par défaut, les classes wrapper suivantes sont fournies dans Groovy.
L'objet de la classe wrapper contient ou encapsule son type de données primitif respectif. Le processus de conversion d'un type de données primitif en objet est appelé boxing, et cela est pris en charge par le compilateur. Le processus de conversion de l'objet vers son type primitif correspondant est appelé unboxing.
Exemple
Voici un exemple de boxe et de déballage -
class Example {
static void main(String[] args) {
Integer x = 5,y = 10,z = 0;
// The the values of 5,10 and 0 are boxed into Integer types
// The values of x and y are unboxed and the addition is performed
z = x+y;
println(z);
}
}
La sortie du programme ci-dessus serait 15. Dans l'exemple ci-dessus, les valeurs de 5, 10 et 0 sont d'abord encadrées dans les variables Integer x, y et z en conséquence. Et puis, lorsque l'addition de x et y est effectuée, les valeurs sont décompressées de leurs types Integer.
Méthodes numériques
Étant donné que les nombres dans Groovy sont représentés sous forme de classes, voici la liste des méthodes disponibles.
S.No. | Méthodes et description |
---|---|
1 | xxxValeur () Cette méthode prend le nombre comme paramètre et retourne un type primitif basé sur la méthode qui est appelée. |
2 | comparer aux() La méthode compareTo consiste à comparer un nombre à un autre. Ceci est utile si vous souhaitez comparer la valeur des nombres. |
3 | équivaut à() La méthode détermine si l'objet Number qui appelle la méthode est égal à l'objet qui est passé en argument. |
4 | valeur de() La méthode valueOf renvoie l'objet Number pertinent contenant la valeur de l'argument passé. |
5 | toString () La méthode est utilisée pour obtenir un objet String représentant la valeur de l'objet Number. |
6 | parseInt () Cette méthode est utilisée pour obtenir le type de données primitif d'une certaine chaîne. parseXxx () est une méthode statique et peut avoir un ou deux arguments. |
sept | abdos() La méthode donne la valeur absolue de l'argument. L'argument peut être int, float, long, double, short, byte. |
8 | ceil () La méthode ceil donne le plus petit entier supérieur ou égal à l'argument. |
9 | sol() La méthode floor donne le plus grand entier inférieur ou égal à l'argument. |
dix | rint () La méthode rint renvoie l'entier dont la valeur est la plus proche de l'argument. |
11 | rond() La méthode round renvoie le long ou int le plus proche, comme indiqué par le type de retour des méthodes. |
12 | min () La méthode donne le plus petit des deux arguments. L'argument peut être int, float, long, double. |
13 | max () La méthode donne le maximum des deux arguments. L'argument peut être int, float, long, double. |
14 | exp () La méthode renvoie la base des logarithmes naturels, e, à la puissance de l'argument. |
15 | Journal() La méthode renvoie le logarithme naturel de l'argument. |
16 | pow () La méthode renvoie la valeur du premier argument élevé à la puissance du deuxième argument. |
17 | sqrt () La méthode renvoie la racine carrée de l'argument. |
18 | péché() La méthode renvoie le sinus de la valeur double spécifiée. |
19 | cos () La méthode renvoie le cosinus de la valeur double spécifiée. |
20 | bronzer() La méthode renvoie la tangente de la valeur double spécifiée. |
21 | un péché() La méthode renvoie l'arc sinus de la valeur double spécifiée. |
22 | acos () La méthode renvoie l'arc cosinus de la valeur double spécifiée. |
23 | un bronzage() La méthode renvoie l'arc tangente de la valeur double spécifiée. |
24 | atan2 () La méthode Convertit les coordonnées rectangulaires (x, y) en coordonnées polaires (r, thêta) et renvoie thêta. |
25 | toDegrees () La méthode convertit la valeur de l'argument en degrés. |
26 | radian() La méthode convertit la valeur de l'argument en radians. |
27 | Aléatoire() La méthode est utilisée pour générer un nombre aléatoire entre 0,0 et 1,0. La plage est: 0.0 = <Math.random <1.0. Différentes plages peuvent être obtenues en utilisant l'arithmétique. |
Un littéral String est construit dans Groovy en plaçant le texte de chaîne entre guillemets.
Groovy offre une variété de façons de désigner un littéral String. Les chaînes de Groovy peuvent être placées entre guillemets simples ('), guillemets doubles (") ou triples guillemets (" ""). En outre, une chaîne Groovy entourée de guillemets triples peut s'étendre sur plusieurs lignes.
Voici un exemple d'utilisation de chaînes dans Groovy -
class Example {
static void main(String[] args) {
String a = 'Hello Single';
String b = "Hello Double";
String c = "'Hello Triple" + "Multiple lines'";
println(a);
println(b);
println(c);
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Hello Single
Hello Double
'Hello TripleMultiple lines'
Indexation des chaînes
Les chaînes dans Groovy sont des séquences ordonnées de caractères. Le caractère individuel d'une chaîne est accessible par sa position. Ceci est donné par une position d'index.
Les indices de chaîne commencent à zéro et se terminent à un de moins que la longueur de la chaîne. Groovy permet également aux indices négatifs de compter à rebours à partir de la fin de la chaîne.
Voici un exemple de l'utilisation de l'indexation de chaînes dans Groovy -
class Example {
static void main(String[] args) {
String sample = "Hello world";
println(sample[4]); // Print the 5 character in the string
//Print the 1st character in the string starting from the back
println(sample[-1]);
println(sample[1..2]);//Prints a string starting from Index 1 to 2
println(sample[4..2]);//Prints a string starting from Index 4 back to 2
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
o
d
el
oll
Opérations de base sur les chaînes
Apprenons d'abord les opérations de base sur les cordes dans groovy. Ils sont donnés ci-dessous.
S.No. | Opération de chaîne et description |
---|---|
1 | Concaténation de deux chaînes La concaténation des chaînes peut être effectuée par le simple opérateur «+». |
2 | Répétition de cordes La répétition des chaînes peut être effectuée par le simple opérateur '*'. |
3 | Longueur de chaine La longueur de la chaîne déterminée par la méthode length () de la chaîne. |
Méthodes de chaîne
Voici la liste des méthodes prises en charge par la classe String.
S.No. | Méthodes et description |
---|---|
1 | centre() Renvoie une nouvelle chaîne de longueur numberOfChars composée du destinataire complété à gauche et à droite avec des espaces. |
2 | compareToIgnoreCase () Compare deux chaînes lexicographiquement, en ignorant les différences de casse. |
3 | concat () Concatène la chaîne spécifiée à la fin de cette chaîne. |
4 | eachMatch () Traite chaque sous-chaîne de correspondance de groupe d'expression régulière (voir la section suivante) de la chaîne donnée. |
5 | se termine par() Teste si cette chaîne se termine par le suffixe spécifié. |
6 | equalsIgnoreCase () Compare cette chaîne à une autre chaîne, en ignorant les considérations de casse. |
sept | atteindre() Il renvoie une valeur de chaîne à la position d'index |
8 | Indice de() Renvoie l'index dans cette chaîne de la première occurrence de la sous-chaîne spécifiée. |
9 | allumettes() Il indique si une chaîne correspond à l'expression régulière donnée. |
dix | moins() Supprime la partie valeur de la chaîne. |
11 | prochain() Cette méthode est appelée par l'opérateur ++ pour la classe String. Il incrémente le dernier caractère de la chaîne donnée. |
12 | padLeft () Remplissez la chaîne avec les espaces ajoutés à gauche. |
13 | padRight () Remplissez la chaîne avec les espaces ajoutés à droite. |
14 | plus() Ajoute une chaîne |
15 | précédent() Cette méthode est appelée par l'opérateur - pour la CharSequence. |
16 | remplace tout() Remplace toutes les occurrences d'un groupe capturé par le résultat d'une fermeture sur ce texte. |
17 | inverser() Crée une nouvelle chaîne qui est l'inverse de cette chaîne. |
18 | Divisé() Divise cette chaîne autour des correspondances de l'expression régulière donnée. |
19 | sousString () Renvoie une nouvelle chaîne qui est une sous-chaîne de cette chaîne. |
20 | toUpperCase () Convertit tous les caractères de cette chaîne en majuscules. |
21 | toLowerCase () Convertit tous les caractères de cette chaîne en minuscules. |
Une plage est un raccourci pour spécifier une séquence de valeurs. Une plage est indiquée par la première et la dernière valeur de la séquence et la plage peut être inclusive ou exclusive. Une plage inclusive inclut toutes les valeurs de la première à la dernière, tandis qu'une plage exclusive inclut toutes les valeurs sauf la dernière. Voici quelques exemples de littéraux Range -
- 1..10 - Un exemple de Range inclusive
- 1 .. <10 - Un exemple de gamme exclusive
- 'a' .. 'x' - Les plages peuvent également être constituées de caractères
- 10..1 - Les plages peuvent également être dans l'ordre décroissant
- 'x' .. 'a' - Les plages peuvent également être constituées de caractères et être dans l'ordre décroissant.
Voici les différentes méthodes disponibles pour les gammes.
Sr.No. | Méthodes et description |
---|---|
1 | contient () Vérifie si une plage contient une valeur spécifique |
2 | avoir() Renvoie l'élément à la position spécifiée dans cette plage. |
3 | obtenir de() Obtenez la valeur inférieure de cette plage. |
4 | accéder à() Obtenez la valeur supérieure de cette plage. |
5 | isReverse () Est-ce une gamme inversée, itérant en arrière |
6 | Taille() Renvoie le nombre d'éléments dans cette plage. |
sept | subList () Renvoie une vue de la partie de cette plage entre le fromIndex, inclus, et toIndex, exclusif |
La liste est une structure utilisée pour stocker une collection d'éléments de données. Dans Groovy, la liste contient une séquence de références d'objet. Les références d'objet dans une liste occupent une position dans la séquence et se distinguent par un index entier. Un littéral List est présenté comme une série d'objets séparés par des virgules et entre crochets.
Pour traiter les données dans une liste, nous devons pouvoir accéder à des éléments individuels. Les Groovy Lists sont indexées à l'aide de l'opérateur d'indexation []. Les index de liste commencent à zéro, ce qui fait référence au premier élément.
Voici quelques exemples de listes -
- [11, 12, 13, 14] - Une liste de valeurs entières
- ['Angular', 'Groovy', 'Java'] - Une liste de chaînes
- [1, 2, [3, 4], 5] - Une liste imbriquée
- ['Groovy', 21, 2.11] - Une liste hétérogène de références d'objets
- [] - Une liste vide
Dans ce chapitre, nous discuterons des méthodes de liste disponibles dans Groovy.
Sr.No. | Méthodes et description |
---|---|
1 | ajouter() Ajoutez la nouvelle valeur à la fin de cette liste. |
2 | contient () Renvoie true si cette liste contient la valeur spécifiée. |
3 | avoir() Renvoie l'élément à la position spécifiée dans cette liste. |
4 | est vide() Renvoie true si cette liste ne contient aucun élément |
5 | moins() Crée une nouvelle liste composée des éléments de l'original sans ceux spécifiés dans la collection. |
6 | plus() Crée une nouvelle liste composée des éléments de l'original avec ceux spécifiés dans la collection. |
sept | pop() Supprime le dernier élément de cette liste |
8 | retirer() Supprime l'élément à la position spécifiée dans cette liste. |
9 | inverser() Créer une nouvelle liste qui est l'inverse des éléments de la liste d'origine |
dix | Taille() Obtient le nombre d'éléments de cette liste. |
11 | Trier() Renvoie une copie triée de la liste d'origine. |
Une carte (également appelée tableau associatif, dictionnaire, table et hachage) est une collection non ordonnée de références d'objets. Les éléments d'une collection Map sont accessibles par une valeur de clé. Les clés utilisées dans une carte peuvent être de n'importe quelle classe. Lorsque nous l'insérons dans une collection Map, deux valeurs sont requises: la clé et la valeur.
Voici quelques exemples de cartes -
['TopicName': 'Lists', 'TopicName': 'Maps'] - Collections de paires clé-valeur qui a TopicName comme clé et leurs valeurs respectives.
[:] - Une carte vide.
Dans ce chapitre, nous discuterons des méthodes de carte disponibles dans Groovy.
Sr.No. | Méthodes et description |
---|---|
1 | containsKey () Cette carte contient-elle cette clé? |
2 | avoir() Recherchez la clé dans cette carte et renvoyez la valeur correspondante. S'il n'y a aucune entrée dans cette mappe pour la clé, retournez null. |
3 | keySet () Obtenez un jeu de clés dans cette carte. |
4 | mettre() Associe la valeur spécifiée à la clé spécifiée dans cette mappe. Si cette carte contenait auparavant un mappage pour cette clé, l'ancienne valeur est remplacée par la valeur spécifiée. |
5 | Taille() Renvoie le nombre de mappages clé-valeur dans cette mappe. |
6 | valeurs() Renvoie une vue de collection des valeurs contenues dans cette carte. |
La classe Date représente un instant spécifique dans le temps, avec une précision de la milliseconde. La classe Date a deux constructeurs comme indiqué ci-dessous.
Date()
Syntaxe
public Date()
Parameters - Aucun.
Return Value
Alloue un objet Date et l'initialise afin qu'il représente l'heure à laquelle il a été alloué, mesuré à la milliseconde près.
Exemple
Voici un exemple de l'utilisation de cette méthode -
class Example {
static void main(String[] args) {
Date date = new Date();
// display time and date using toString()
System.out.println(date.toString());
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant. La sortie suivante vous donnera la date et l'heure actuelles -
Thu Dec 10 21:31:15 GST 2015
Date (milliseconde longue)
Syntaxe
public Date(long millisec)
Parameters
Millisec - Le nombre de millisecondes à spécifier depuis le temps de base standard.
Return Value - Attribue un Date objet et l'initialise pour représenter le nombre de millisecondes spécifié depuis l'heure de base standard connue sous le nom de «l'époque», à savoir le 1er janvier 1970 à 00:00:00 GMT.
Exemple
Voici un exemple de l'utilisation de cette méthode -
class Example {
static void main(String[] args) {
Date date = new Date(100);
// display time and date using toString()
System.out.println(date.toString());
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Thu Jan 01 04:00:00 GST 1970
Voici les méthodes données de la classe Date. Dans toutes les méthodes de la classe Date qui acceptent ou renvoient les valeurs de l'année, du mois, de la date, des heures, des minutes et des secondes, les représentations suivantes sont utilisées -
Une année y est représentée par l'entier y - 1900.
Un mois est représenté par un entier de 0 à 11; 0 est janvier, 1 est février, et ainsi de suite; le 11 est donc décembre.
Une date (jour du mois) est représentée par un entier de 1 à 31 de la manière habituelle.
Une heure est représentée par un entier de 0 à 23. Ainsi, l'heure de minuit à 1 h du matin est l'heure 0, et l'heure de midi à 13 h est l'heure 12.
Une minute est représentée par un entier de 0 à 59 de la manière habituelle.
Une seconde est représentée par un entier de 0 à 61.
Sr.No. | Méthodes et description |
---|---|
1 | après() Teste si cette date est postérieure à la date spécifiée. |
2 | équivaut à() Compare deux dates pour l'égalité. Le résultat est vrai si et seulement si l'argument n'est pas nul et est un objet Date qui représente le même point dans le temps, à la milliseconde, que cet objet. |
3 | comparer aux() Compare deux dates de commande. |
4 | toString () Convertit cet objet Date en chaîne |
5 | avant() Teste si cette date est antérieure à la date spécifiée. |
6 | obtenir du temps() Renvoie le nombre de millisecondes depuis le 1er janvier 1970 à 00:00:00 GMT représenté par cet objet Date. |
sept | régler le temps() Définit cet objet Date pour représenter un point dans le temps qui correspond à des millisecondes après le 1er janvier 1970 00:00:00 GMT. |
Une expression régulière est un modèle utilisé pour rechercher des sous-chaînes dans du texte. Groovy prend en charge les expressions régulières nativement en utilisant l'expression ~ ”regex”. Le texte entre les guillemets représente l'expression à comparer.
Par exemple, nous pouvons créer un objet d'expression régulière comme indiqué ci-dessous -
def regex = ~'Groovy'
Lorsque l'opérateur Groovy = ~ apparaît comme un prédicat (expression renvoyant un booléen) dans if et while(voir chapitre 8), l'opérande String à gauche est comparé à l'opérande d'expression régulière à droite. Par conséquent, chacun des éléments suivants fournit la valeur true.
Lors de la définition d'une expression régulière, les caractères spéciaux suivants peuvent être utilisés -
Il existe deux caractères spéciaux de position utilisés pour désigner le début et la fin d'une ligne: le signe caret (∧) et le signe dollar ($).
Les expressions régulières peuvent également inclure des quantificateurs. Le signe plus (+) représente une ou plusieurs fois, appliqué à l'élément précédent de l'expression. L'astérisque (*) est utilisé pour représenter zéro ou plusieurs occurrences. Le point d'interrogation (?) Indique zéro ou une fois.
Le métacaractère {et} est utilisé pour faire correspondre un nombre spécifique d'instances du caractère précédent.
Dans une expression régulière, le symbole de point (.) Peut représenter n'importe quel caractère. Ceci est décrit comme le caractère générique.
Une expression régulière peut inclure des classes de caractères. Un ensemble de caractères peut être donné comme une simple séquence de caractères entre les métacaractères [et] comme dans [aeiou]. Pour les plages de lettres ou de nombres, vous pouvez utiliser un séparateur de tirets comme dans [a – z] ou [a – mA – M]. Le complément d'une classe de caractères est indiqué par un signe d'insertion dans les raquettes carrées comme dans [∧a – z] et représente tous les caractères autres que ceux spécifiés. Quelques exemples d'expressions régulières sont donnés ci-dessous
'Groovy' =~ 'Groovy'
'Groovy' =~ 'oo'
'Groovy' ==~ 'Groovy'
'Groovy' ==~ 'oo'
'Groovy' =~ '∧G'
‘Groovy' =~ 'G$'
‘Groovy' =~ 'Gro*vy' 'Groovy' =~ 'Gro{2}vy'
La gestion des exceptions est requise dans tout langage de programmation pour gérer les erreurs d'exécution afin que le flux normal de l'application puisse être maintenu.
L'exception perturbe normalement le flux normal de l'application, raison pour laquelle nous devons utiliser la gestion des exceptions dans notre application.
Les exceptions sont généralement classées dans les catégories suivantes -
Checked Exception - Les classes qui étendent la classe Throwable à l'exception de RuntimeException et Error sont appelées exceptions vérifiées, egIOException, SQLException, etc. Les exceptions vérifiées sont vérifiées au moment de la compilation.
Un cas classique est le FileNotFoundException. Supposons que vous ayez le code suivant dans votre application qui lit un fichier dans le lecteur E.
class Example {
static void main(String[] args) {
File file = new File("E://file.txt");
FileReader fr = new FileReader(file);
}
}
si le fichier (file.txt) n'est pas présent dans le lecteur E, l'exception suivante sera déclenchée.
Attrapé: java.io.FileNotFoundException: E: \ file.txt (le système ne trouve pas le fichier spécifié).
java.io.FileNotFoundException: E: \ file.txt (Le système ne trouve pas le fichier spécifié).
Unchecked Exception - Les classes qui étendent RuntimeException sont appelées exceptions non vérifiées, par exemple, ArithmeticException, NullPointerException, ArrayIndexOutOfBoundsException, etc.
Un cas classique est l'exception ArrayIndexOutOfBoundsException qui se produit lorsque vous essayez d'accéder à un index d'un tableau qui est supérieur à la longueur du tableau. Voici un exemple typique de ce type d'erreur.
class Example {
static void main(String[] args) {
def arr = new int[3];
arr[5] = 5;
}
}
Lorsque le code ci-dessus est exécuté, l'exception suivante sera déclenchée.
Attrapé: java.lang.ArrayIndexOutOfBoundsException: 5
java.lang.ArrayIndexOutOfBoundsException: 5
Error - L'erreur est irrécupérable, par exemple OutOfMemoryError, VirtualMachineError, AssertionError, etc.
Ce sont des erreurs dont le programme ne peut jamais récupérer et qui provoqueront un plantage du programme.
Le diagramme suivant montre comment la hiérarchie des exceptions dans Groovy est organisée. Tout est basé sur la hiérarchie définie en Java.
Attraper les exceptions
Une méthode intercepte une exception en utilisant une combinaison des try et catchmots clés. Un bloc try / catch est placé autour du code qui peut générer une exception.
try {
//Protected code
} catch(ExceptionName e1) {
//Catch block
}
Tout votre code qui pourrait déclencher une exception est placé dans le bloc de code protégé.
Dans le bloc catch, vous pouvez écrire du code personnalisé pour gérer votre exception afin que l'application puisse récupérer de l'exception.
Regardons un exemple du code similaire que nous avons vu ci-dessus pour accéder à un tableau avec une valeur d'index supérieure à la taille du tableau. Mais cette fois, enveloppons notre code dans un bloc try / catch.
class Example {
static void main(String[] args) {
try {
def arr = new int[3];
arr[5] = 5;
} catch(Exception ex) {
println("Catching the exception");
}
println("Let's move on after the exception");
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Catching the exception
Let's move on after the exception
À partir du code ci-dessus, nous enveloppons le code défectueux dans le bloc try. Dans le bloc catch, nous interceptons simplement notre exception et émettons un message indiquant qu'une exception s'est produite.
Blocs de capture multiples
On peut avoir plusieurs blocs catch pour gérer plusieurs types d'exceptions. Pour chaque bloc catch, selon le type d'exception déclenchée, vous écririez du code pour le gérer en conséquence.
Modifions notre code ci-dessus pour intercepter spécifiquement l'exception ArrayIndexOutOfBoundsException. Voici l'extrait de code.
class Example {
static void main(String[] args) {
try {
def arr = new int[3];
arr[5] = 5;
}catch(ArrayIndexOutOfBoundsException ex) {
println("Catching the Array out of Bounds exception");
}catch(Exception ex) {
println("Catching the exception");
}
println("Let's move on after the exception");
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Catching the Aray out of Bounds exception
Let's move on after the exception
À partir du code ci-dessus, vous pouvez voir que le bloc catch ArrayIndexOutOfBoundsException est intercepté en premier car il signifie les critères de l'exception.
Enfin bloquer
le finallyblock suit un bloc try ou un bloc catch. Un bloc de code finally s'exécute toujours, indépendamment de l'occurrence d'une exception.
L'utilisation d'un bloc finally vous permet d'exécuter toutes les instructions de type nettoyage que vous souhaitez exécuter, peu importe ce qui se passe dans le code protégé. La syntaxe de ce bloc est donnée ci-dessous.
try {
//Protected code
} catch(ExceptionType1 e1) {
//Catch block
} catch(ExceptionType2 e2) {
//Catch block
} catch(ExceptionType3 e3) {
//Catch block
} finally {
//The finally block always executes.
}
Modifions notre code ci-dessus et ajoutons le dernier bloc de code. Voici l'extrait de code.
class Example {
static void main(String[] args) {
try {
def arr = new int[3];
arr[5] = 5;
} catch(ArrayIndexOutOfBoundsException ex) {
println("Catching the Array out of Bounds exception");
}catch(Exception ex) {
println("Catching the exception");
} finally {
println("The final block");
}
println("Let's move on after the exception");
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Catching the Array out of Bounds exception
The final block
Let's move on after the exception
Voici les méthodes d'exception disponibles dans Groovy -
public String getMessage ()
Renvoie un message détaillé sur l'exception qui s'est produite. Ce message est initialisé dans le constructeur Throwable.
public Throwable getCause ()
Renvoie la cause de l'exception représentée par un objet Throwable.
chaîne publique toString ()
Renvoie le nom de la classe concaténée avec le résultat de getMessage ()
public void printStackTrace ()
Imprime le résultat de toString () avec la trace de la pile dans System.err, le flux de sortie d'erreur.
public StackTraceElement [] getStackTrace ()
Renvoie un tableau contenant chaque élément de la trace de pile. L'élément à l'index 0 représente le haut de la pile d'appels et le dernier élément du tableau représente la méthode au bas de la pile d'appels.
public Throwable fillInStackTrace ()
Remplit la trace de pile de cet objet Throwable avec la trace de pile actuelle, en ajoutant à toutes les informations précédentes dans la trace de pile.
Exemple
Voici l'exemple de code utilisant certaines des méthodes données ci-dessus -
class Example {
static void main(String[] args) {
try {
def arr = new int[3];
arr[5] = 5;
}catch(ArrayIndexOutOfBoundsException ex) {
println(ex.toString());
println(ex.getMessage());
println(ex.getStackTrace());
} catch(Exception ex) {
println("Catching the exception");
}finally {
println("The final block");
}
println("Let's move on after the exception");
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
java.lang.ArrayIndexOutOfBoundsException: 5
5
[org.codehaus.groovy.runtime.dgmimpl.arrays.IntegerArrayPutAtMetaMethod$MyPojoMetaMet
hodSite.call(IntegerArrayPutAtMetaMethod.java:75),
org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:48) ,
org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:113) ,
org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:133) ,
Example.main(Sample:8), sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method),
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57),
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ,
java.lang.reflect.Method.invoke(Method.java:606),
org.codehaus.groovy.reflection.CachedMethod.invoke(CachedMethod.java:93),
groovy.lang.MetaMethod.doMethodInvoke(MetaMethod.java:325),
groovy.lang.MetaClassImpl.invokeStaticMethod(MetaClassImpl.java:1443),
org.codehaus.groovy.runtime.InvokerHelper.invokeMethod(InvokerHelper.java:893),
groovy.lang.GroovyShell.runScriptOrMainOrTestOrRunnable(GroovyShell.java:287),
groovy.lang.GroovyShell.run(GroovyShell.java:524),
groovy.lang.GroovyShell.run(GroovyShell.java:513),
groovy.ui.GroovyMain.processOnce(GroovyMain.java:652),
groovy.ui.GroovyMain.run(GroovyMain.java:384),
groovy.ui.GroovyMain.process(GroovyMain.java:370),
groovy.ui.GroovyMain.processArgs(GroovyMain.java:129),
groovy.ui.GroovyMain.main(GroovyMain.java:109),
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method),
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57),
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ,
java.lang.reflect.Method.invoke(Method.java:606),
org.codehaus.groovy.tools.GroovyStarter.rootLoader(GroovyStarter.java:109),
org.codehaus.groovy.tools.GroovyStarter.main(GroovyStarter.java:131),
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method),
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57),
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ,
java.lang.reflect.Method.invoke(Method.java:606),
com.intellij.rt.execution.application.AppMain.main(AppMain.java:144)]
The final block
Let's move on after the exception
Dans Groovy, comme dans tout autre langage orienté objet, il existe le concept de classes et d'objets pour représenter la nature orientée objet du langage de programmation. Une classe Groovy est une collection de données et les méthodes qui opèrent sur ces données. Ensemble, les données et les méthodes d'une classe sont utilisées pour représenter un objet du monde réel du domaine du problème.
Une classe dans Groovy déclare l'état (données) et le comportement des objets définis par cette classe. Par conséquent, une classe Groovy décrit à la fois les champs d'instance et les méthodes de cette classe.
Voici un exemple de classe dans Groovy. Le nom de la classe est Student qui a deux champs -StudentID et StudentName. Dans la fonction principale, nous créons un objet de cette classe et attribuons des valeurs auStudentID et StudentName de l'objet.
class Student {
int StudentID;
String StudentName;
static void main(String[] args) {
Student st = new Student();
st.StudentID = 1;
st.StudentName = "Joe"
}
}
Méthodes getter et setter
Dans tout langage de programmation, il est toujours pratique de masquer les membres de l'instance avec le mot clé private et de fournir à la place des méthodes getter et setter pour définir et obtenir les valeurs des variables d'instance en conséquence. L'exemple suivant montre comment cela peut être fait.
class Student {
private int StudentID;
private String StudentName;
void setStudentID(int pID) {
StudentID = pID;
}
void setStudentName(String pName) {
StudentName = pName;
}
int getStudentID() {
return this.StudentID;
}
String getStudentName() {
return this.StudentName;
}
static void main(String[] args) {
Student st = new Student();
st.setStudentID(1);
st.setStudentName("Joe");
println(st.getStudentID());
println(st.getStudentName());
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
1
Joe
Notez les points clés suivants concernant le programme ci-dessus -
Dans la classe, le studentID et le studentName sont marqués comme privés, ce qui signifie qu'ils ne sont pas accessibles depuis l'extérieur de la classe.
Chaque membre d'instance a sa propre méthode getter et setter. La méthode getter renvoie la valeur de la variable d'instance, par exemple la méthode int getStudentID () et la méthode setter définit la valeur de l'ID d'instance, par exemple la méthode - void setStudentName (String pName)
Méthodes d'instance
Il est normalement naturel d'inclure plus de méthodes à l'intérieur de la classe, ce qui en fait une sorte de fonctionnalité pour la classe. Dans notre exemple d'élève, ajoutons des membres d'instance de Marks1, Marks2 et Marks3 pour désigner les notes de l'élève dans 3 matières. Nous ajouterons ensuite une nouvelle méthode d'instance qui calculera les notes totales de l'étudiant. Voici à quoi ressemblerait le code.
Dans l'exemple suivant, la méthode Total est une méthode Instance supplémentaire qui intègre une certaine logique.
class Student {
int StudentID;
String StudentName;
int Marks1;
int Marks2;
int Marks3;
int Total() {
return Marks1+Marks2+Marks3;
}
static void main(String[] args) {
Student st = new Student();
st.StudentID = 1;
st.StudentName="Joe";
st.Marks1 = 10;
st.Marks2 = 20;
st.Marks3 = 30;
println(st.Total());
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
60
Création de plusieurs objets
On peut également créer plusieurs objets d'une classe. Voici l'exemple de la façon dont cela peut être réalisé. Ici, nous créons 3 objets (st, st1 et st2) et appelons leurs membres d'instance et leurs méthodes d'instance en conséquence.
class Student {
int StudentID;
String StudentName;
int Marks1;
int Marks2;
int Marks3;
int Total() {
return Marks1+Marks2+Marks3;
}
static void main(String[] args) {
Student st = new Student();
st.StudentID = 1;
st.StudentName = "Joe";
st.Marks1 = 10;
st.Marks2 = 20;
st.Marks3 = 30;
println(st.Total());
Student st1 = new Student();
st.StudentID = 1;
st.StudentName = "Joe";
st.Marks1 = 10;
st.Marks2 = 20;
st.Marks3 = 40;
println(st.Total());
Student st3 = new Student();
st.StudentID = 1;
st.StudentName = "Joe";
st.Marks1 = 10;
st.Marks2 = 20;
st.Marks3 = 50;
println(st.Total());
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
60
70
80
Héritage
L'héritage peut être défini comme le processus par lequel une classe acquiert les propriétés (méthodes et champs) d'une autre. Avec l'utilisation de l'héritage, les informations sont gérables dans un ordre hiérarchique.
La classe qui hérite des propriétés des autres est appelée sous-classe (classe dérivée, classe enfant) et la classe dont les propriétés sont héritées est appelée superclasse (classe de base, classe parent).
Prolonge
extendsest le mot-clé utilisé pour hériter des propriétés d'une classe. Voici la syntaxe du mot-clé extend. Dans l'exemple suivant, nous faisons les choses suivantes -
Création d'une classe appelée Person. Cette classe a un membre d'instance appelé nom.
Création d'une classe appelée Student qui s'étend à partir de la classe Person. Notez que le membre de l'instance de nom qui est défini dans la classe Person est hérité dans la classe Student.
Dans le constructeur de classe Student, nous appelons le constructeur de classe de base.
Dans notre classe Student, nous ajoutons 2 membres d'instance supplémentaires de StudentID et Marks1.
class Example {
static void main(String[] args) {
Student st = new Student();
st.StudentID = 1;
st.Marks1 = 10;
st.name = "Joe";
println(st.name);
}
}
class Person {
public String name;
public Person() {}
}
class Student extends Person {
int StudentID
int Marks1;
public Student() {
super();
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Joe
Classes intérieures
Les classes internes sont définies dans d'autres classes. La classe englobante peut utiliser la classe interne comme d'habitude. De l'autre côté, une classe interne peut accéder aux membres de sa classe englobante, même s'ils sont privés. Les classes autres que la classe englobante ne sont pas autorisées à accéder aux classes internes.
Voici un exemple de classe externe et interne. Dans l'exemple suivant, nous faisons les choses suivantes -
- Création d'une classe appelée Outer qui sera notre classe externe.
- Définition d'une chaîne appelée nom dans notre classe Outer.
- Création d'une classe interne ou imbriquée à l'intérieur de notre classe externe.
- Notez que dans la classe interne, nous pouvons accéder au membre de l'instance de nom défini dans la classe Outer.
class Example {
static void main(String[] args) {
Outer outobj = new Outer();
outobj.name = "Joe";
outobj.callInnerMethod()
}
}
class Outer {
String name;
def callInnerMethod() {
new Inner().methodA()
}
class Inner {
def methodA() {
println(name);
}
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Joe
Classes abstraites
Les classes abstraites représentent des concepts génériques, par conséquent, elles ne peuvent pas être instanciées, étant créées pour être sous-classées. Leurs membres incluent des champs / propriétés et des méthodes abstraites ou concrètes. Les méthodes abstraites n'ont pas d'implémentation et doivent être implémentées par des sous-classes concrètes. Les classes abstraites doivent être déclarées avec un mot-clé abstrait. Les méthodes abstraites doivent également être déclarées avec un mot-clé abstrait.
Dans l'exemple suivant, notez que la classe Person est désormais transformée en classe abstraite et ne peut pas être instanciée. Notez également qu'il existe une méthode abstraite appelée DisplayMarks dans la classe abstraite qui n'a pas de détails d'implémentation. Dans la classe des étudiants, il est obligatoire d'ajouter les détails d'implémentation.
class Example {
static void main(String[] args) {
Student st = new Student();
st.StudentID = 1;
st.Marks1 = 10;
st.name="Joe";
println(st.name);
println(st.DisplayMarks());
}
}
abstract class Person {
public String name;
public Person() { }
abstract void DisplayMarks();
}
class Student extends Person {
int StudentID
int Marks1;
public Student() {
super();
}
void DisplayMarks() {
println(Marks1);
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Joe
10
null
Interfaces
Une interface définit un contrat auquel une classe doit se conformer. Une interface définit uniquement une liste de méthodes qui doivent être implémentées, mais ne définit pas l'implémentation des méthodes. Une interface doit être déclarée à l'aide du mot clé interface. Une interface définit uniquement les signatures de méthode. Les méthodes d'une interface sont toujourspublic. C'est une erreur d'utiliser des méthodes protégées ou privées dans les interfaces.
Voici un exemple d'interface dans groovy. Dans l'exemple suivant, nous faisons les choses suivantes -
Création d'une interface appelée Marks et création d'une méthode d'interface appelée DisplayMarks.
Dans la définition de classe, nous utilisons le mot clé implements pour implémenter l'interface.
Parce que nous implémentons l'interface, nous devons fournir l'implémentation de la méthode DisplayMarks.
class Example {
static void main(String[] args) {
Student st = new Student();
st.StudentID = 1;
st.Marks1 = 10;
println(st.DisplayMarks());
}
}
interface Marks {
void DisplayMarks();
}
class Student implements Marks {
int StudentID
int Marks1;
void DisplayMarks() {
println(Marks1);
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
10
null
Les génériques permettent aux types (classes et interfaces) d'être des paramètres lors de la définition des classes, des interfaces et des méthodes. Tout comme les paramètres formels plus familiers utilisés dans les déclarations de méthode, les paramètres de type vous permettent de réutiliser le même code avec différentes entrées. La différence est que les entrées des paramètres formels sont des valeurs, tandis que les entrées des paramètres de type sont des types.
Générique pour les collections
Les classes de collections telles que la classe List peuvent être généralisées afin que seules les collections de ce type soient acceptées dans l'application. Un exemple de ArrayList généralisé est présenté ci-dessous. L'instruction suivante n'accepte que les éléments de liste qui sont de type chaîne -
List<String> list = new ArrayList<String>();
Dans l'exemple de code suivant, nous procédons comme suit -
- Création d'une collection ArrayList généralisée qui ne contiendra que des chaînes.
- Ajoutez 3 chaînes à la liste.
- Pour chaque élément de la liste, impression de la valeur des chaînes.
class Example {
static void main(String[] args) {
// Creating a generic List collection
List<String> list = new ArrayList<String>();
list.add("First String");
list.add("Second String");
list.add("Third String");
for(String str : list) {
println(str);
}
}
}
La sortie du programme ci-dessus serait -
First String
Second String
Third String
Classes généralisées
La classe entière peut également être généralisée. Cela rend la classe plus flexible pour accepter tous les types et travailler en conséquence avec ces types. Regardons un exemple de la façon dont nous pouvons y parvenir.
Dans le programme suivant, nous effectuons les étapes suivantes -
Nous créons une classe appelée ListType. Notez les mots-clés <T> placés devant la définition de classe. Cela indique au compilateur que cette classe peut accepter n'importe quel type. Ainsi, lorsque nous déclarons un objet de cette classe, nous pouvons spécifier un type lors de la déclaration et ce type serait remplacé dans l'espace réservé <T>
La classe générique a de simples méthodes getter et setter pour travailler avec la variable membre définie dans la classe.
Dans le programme principal, notez que nous sommes en mesure de déclarer des objets de la classe ListType, mais de types différents. Le premier est de type Integer et le second est de type String.
class Example {
static void main(String[] args) {
// Creating a generic List collection
ListType<String> lststr = new ListType<>();
lststr.set("First String");
println(lststr.get());
ListType<Integer> lstint = new ListType<>();
lstint.set(1);
println(lstint.get());
}
}
public class ListType<T> {
private T localt;
public T get() {
return this.localt;
}
public void set(T plocal) {
this.localt = plocal;
}
}
La sortie du programme ci-dessus serait -
First String
1
Les traits sont une construction structurelle du langage qui permet -
- Composition des comportements.
- Implémentation à l'exécution des interfaces.
- Compatibilité avec la vérification / compilation de type statique
Ils peuvent être considérés comme des interfaces portant à la fois des implémentations et un état par défaut. Un trait est défini à l'aide du mot-clé trait.
Un exemple de trait est donné ci-dessous -
trait Marks {
void DisplayMarks() {
println("Display Marks");
}
}
On peut ensuite utiliser le mot-clé implémenter pour implémenter le trait de la même manière que les interfaces.
class Example {
static void main(String[] args) {
Student st = new Student();
st.StudentID = 1;
st.Marks1 = 10;
println(st.DisplayMarks());
}
}
trait Marks {
void DisplayMarks() {
println("Display Marks");
}
}
class Student implements Marks {
int StudentID
int Marks1;
}
Implémentation d'interfaces
Les traits peuvent implémenter des interfaces, auquel cas les interfaces sont déclarées à l'aide du mot clé implements.
Un exemple de trait implémentant une interface est donné ci-dessous. Dans l'exemple suivant, les points clés suivants peuvent être notés.
Une interface Total est définie avec la méthode DisplayTotal.
Le trait Marks implémente l'interface Total et doit donc fournir une implémentation pour la méthode DisplayTotal.
class Example {
static void main(String[] args) {
Student st = new Student();
st.StudentID = 1;
st.Marks1 = 10;
println(st.DisplayMarks());
println(st.DisplayTotal());
}
}
interface Total {
void DisplayTotal()
}
trait Marks implements Total {
void DisplayMarks() {
println("Display Marks");
}
void DisplayTotal() {
println("Display Total");
}
}
class Student implements Marks {
int StudentID
int Marks1;
}
La sortie du programme ci-dessus serait -
Display Marks
Display Total
Propriétés
Un trait peut définir des propriétés. Un exemple de trait avec une propriété est donné ci-dessous.
Dans l'exemple suivant, le Marks1 de type integer est une propriété.
class Example {
static void main(String[] args) {
Student st = new Student();
st.StudentID = 1;
println(st.DisplayMarks());
println(st.DisplayTotal());
}
interface Total {
void DisplayTotal()
}
trait Marks implements Total {
int Marks1;
void DisplayMarks() {
this.Marks1 = 10;
println(this.Marks1);
}
void DisplayTotal() {
println("Display Total");
}
}
class Student implements Marks {
int StudentID
}
}
La sortie du programme ci-dessus serait -
10
Display Total
Composition des comportements
Les traits peuvent être utilisés pour implémenter l'héritage multiple de manière contrôlée, évitant ainsi le problème du diamant. Dans l'exemple de code suivant, nous avons défini deux traits -Marks et Total. Notre classe Student implémente les deux traits. Étant donné que la classe d'étudiants étend les deux traits, elle peut accéder aux deux méthodes -DisplayMarks et DisplayTotal.
class Example {
static void main(String[] args) {
Student st = new Student();
st.StudentID = 1;
println(st.DisplayMarks());
println(st.DisplayTotal());
}
}
trait Marks {
void DisplayMarks() {
println("Marks1");
}
}
trait Total {
void DisplayTotal() {
println("Total");
}
}
class Student implements Marks,Total {
int StudentID
}
La sortie du programme ci-dessus serait -
Total
Marks1
Extension des traits
Les traits peuvent étendre un autre trait, auquel cas vous devez utiliser le extendsmot-clé. Dans l'exemple de code suivant, nous étendons le trait Total avec le trait Marks.
class Example {
static void main(String[] args) {
Student st = new Student();
st.StudentID = 1;
println(st.DisplayMarks());
}
}
trait Marks {
void DisplayMarks() {
println("Marks1");
}
}
trait Total extends Marks {
void DisplayMarks() {
println("Total");
}
}
class Student implements Total {
int StudentID
}
La sortie du programme ci-dessus serait -
Total
Une fermeture est un court bloc de code anonyme. Il s'étend normalement sur quelques lignes de code. Une méthode peut même prendre le bloc de code comme paramètre. Ils sont de nature anonyme.
Voici un exemple de fermeture simple et à quoi cela ressemble.
class Example {
static void main(String[] args) {
def clos = {println "Hello World"};
clos.call();
}
}
Dans l'exemple ci-dessus, la ligne de code - {println "Hello World"} est appelée fermeture. Le bloc de code référencé par cet identifiant peut être exécuté avec l'instruction call.
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Hello World
Paramètres formels dans les fermetures
Les fermetures peuvent également contenir des paramètres formels pour les rendre plus utiles, tout comme les méthodes de Groovy.
class Example {
static void main(String[] args) {
def clos = {param->println "Hello ${param}"};
clos.call("World");
}
}
Dans l'exemple de code ci-dessus, notez l'utilisation de $ {param} qui oblige la fermeture à prendre un paramètre. Lors de l'appel de la fermeture via l'instruction clos.call, nous avons maintenant la possibilité de passer un paramètre à la fermeture.
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Hello World
L'illustration suivante répète l'exemple précédent et produit le même résultat, mais montre qu'un paramètre unique implicite désigné comme il peut être utilisé. Ici 'c'est' est un mot-clé dans Groovy.
class Example {
static void main(String[] args) {
def clos = {println "Hello ${it}"};
clos.call("World");
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Hello World
Fermetures et variables
Plus formellement, les fermetures peuvent faire référence à des variables au moment où la fermeture est définie. Voici un exemple de la manière dont cela peut être réalisé.
class Example {
static void main(String[] args) {
def str1 = "Hello";
def clos = {param -> println "${str1} ${param}"}
clos.call("World");
// We are now changing the value of the String str1 which is referenced in the closure
str1 = "Welcome";
clos.call("World");
}
}
Dans l'exemple ci-dessus, en plus de passer un paramètre à la fermeture, nous définissons également une variable appelée str1. La fermeture prend également la variable avec le paramètre.
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Hello World
Welcome World
Utilisation des fermetures dans les méthodes
Les fermetures peuvent également être utilisées comme paramètres de méthodes. Dans Groovy, de nombreuses méthodes intégrées pour les types de données tels que les listes et les collections ont des fermetures comme type de paramètre.
L'exemple suivant montre comment une fermeture peut être envoyée à une méthode en tant que paramètre.
class Example {
def static Display(clo) {
// This time the $param parameter gets replaced by the string "Inner"
clo.call("Inner");
}
static void main(String[] args) {
def str1 = "Hello";
def clos = { param -> println "${str1} ${param}" }
clos.call("World");
// We are now changing the value of the String str1 which is referenced in the closure
str1 = "Welcome";
clos.call("World");
// Passing our closure to a method
Example.Display(clos);
}
}
Dans l'exemple ci-dessus,
Nous définissons une méthode statique appelée Display qui prend une fermeture comme argument.
Nous définissons ensuite une fermeture dans notre méthode principale et la passons à notre méthode Display en tant que paramètre.
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Hello World
Welcome World
Welcome Inner
Fermetures dans les collections et la chaîne
Plusieurs méthodes List, Map et String acceptent une fermeture comme argument. Regardons un exemple de la façon dont les fermetures peuvent être utilisées dans ces types de données.
Utilisation de fermetures avec des listes
L'exemple suivant montre comment les fermetures peuvent être utilisées avec les listes. Dans l'exemple suivant, nous définissons d'abord une simple liste de valeurs. Le type de collection de liste définit ensuite une fonction appelée.each. Cette fonction prend une fermeture comme paramètre et applique la fermeture à chaque élément de la liste.
class Example {
static void main(String[] args) {
def lst = [11, 12, 13, 14];
lst.each {println it}
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
11
12
13
14
Utilisation des fermetures avec des cartes
L'exemple suivant montre comment les fermetures peuvent être utilisées avec Maps. Dans l'exemple suivant, nous définissons d'abord une simple carte d'éléments de valeur clé. Le type de collection de cartes définit ensuite une fonction appelée .each. Cette fonction prend une fermeture comme paramètre et applique la fermeture à chaque paire clé-valeur de la carte.
class Example {
static void main(String[] args) {
def mp = ["TopicName" : "Maps", "TopicDescription" : "Methods in Maps"]
mp.each {println it}
mp.each {println "${it.key} maps to: ${it.value}"}
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
TopicName = Maps
TopicDescription = Methods in Maps
TopicName maps to: Maps
TopicDescription maps to: Methods in Maps
Souvent, nous souhaitons effectuer une itération parmi les membres d'une collection et appliquer une logique uniquement lorsque l'élément répond à un critère. Ceci est facilement traité avec une instruction conditionnelle dans la fermeture.
class Example {
static void main(String[] args) {
def lst = [1,2,3,4];
lst.each {println it}
println("The list will only display those numbers which are divisible by 2")
lst.each{num -> if(num % 2 == 0) println num}
}
}
L'exemple ci-dessus montre l'expression conditionnelle if (num% 2 == 0) utilisée dans la fermeture qui est utilisée pour vérifier si chaque élément de la liste est divisible par 2.
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
1
2
3
4
The list will only display those numbers which are divisible by 2.
2
4
Méthodes utilisées avec les fermetures
Les fermetures elles-mêmes fournissent certaines méthodes.
Sr.No. | Méthodes et description |
---|---|
1 | trouver() La méthode find trouve la première valeur d'une collection qui correspond à un critère. |
2 | Trouver tout() Il trouve toutes les valeurs de l'objet récepteur correspondant à la condition de fermeture. |
3 | any () & every () La méthode any itère dans chaque élément d'une collection pour vérifier si un prédicat booléen est valide pour au moins un élément. |
4 | collecte() La méthode collect itère dans une collection, convertissant chaque élément en une nouvelle valeur en utilisant la fermeture comme transformateur. |
Les annotations sont une forme de métadonnées dans lesquelles elles fournissent des données sur un programme qui ne fait pas partie du programme lui-même. Les annotations n'ont aucun effet direct sur le fonctionnement du code qu'elles annotent.
Les annotations sont principalement utilisées pour les raisons suivantes -
Information for the compiler - Les annotations peuvent être utilisées par le compilateur pour détecter les erreurs ou supprimer les avertissements.
Compile-time and deployment-time processing - Les outils logiciels peuvent traiter les informations d'annotation pour générer du code, des fichiers XML, etc.
Runtime processing - Certaines annotations peuvent être examinées lors de l'exécution.
Dans Groovy, une annotation de base se présente comme suit -
@interface - Le caractère de signe arobase (@) indique au compilateur que ce qui suit est une annotation.
Une annotation peut définir des membres dans the form de méthodes sans corps et une valeur par défaut facultative.
Les annotations peuvent être appliquées aux types suivants -
Type de chaîne
Un exemple d'annotation pour une chaîne est donné ci-dessous -
@interface Simple {
String str1() default "HelloWorld";
}
Type d'énumération
enum DayOfWeek { mon, tue, wed, thu, fri, sat, sun }
@interface Scheduled {
DayOfWeek dayOfWeek()
}
Type de classe
@interface Simple {}
@Simple
class User {
String username
int age
}
def user = new User(username: "Joe",age:1);
println(user.age);
println(user.username);
Valeurs des membres d'annotation
Lorsqu'une annotation est utilisée, il est nécessaire de définir au moins tous les membres qui n'ont pas de valeur par défaut. Un exemple est donné ci-dessous. Lorsque l'exemple d'annotation est utilisé après avoir été défini, une valeur doit lui être affectée.
@interface Example {
int status()
}
@Example(status = 1)
Paramètres d'annotation de fermeture
Une bonne fonctionnalité des annotations dans Groovy est que vous pouvez également utiliser une fermeture comme valeur d'annotation. Par conséquent, les annotations peuvent être utilisées avec une grande variété d'expressions.
Un exemple est donné ci-dessous à ce sujet. L'annotation Onlyif est créée en fonction d'une valeur de classe. Ensuite, l'annotation est appliquée à deux méthodes qui publient des messages différents dans la variable de résultat en fonction de la valeur de la variable numérique.
@interface OnlyIf {
Class value()
}
@OnlyIf({ number<=6 })
void Version6() {
result << 'Number greater than 6'
}
@OnlyIf({ number>=6 })
void Version7() {
result << 'Number greater than 6'
}
Annotations méta
C'est une fonctionnalité très utile des annotations dans groovy. Il peut arriver que vous ayez plusieurs annotations pour une méthode comme celle illustrée ci-dessous. Parfois, cela peut devenir compliqué d'avoir plusieurs annotations.
@Procedure
@Master class
MyMasterProcedure {}
Dans un tel cas, vous pouvez définir une méta-annotation qui associe plusieurs annotations et appliquer la méta-annotation à la méthode. Donc, pour l'exemple ci-dessus, vous pouvez d'abord définir la collection d'annotations à l'aide de AnnotationCollector.
import groovy.transform.AnnotationCollector
@Procedure
@Master
@AnnotationCollector
Une fois que cela est fait, vous pouvez appliquer le méta-annotateur suivant à la méthode -
import groovy.transform.AnnotationCollector
@Procedure
@Master
@AnnotationCollector
@MasterProcedure
class MyMasterProcedure {}
XML est un langage open source portable qui permet aux programmeurs de développer des applications qui peuvent être lues par d'autres applications, quel que soit le système d'exploitation et / ou le langage de développement. Il s'agit de l'un des langages les plus couramment utilisés pour l'échange de données entre applications.
Qu'est-ce que XML?
Le XML du langage de balisage extensible est un langage de balisage semblable au HTML ou au SGML. Ceci est recommandé par le World Wide Web Consortium et disponible en tant que norme ouverte. XML est extrêmement utile pour garder une trace de petites et moyennes quantités de données sans avoir besoin d'un backbone basé sur SQL.
Prise en charge XML dans Groovy
Le langage Groovy fournit également un support riche du langage XML. Les deux classes XML les plus basiques utilisées sont -
XML Markup Builder- Groovy prend en charge un générateur de balisage basé sur une arborescence, BuilderSupport, qui peut être sous-classé pour créer une variété de représentations d'objets structurés en arborescence. Généralement, ces générateurs sont utilisés pour représenter le balisage XML, le balisage HTML. Le générateur de balisage de Groovy intercepte les appels à des pseudométries et les convertit en éléments ou nœuds d'une structure arborescente. Les paramètres de ces pseudo-méthodes sont traités comme des attributs des nœuds. Les fermetures faisant partie de l'appel de méthode sont considérées comme un sous-contenu imbriqué pour le nœud d'arbre résultant.
XML Parser- La classe Groovy XmlParser utilise un modèle simple pour analyser un document XML dans une arborescence d'instances Node. Chaque nœud a le nom de l'élément XML, les attributs de l'élément et des références à tous les nœuds enfants. Ce modèle est suffisant pour la plupart des traitements XML simples.
Pour tous nos exemples de code XML, utilisons le simple fichier XML movies.xml pour la construction du fichier XML et la lecture du fichier par la suite.
<collection shelf = "New Arrivals">
<movie title = "Enemy Behind">
<type>War, Thriller</type>
<format>DVD</format>
<year>2003</year>
<rating>PG</rating>
<stars>10</stars>
<description>Talk about a US-Japan war</description>
</movie>
<movie title = "Transformers">
<type>Anime, Science Fiction</type>
<format>DVD</format>
<year>1989</year>
<rating>R</rating>
<stars>8</stars>
<description>A schientific fiction</description>
</movie>
<movie title = "Trigun">
<type>Anime, Action</type>
<format>DVD</format>
<year>1986</year>
<rating>PG</rating>
<stars>10</stars>
<description>Vash the Stam pede!</description>
</movie>
<movie title = "Ishtar">
<type>Comedy</type>
<format>VHS</format>
<year>1987</year>
<rating>PG</rating>
<stars>2</stars>
<description>Viewable boredom </description>
</movie>
</collection>
Générateur de balisage XML
Syntaxe
public MarkupBuilder()
Le MarkupBuilder est utilisé pour construire l'ensemble du document XML. Le document XML est créé en créant d'abord un objet de la classe de document XML. Une fois l'objet créé, une pseudo-méthode peut être appelée pour créer les différents éléments du document XML.
Regardons un exemple de comment créer un bloc, c'est-à-dire un élément de film à partir du document XML ci-dessus -
import groovy.xml.MarkupBuilder
class Example {
static void main(String[] args) {
def mB = new MarkupBuilder()
// Compose the builder
mB.collection(shelf : 'New Arrivals') {
movie(title : 'Enemy Behind')
type('War, Thriller')
format('DVD')
year('2003')
rating('PG')
stars(10)
description('Talk about a US-Japan war')
}
}
}
Dans l'exemple ci-dessus, les choses suivantes doivent être notées -
mB.collection() - Ceci est un générateur de balisage qui crée la balise XML head de <collection> </collection>
movie(title : 'Enemy Behind')- Ces pseudo-méthodes créent les balises enfants avec cette méthode créant la balise avec la valeur. En spécifiant une valeur appelée title, cela indique en fait qu'un attribut doit être créé pour l'élément.
Une fermeture est fournie à la pseudo-méthode pour créer les éléments restants du document XML.
Le constructeur par défaut de la classe MarkupBuilder est initialisé afin que le XML généré soit émis vers le flux de sortie standard
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
<collection shelf = 'New Arrivals'>
<movie title = 'Enemy Behind' />
<type>War, Thriller</type>
<format>DVD</format>
<year>2003</year>
<rating>PG</rating>
<stars>10</stars>
<description>Talk about a US-Japan war</description>
</movie>
</collection>
Pour créer l'intégralité du document XML, les opérations suivantes doivent être effectuées.
- Une entrée de carte doit être créée pour stocker les différentes valeurs des éléments.
- Pour chaque élément de la carte, nous attribuons la valeur à chaque élément.
import groovy.xml.MarkupBuilder
class Example {
static void main(String[] args) {
def mp = [1 : ['Enemy Behind', 'War, Thriller','DVD','2003',
'PG', '10','Talk about a US-Japan war'],
2 : ['Transformers','Anime, Science Fiction','DVD','1989',
'R', '8','A scientific fiction'],
3 : ['Trigun','Anime, Action','DVD','1986',
'PG', '10','Vash the Stam pede'],
4 : ['Ishtar','Comedy','VHS','1987', 'PG',
'2','Viewable boredom ']]
def mB = new MarkupBuilder()
// Compose the builder
def MOVIEDB = mB.collection('shelf': 'New Arrivals') {
mp.each {
sd ->
mB.movie('title': sd.value[0]) {
type(sd.value[1])
format(sd.value[2])
year(sd.value[3])
rating(sd.value[4])
stars(sd.value[4])
description(sd.value[5])
}
}
}
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
<collection shelf = 'New Arrivals'>
<movie title = 'Enemy Behind'>
<type>War, Thriller</type>
<format>DVD</format>
<year>2003</year>
<rating>PG</rating>
<stars>PG</stars>
<description>10</description>
</movie>
<movie title = 'Transformers'>
<type>Anime, Science Fiction</type>
<format>DVD</format>
<year>1989</year>
<rating>R</rating>
<stars>R</stars>
<description>8</description>
</movie>
<movie title = 'Trigun'>
<type>Anime, Action</type>
<format>DVD</format>
<year>1986</year>
<rating>PG</rating>
<stars>PG</stars>
<description>10</description>
</movie>
<movie title = 'Ishtar'>
<type>Comedy</type>
<format>VHS</format>
<year>1987</year>
<rating>PG</rating>
<stars>PG</stars>
<description>2</description>
</movie>
</collection>
Analyse XML
La classe Groovy XmlParser utilise un modèle simple pour analyser un document XML dans une arborescence d'instances Node. Chaque nœud a le nom de l'élément XML, les attributs de l'élément et des références à tous les nœuds enfants. Ce modèle est suffisant pour la plupart des traitements XML simples.
Syntaxe
public XmlParser()
throws ParserConfigurationException,
SAXException
Le code suivant montre un exemple de la façon dont l'analyseur XML peut être utilisé pour lire un document XML.
Supposons que nous ayons le même document appelé Movies.xml et que nous voulions analyser le document XML et afficher une sortie appropriée à l'utilisateur. Le code suivant est un extrait de la façon dont nous pouvons parcourir tout le contenu du document XML et afficher une réponse appropriée à l'utilisateur.
import groovy.xml.MarkupBuilder
import groovy.util.*
class Example {
static void main(String[] args) {
def parser = new XmlParser()
def doc = parser.parse("D:\\Movies.xml");
doc.movie.each{
bk->
print("Movie Name:")
println "${bk['@title']}" print("Movie Type:") println "${bk.type[0].text()}"
print("Movie Format:")
println "${bk.format[0].text()}" print("Movie year:") println "${bk.year[0].text()}"
print("Movie rating:")
println "${bk.rating[0].text()}" print("Movie stars:") println "${bk.stars[0].text()}"
print("Movie description:")
println "${bk.description[0].text()}"
println("*******************************")
}
}
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
Movie Name:Enemy Behind
Movie Type:War, Thriller
Movie Format:DVD
Movie year:2003
Movie rating:PG
Movie stars:10
Movie description:Talk about a US-Japan war
*******************************
Movie Name:Transformers
Movie Type:Anime, Science Fiction
Movie Format:DVD
Movie year:1989
Movie rating:R
Movie stars:8
Movie description:A schientific fiction
*******************************
Movie Name:Trigun
Movie Type:Anime, Action
Movie Format:DVD
Movie year:1986
Movie rating:PG
Movie stars:10
Movie description:Vash the Stam pede!
*******************************
Movie Name:Ishtar
Movie Type:Comedy
Movie Format:VHS
Movie year:1987
Movie rating:PG
Movie stars:2
Movie description:Viewable boredom
Les choses importantes à noter sur le code ci-dessus.
Un objet de la classe XmlParser est en cours de formation afin de pouvoir être utilisé pour analyser le document XML.
L'analyseur reçoit l'emplacement du fichier XML.
Pour chaque élément de film, nous utilisons une fermeture pour parcourir chaque nœud enfant et afficher les informations pertinentes.
Pour l'élément movie lui-même, nous utilisons le symbole @ pour afficher l'attribut title attaché à l'élément movie.
JMX est le standard de facto qui est utilisé pour surveiller toutes les applications qui ont quelque chose à voir avec l'environnement viruel Java. Étant donné que Groovy se trouve directement au-dessus de Java, Groovy peut tirer parti de l'énorme quantité de travail déjà effectué pour JMX avec Java.
Surveillance de la JVM
On peut utiliser les classes standard disponibles dans java.lang.management pour effectuer le monitoring de la JVM. L'exemple de code suivant montre comment cela peut être fait.
import java.lang.management.*
def os = ManagementFactory.operatingSystemMXBean
println """OPERATING SYSTEM:
\tOS architecture = $os.arch
\tOS name = $os.name \tOS version = $os.version
\tOS processors = $os.availableProcessors """ def rt = ManagementFactory.runtimeMXBean println """RUNTIME: \tRuntime name = $rt.name
\tRuntime spec name = $rt.specName \tRuntime vendor = $rt.specVendor
\tRuntime spec version = $rt.specVersion \tRuntime management spec version = $rt.managementSpecVersion
"""
def mem = ManagementFactory.memoryMXBean
def heapUsage = mem.heapMemoryUsage
def nonHeapUsage = mem.nonHeapMemoryUsage
println """MEMORY:
HEAP STORAGE:
\tMemory committed = $heapUsage.committed \tMemory init = $heapUsage.init
\tMemory max = $heapUsage.max \tMemory used = $heapUsage.used NON-HEAP STORAGE:
\tNon-heap memory committed = $nonHeapUsage.committed \tNon-heap memory init = $nonHeapUsage.init
\tNon-heap memory max = $nonHeapUsage.max \tNon-heap memory used = $nonHeapUsage.used
"""
println "GARBAGE COLLECTION:"
ManagementFactory.garbageCollectorMXBeans.each { gc ->
println "\tname = $gc.name" println "\t\tcollection count = $gc.collectionCount"
println "\t\tcollection time = $gc.collectionTime" String[] mpoolNames = gc.memoryPoolNames mpoolNames.each { mpoolName -> println "\t\tmpool name = $mpoolName"
}
}
Lorsque le code est exécuté, la sortie varie en fonction du système sur lequel le code est exécuté. Un exemple de la sortie est donné ci-dessous.
OPERATING SYSTEM:
OS architecture = x86
OS name = Windows 7
OS version = 6.1
OS processors = 4
RUNTIME:
Runtime name = 5144@Babuli-PC
Runtime spec name = Java Virtual Machine Specification
Runtime vendor = Oracle Corporation
Runtime spec version = 1.7
Runtime management spec version = 1.2
MEMORY:
HEAP STORAGE:
Memory committed = 16252928
Memory init = 16777216
Memory max = 259522560
Memory used = 7355840
NON-HEAP STORAGE:
Non-heap memory committed = 37715968
Non-heap memory init = 35815424
Non-heap memory max = 123731968
Non-heap memory used = 18532232
GARBAGE COLLECTION:
name = Copy
collection count = 15
collection time = 47
mpool name = Eden Space
mpool name = Survivor Space
name = MarkSweepCompact
collection count = 0
collection time = 0
mpool name = Eden Space
mpool name = Survivor Space
mpool name = Tenured Gen
mpool name = Perm Gen
mpool name = Perm Gen [shared-ro]
mpool name = Perm Gen [shared-rw]
Surveillance de Tomcat
Afin de surveiller tomcat, le paramètre suivant doit être défini au démarrage de tomcat -
set JAVA_OPTS = -Dcom.sun.management.jmxremote
Dcom.sun.management.jmxremote.port = 9004\
-Dcom.sun.management.jmxremote.authenticate=false
Dcom.sun.management.jmxremote.ssl = false
Le code suivant utilise JMX pour découvrir les MBeans disponibles dans le Tomcat en cours d'exécution, déterminer quels sont les modules Web et extraire le temps de traitement de chaque module Web.
import groovy.swing.SwingBuilder
import javax.management.ObjectName
import javax.management.remote.JMXConnectorFactory as JmxFactory
import javax.management.remote.JMXServiceURL as JmxUrl
import javax.swing.WindowConstants as WC
import org.jfree.chart.ChartFactory
import org.jfree.data.category.DefaultCategoryDataset as Dataset
import org.jfree.chart.plot.PlotOrientation as Orientation
def serverUrl = 'service:jmx:rmi:///jndi/rmi://localhost:9004/jmxrmi'
def server = JmxFactory.connect(new JmxUrl(serverUrl)).MBeanServerConnection
def serverInfo = new GroovyMBean(server, 'Catalina:type = Server').serverInfo
println "Connected to: $serverInfo" def query = new ObjectName('Catalina:*') String[] allNames = server.queryNames(query, null) def modules = allNames.findAll { name -> name.contains('j2eeType=WebModule') }.collect{ new GroovyMBean(server, it) } println "Found ${modules.size()} web modules. Processing ..."
def dataset = new Dataset()
modules.each { m ->
println m.name()
dataset.addValue m.processingTime, 0, m.path
}
Ce chapitre explique comment utiliser le langage Groovy pour analyser et produire des objets JSON.
Fonctions JSON
Sr.Non | Fonctions et bibliothèques |
---|---|
1 | JsonSlurper JsonSlurper est une classe qui analyse le texte JSON ou le contenu du lecteur en données Groovy Structures telles que les cartes, les listes et les types primitifs tels que Integer, Double, Boolean et String. |
2 | JsonOutput Cette méthode est responsable de la sérialisation des objets Groovy dans des chaînes JSON. |
Analyse des données à l'aide de JsonSlurper
JsonSlurper est une classe qui analyse le texte JSON ou le contenu du lecteur dans des structures de données Groovy telles que des cartes, des listes et des types primitifs comme Integer, Double, Boolean et String.
Syntaxe
def slurper = new JsonSlurper()
JSON slurper analyse le texte ou le contenu du lecteur dans une structure de données de listes et de cartes.
La classe JsonSlurper est fournie avec quelques variantes pour les implémentations d'analyseur. Parfois, vous pouvez avoir des exigences différentes en ce qui concerne l'analyse de certaines chaînes. Prenons un exemple dans lequel il faut lire le JSON qui est renvoyé par la réponse d'un serveur Web. Dans un tel cas, il est avantageux d'utiliser la variante de l'analyseur JsonParserLax. Cet analyseur autorise les commentaires dans le texte JSON ainsi que les chaînes sans guillemets, etc. Pour spécifier ce type d'analyseur, vous devez utiliser le type d'analyseur JsonParserType.LAX lors de la définition d'un objet du JsonSlurper.
Voyons un exemple ci-dessous. L'exemple est pour obtenir des données JSON à partir d'un serveur Web à l'aide du module http. Pour ce type de parcours, la meilleure option est d'avoir le type d'analyseur défini sur la variante JsonParserLax.
http.request( GET, TEXT ) {
headers.Accept = 'application/json'
headers.'User-Agent' = USER_AGENT
response.success = {
res, rd ->
def jsonText = rd.text
//Setting the parser type to JsonParserLax
def parser = new JsonSlurper().setType(JsonParserType.LAX)
def jsonResp = parser.parseText(jsonText)
}
}
De même, les types d'analyseurs supplémentaires suivants sont disponibles dans Groovy -
L'analyseur JsonParserCharArray prend essentiellement une chaîne JSON et opère sur le tableau de caractères sous-jacent. Pendant la conversion de valeur, il copie les sous-tableaux de caractères (un mécanisme connu sous le nom de "hachage") et opère sur eux individuellement.
Le JsonFastParser est une variante spéciale du JsonParserCharArray et est l'analyseur le plus rapide. JsonFastParser est également connu comme l'analyseur de superposition d'index. Lors de l'analyse de la chaîne JSON donnée, il essaie autant que possible d'éviter de créer de nouveaux tableaux de caractères ou des instances de chaîne. Il ne conserve que les pointeurs vers le tableau de caractères d'origine sous-jacent uniquement. De plus, il reporte la création d'objet le plus tard possible.
Le JsonParserUsingCharacterSource est un analyseur spécial pour les fichiers très volumineux. Il utilise une technique appelée «fenêtrage de caractères» pour analyser de gros fichiers JSON (gros signifie des fichiers de plus de 2 Mo dans ce cas) avec des caractéristiques de performances constantes.
Analyse du texte
Jetons un coup d'œil à quelques exemples d'utilisation de la classe JsonSlurper.
import groovy.json.JsonSlurper
class Example {
static void main(String[] args) {
def jsonSlurper = new JsonSlurper()
def object = jsonSlurper.parseText('{ "name": "John", "ID" : "1"}')
println(object.name);
println(object.ID);
}
}
Dans l'exemple ci-dessus, nous sommes -
Créer d'abord une instance de la classe JsonSlurper
Nous utilisons ensuite la fonction parseText de la classe JsonSlurper pour analyser du texte JSON.
Lorsque nous obtenons l'objet, vous pouvez voir que nous pouvons réellement accéder aux valeurs de la chaîne JSON via la clé.
La sortie du programme ci-dessus est donnée ci-dessous -
John
1
Analyse de la liste des nombres entiers
Jetons un coup d'œil à un autre exemple de la méthode d'analyse JsonSlurper. Dans l'exemple suivant, nous passons une liste d'entiers. Vous remarquerez à partir du code suivant que nous sommes en mesure d'utiliser la méthode List de chacun et de lui passer une fermeture.
import groovy.json.JsonSlurper
class Example {
static void main(String[] args) {
def jsonSlurper = new JsonSlurper()
Object lst = jsonSlurper.parseText('{ "List": [2, 3, 4, 5] }')
lst.each { println it }
}
}
La sortie du programme ci-dessus est donnée ci-dessous -
List=[2, 3, 4, 5]
Analyse de la liste des types de données primitives
L'analyseur JSON prend également en charge les types de données primitifs de chaîne, nombre, objet, vrai, faux et nul. La classe JsonSlurper convertit ces types JSON en types Groovy correspondants.
L'exemple suivant montre comment utiliser JsonSlurper pour analyser une chaîne JSON. Et ici, vous pouvez voir que JsonSlurper est capable d'analyser les éléments individuels dans leurs types primitifs respectifs.
import groovy.json.JsonSlurper
class Example {
static void main(String[] args) {
def jsonSlurper = new JsonSlurper()
def obj = jsonSlurper.parseText ''' {"Integer": 12, "fraction": 12.55, "double": 12e13}'''
println(obj.Integer);
println(obj.fraction);
println(obj.double);
}
}
La sortie du programme ci-dessus est donnée ci-dessous -
12
12.55
1.2E+14
JsonOutput
Voyons maintenant comment imprimer la sortie dans Json. Cela peut être fait par la méthode JsonOutput. Cette méthode est responsable de la sérialisation des objets Groovy dans des chaînes JSON.
Syntaxe
Static string JsonOutput.toJson(datatype obj)
Parameters - Les paramètres peuvent être un objet d'un type de données - Nombre, Booléen, caractère, Chaîne, Date, Carte, fermeture etc.
Return type - Le type de retour est une chaîne json.
Exemple
Voici un exemple simple de la manière dont cela peut être réalisé.
import groovy.json.JsonOutput
class Example {
static void main(String[] args) {
def output = JsonOutput.toJson([name: 'John', ID: 1])
println(output);
}
}
La sortie du programme ci-dessus est donnée ci-dessous -
{"name":"John","ID":1}
Le JsonOutput peut également être utilisé pour de vieux objets groovy simples. Dans l'exemple suivant, vous pouvez voir que nous transmettons en fait des objets du type Student à la méthode JsonOutput.
import groovy.json.JsonOutput
class Example {
static void main(String[] args) {
def output = JsonOutput.toJson([ new Student(name: 'John',ID:1),
new Student(name: 'Mark',ID:2)])
println(output);
}
}
class Student {
String name
int ID;
}
La sortie du programme ci-dessus est donnée ci-dessous -
[{"name":"John","ID":1},{"name":"Mark","ID":2}]
Groovy permet d'omettre les parenthèses autour des arguments d'un appel de méthode pour les instructions de niveau supérieur. C'est ce que l'on appelle la fonction "chaîne de commande". Cette extension fonctionne en permettant d'enchaîner de tels appels de méthode sans parenthèses, ne nécessitant ni parenthèses autour des arguments, ni points entre les appels chaînés.
Si un appel est exécuté comme a b c d, ce sera en fait équivalent à a(b).c(d).
Le langage DSL ou spécifique au domaine est destiné à simplifier le code écrit en Groovy de manière à ce qu'il devienne facilement compréhensible pour l'utilisateur ordinaire. L'exemple suivant montre ce que signifie exactement le fait d'avoir un langage spécifique à un domaine.
def lst = [1,2,3,4]
print lst
Le code ci-dessus montre une liste de nombres imprimés sur la console à l'aide de l'instruction println. Dans un langage spécifique à un domaine, les commandes seraient comme -
Given the numbers 1,2,3,4
Display all the numbers
Ainsi, l'exemple ci-dessus montre la transformation du langage de programmation pour répondre aux besoins d'un langage spécifique à un domaine.
Regardons un exemple simple de la façon dont nous pouvons implémenter des DSL dans Groovy -
class EmailDsl {
String toText
String fromText
String body
/**
* This method accepts a closure which is essentially the DSL. Delegate the
* closure methods to
* the DSL class so the calls can be processed
*/
def static make(closure) {
EmailDsl emailDsl = new EmailDsl()
// any method called in closure will be delegated to the EmailDsl class
closure.delegate = emailDsl
closure()
}
/**
* Store the parameter as a variable and use it later to output a memo
*/
def to(String toText) {
this.toText = toText
}
def from(String fromText) {
this.fromText = fromText
}
def body(String bodyText) {
this.body = bodyText
}
}
EmailDsl.make {
to "Nirav Assar"
from "Barack Obama"
body "How are things? We are doing well. Take care"
}
Lorsque nous exécutons le programme ci-dessus, nous obtiendrons le résultat suivant -
How are things? We are doing well. Take care
Ce qui suit doit être noté à propos de l'implémentation du code ci-dessus -
Une méthode statique est utilisée qui accepte une fermeture. C'est surtout un moyen sans tracas d'implémenter un DSL.
Dans l'exemple de courrier électronique, la classe EmailDsl a une méthode make. Il crée une instance et délègue tous les appels de la fermeture à l'instance. C'est le mécanisme par lequel les sections «to» et «from» finissent par exécuter des méthodes à l'intérieur de la classe EmailDsl.
Une fois la méthode to () appelée, nous stockons le texte dans l'instance pour un formatage ultérieur.
Nous pouvons désormais appeler la méthode EmailDSL avec un langage simple et facile à comprendre pour les utilisateurs finaux.
Le module groovy-sql de Groovy fournit une abstraction de plus haut niveau par rapport à la technologie JDBC actuelle de Java. L'API Groovy sql prend en charge une grande variété de bases de données, dont certaines sont présentées ci-dessous.
- HSQLDB
- Oracle
- serveur SQL
- MySQL
- MongoDB
Dans notre exemple, nous allons utiliser MySQL DB comme exemple. Pour utiliser MySQL avec Groovy, la première chose à faire est de télécharger le fichier jar MySQL jdbc depuis le site mysql.The format de MySQL sera montré ci-dessous.
mysql-connector-java-5.1.38-bin
Assurez-vous ensuite d'ajouter le fichier jar ci-dessus au chemin d'accès aux classes de votre poste de travail.
Connexion à la base de données
Avant de vous connecter à une base de données MySQL, assurez-vous des points suivants -
- Vous avez créé une base de données TESTDB.
- Vous avez créé une table EMPLOYEE dans TESTDB.
- Cette table contient les champs FIRST_NAME, LAST_NAME, AGE, SEX et INCOME.
- L'ID utilisateur "testuser" et le mot de passe "test123" sont définis pour accéder à TESTDB.
- Assurez-vous d'avoir téléchargé le fichier jar mysql et ajouté le fichier à votre chemin de classe.
- Vous avez parcouru le didacticiel MySQL pour comprendre les bases de MySQL
L'exemple suivant montre comment se connecter à la base de données MySQL "TESTDB".
import java.sql.*;
import groovy.sql.Sql
class Example {
static void main(String[] args) {
// Creating a connection to the database
def sql = Sql.newInstance('jdbc:mysql://localhost:3306/TESTDB',
'testuser', 'test123', 'com.mysql.jdbc.Driver')
// Executing the query SELECT VERSION which gets the version of the database
// Also using the eachROW method to fetch the result from the database
sql.eachRow('SELECT VERSION()'){ row ->
println row[0]
}
sql.close()
}
}
Lors de l'exécution de ce script, il produit le résultat suivant -
5.7.10-log
The Sql.newInstance method is used to establish a connection to the database.
Création d'une table de base de données
La prochaine étape après la connexion à la base de données est de créer les tables dans notre base de données. L'exemple suivant montre comment créer une table dans la base de données à l'aide de Groovy. La méthode execute de la classe Sql est utilisée pour exécuter des instructions sur la base de données.
import java.sql.*;
import groovy.sql.Sql
class Example {
static void main(String[] args) {
// Creating a connection to the database
def sql = Sql.newInstance('jdbc:mysql://localhost:3306/TESTDB', 'testuser',
'test123', 'com.mysql.jdbc.Driver')
def sqlstr = """CREATE TABLE EMPLOYEE (
FIRST_NAME CHAR(20) NOT NULL,
LAST_NAME CHAR(20),
AGE INT,
SEX CHAR(1),
INCOME FLOAT )"""
sql.execute(sqlstr);
sql.close()
}
}
Insérer une opération
Il est nécessaire lorsque vous souhaitez créer vos enregistrements dans une table de base de données.
Exemple
L'exemple suivant insérera un enregistrement dans la table des employés. Le code est placé dans un bloc try catch de sorte que si l'enregistrement est exécuté avec succès, la transaction est validée dans la base de données. Si la transaction échoue, une annulation est effectuée.
import java.sql.*;
import groovy.sql.Sql
class Example {
static void main(String[] args) {
// Creating a connection to the database
def sql = Sql.newInstance('jdbc:mysql://localhost:3306/TESTDB', 'testuser',
'test123', 'com.mysql.jdbc.Driver')
sql.connection.autoCommit = false
def sqlstr = """INSERT INTO EMPLOYEE(FIRST_NAME,
LAST_NAME, AGE, SEX, INCOME) VALUES ('Mac', 'Mohan', 20, 'M', 2000)"""
try {
sql.execute(sqlstr);
sql.commit()
println("Successfully committed")
}catch(Exception ex) {
sql.rollback()
println("Transaction rollback")
}
sql.close()
}
}
Supposons que vous vouliez simplement sélectionner certaines lignes en fonction d'un critère. Le code suivant montre comment vous pouvez ajouter un espace réservé de paramètre pour rechercher des valeurs. L'exemple ci-dessus peut également être écrit pour prendre des paramètres comme indiqué dans le code suivant. Le symbole $ est utilisé pour définir un paramètre qui peut ensuite être remplacé par des valeurs lorsque l'instruction sql est exécutée.
import java.sql.*;
import groovy.sql.Sql
class Example {
static void main(String[] args) {
// Creating a connection to the database
def sql = Sql.newInstance('jdbc:mysql://localhost:3306/TESTDB', 'testuser',
'test123', 'com.mysql.jdbc.Driver')
sql.connection.autoCommit = false
def firstname = "Mac"
def lastname ="Mohan"
def age = 20
def sex = "M"
def income = 2000
def sqlstr = "INSERT INTO EMPLOYEE(FIRST_NAME,LAST_NAME, AGE, SEX,
INCOME) VALUES " + "(${firstname}, ${lastname}, ${age}, ${sex}, ${income} )"
try {
sql.execute(sqlstr);
sql.commit()
println("Successfully committed")
} catch(Exception ex) {
sql.rollback()
println("Transaction rollback")
}
sql.close()
}
}
LIRE l'opération
LIRE L'opération sur n'importe quelle base de données signifie récupérer des informations utiles dans la base de données. Une fois notre connexion à la base de données établie, vous êtes prêt à effectuer une requête dans cette base de données.
L'opération de lecture est effectuée à l'aide de la méthode eachRow de la classe sql.
Syntaxe
eachRow(GString gstring, Closure closure)
Exécute la requête SQL donnée en appelant la fermeture donnée avec chaque ligne du jeu de résultats.
Parameters
Gstring - L'instruction sql qui doit être exécutée.
Closure- L'instruction de fermeture pour traiter les lignes extraites de l'opération de lecture. Exécute la requête SQL donnée en appelant la fermeture donnée avec chaque ligne du jeu de résultats.
L'exemple de code suivant montre comment récupérer tous les enregistrements de la table des employés.
import java.sql.*;
import groovy.sql.Sql
class Example {
static void main(String[] args) {
// Creating a connection to the database
def sql = Sql.newInstance('jdbc:mysql://localhost:3306/TESTDB', 'testuser',
'test123', 'com.mysql.jdbc.Driver')
sql.eachRow('select * from employee') {
tp ->
println([tp.FIRST_NAME,tp.LAST_NAME,tp.age,tp.sex,tp.INCOME])
}
sql.close()
}
}
La sortie du programme ci-dessus serait -
[Mac, Mohan, 20, M, 2000.0]
Opération de mise à jour
UPDATE L'opération sur n'importe quelle base de données signifie mettre à jour un ou plusieurs enregistrements, qui sont déjà disponibles dans la base de données. La procédure suivante met à jour tous les enregistrements ayant SEX comme «M». Ici, nous augmentons l'âge de tous les hommes d'un an.
import java.sql.*;
import groovy.sql.Sql
class Example {
static void main(String[] args){
// Creating a connection to the database
def sql = Sql.newInstance('jdbc:mysql://localhost:3306/TESTDB', 'testuser',
'test@123', 'com.mysql.jdbc.Driver')
sql.connection.autoCommit = false
def sqlstr = "UPDATE EMPLOYEE SET AGE = AGE + 1 WHERE SEX = 'M'"
try {
sql.execute(sqlstr);
sql.commit()
println("Successfully committed")
}catch(Exception ex) {
sql.rollback()
println("Transaction rollback")
}
sql.close()
}
}
Effacer l'opération
L'opération DELETE est requise lorsque vous souhaitez supprimer certains enregistrements de votre base de données. Voici la procédure pour supprimer tous les enregistrements de EMPLOYÉ où AGE est supérieur à 20.
import java.sql.*;
import groovy.sql.Sql
class Example {
static void main(String[] args) {
// Creating a connection to the database
def sql = Sql.newInstance('jdbc:mysql://localhost:3306/TESTDB', 'testuser',
'test@123', 'com.mysql.jdbc.Driver')
sql.connection.autoCommit = false
def sqlstr = "DELETE FROM EMPLOYEE WHERE AGE > 20"
try {
sql.execute(sqlstr);
sql.commit()
println("Successfully committed")
}catch(Exception ex) {
sql.rollback()
println("Transaction rollback")
}
sql.close()
}
}
Effectuer des transactions
Les transactions sont un mécanisme qui garantit la cohérence des données. Les transactions ont les quatre propriétés suivantes -
Atomicity - Soit une transaction se termine, soit rien ne se passe du tout.
Consistency - Une transaction doit démarrer dans un état cohérent et laisser le système dans un état cohérent.
Isolation - Les résultats intermédiaires d'une transaction ne sont pas visibles en dehors de la transaction en cours.
Durability - Une fois qu'une transaction a été validée, les effets sont persistants, même après une panne du système.
Voici un exemple simple de mise en œuvre de transactions. Nous avons déjà vu cet exemple de notre rubrique précédente de l'opération DELETE.
def sqlstr = "DELETE FROM EMPLOYEE WHERE AGE > 20"
try {
sql.execute(sqlstr);
sql.commit()
println("Successfully committed")
}catch(Exception ex) {
sql.rollback()
println("Transaction rollback")
}
sql.close()
Opération de validation
L'opération de validation est ce qui indique à la base de données de poursuivre l'opération et de finaliser toutes les modifications apportées à la base de données.
Dans notre exemple ci-dessus, ceci est réalisé par la déclaration suivante -
sql.commit()
Opération de restauration
Si vous n'êtes pas satisfait d'une ou plusieurs des modifications et que vous souhaitez annuler complètement ces modifications, utilisez la méthode de restauration. Dans notre exemple ci-dessus, ceci est réalisé par la déclaration suivante -
sql.rollback()
Déconnexion des bases de données
Pour déconnecter la connexion à la base de données, utilisez la méthode close.
sql.close()
Au cours du processus de développement logiciel, les développeurs passent parfois beaucoup de temps à créer des structures de données, des classes de domaine, du XML, des dispositions d'interface graphique, des flux de sortie, etc. Et parfois le code utilisé pour créer ces exigences spécifiques entraîne la répétition du même extrait de code dans de nombreux endroits. C'est là que les constructeurs Groovy entrent en jeu. Groovy a des générateurs qui peuvent être utilisés pour créer des objets et des structures standard. Ces générateurs font gagner du temps car les développeurs n'ont pas besoin d'écrire leur propre code pour créer ces générateurs. Dans la suite de ce chapitre, nous examinerons les différents builders disponibles dans groovy.
Constructeur de balançoire
Dans groovy, on peut également créer des interfaces utilisateur graphiques en utilisant les swing builders disponibles dans groovy. La classe principale pour le développement de composants swing est la classe SwingBuilder. Cette classe a de nombreuses méthodes pour créer des composants graphiques tels que -
JFrame - C'est pour créer l'élément frame.
JTextField - Ceci est utilisé pour créer le composant textfield.
Regardons un exemple simple de création d'une application Swing à l'aide de la classe SwingBuilder. Dans l'exemple suivant, vous pouvez voir les points suivants -
Vous devez importer les classes groovy.swing.SwingBuilder et javax.swing. *.
Tous les composants affichés dans l'application Swing font partie de la classe SwingBuilder.
Pour le cadre lui-même, vous pouvez spécifier l'emplacement initial et la taille du cadre. Vous pouvez également spécifier le titre du cadre.
Vous devez définir la propriété Visibility sur true pour que le cadre soit affiché.
import groovy.swing.SwingBuilder
import javax.swing.*
// Create a builder
def myapp = new SwingBuilder()
// Compose the builder
def myframe = myapp.frame(title : 'Tutorials Point', location : [200, 200],
size : [400, 300], defaultCloseOperation : WindowConstants.EXIT_ON_CLOSE {
label(text : 'Hello world')
}
// The following statement is used for displaying the form
frame.setVisible(true)
La sortie du programme ci-dessus est donnée ci-dessous. La sortie suivante montre un JFrame avec un JLabel avec un texte de Hello World.
Regardons notre prochain exemple pour créer un écran de saisie avec des zones de texte. Dans l'exemple suivant, nous souhaitons créer un formulaire contenant des zones de texte pour le nom de l'étudiant, le sujet et le nom de l'école. Dans l'exemple suivant, vous pouvez voir les points clés suivants -
- Nous définissons une disposition pour nos contrôles à l'écran. Dans ce cas, nous utilisons la disposition en grille.
- Nous utilisons une propriété d'alignement pour nos étiquettes.
- Nous utilisons la méthode textField pour afficher les zones de texte à l'écran.
import groovy.swing.SwingBuilder
import javax.swing.*
import java.awt.*
// Create a builder
def myapp = new SwingBuilder()
// Compose the builder
def myframe = myapp.frame(title : 'Tutorials Point', location : [200, 200],
size : [400, 300], defaultCloseOperation : WindowConstants.EXIT_ON_CLOSE) {
panel(layout: new GridLayout(3, 2, 5, 5)) {
label(text : 'Student Name:', horizontalAlignment : JLabel.RIGHT)
textField(text : '', columns : 10)
label(text : 'Subject Name:', horizontalAlignment : JLabel.RIGHT)
textField(text : '', columns : 10)
label(text : 'School Name:', horizontalAlignment : JLabel.RIGHT)
textField(text : '', columns : 10)
}
}
// The following statement is used for displaying the form
myframe.setVisible(true)
La sortie du programme ci-dessus est donnée ci-dessous -
Gestionnaires d'événements
Regardons maintenant les gestionnaires d'événements. Les gestionnaires d'événements sont utilisés pour le bouton pour effectuer une sorte de traitement lorsqu'un bouton est enfoncé. Chaque appel de pseudo-méthode de bouton inclut le paramètre actionPerformed. Cela représente un bloc de code présenté comme une fermeture.
Regardons notre prochain exemple pour créer un écran avec 2 boutons. Lorsque l'un des boutons est enfoncé, un message correspondant est envoyé à l'écran de la console. Dans l'exemple suivant, vous pouvez voir les points clés suivants -
Pour chaque bouton défini, nous utilisons la méthode actionPerformed et définissons une fermeture pour envoyer une sortie à la console lorsque le bouton est cliqué.
import groovy.swing.SwingBuilder
import javax.swing.*
import java.awt.*
def myapp = new SwingBuilder()
def buttonPanel = {
myapp.panel(constraints : BorderLayout.SOUTH) {
button(text : 'Option A', actionPerformed : {
println 'Option A chosen'
})
button(text : 'Option B', actionPerformed : {
println 'Option B chosen'
})
}
}
def mainPanel = {
myapp.panel(layout : new BorderLayout()) {
label(text : 'Which Option do you want', horizontalAlignment :
JLabel.CENTER,
constraints : BorderLayout.CENTER)
buttonPanel()
}
}
def myframe = myapp.frame(title : 'Tutorials Point', location : [100, 100],
size : [400, 300], defaultCloseOperation : WindowConstants.EXIT_ON_CLOSE){
mainPanel()
}
myframe.setVisible(true)
La sortie du programme ci-dessus est donnée ci-dessous. Lorsque vous cliquez sur l'un des boutons, le message requis est envoyé à l'écran du journal de la console.
Une autre variante de l'exemple ci-dessus consiste à définir des méthodes qui peuvent jouer le rôle de gestionnaires. Dans l'exemple suivant, nous définissons 2 gestionnaires de DisplayA et DisplayB.
import groovy.swing.SwingBuilder
import javax.swing.*
import java.awt.*
def myapp = new SwingBuilder()
def DisplayA = {
println("Option A")
}
def DisplayB = {
println("Option B")
}
def buttonPanel = {
myapp.panel(constraints : BorderLayout.SOUTH) {
button(text : 'Option A', actionPerformed : DisplayA)
button(text : 'Option B', actionPerformed : DisplayB)
}
}
def mainPanel = {
myapp.panel(layout : new BorderLayout()) {
label(text : 'Which Option do you want', horizontalAlignment : JLabel.CENTER,
constraints : BorderLayout.CENTER)
buttonPanel()
}
}
def myframe = myapp.frame(title : 'Tutorials Point', location : [100, 100],
size : [400, 300], defaultCloseOperation : WindowConstants.EXIT_ON_CLOSE) {
mainPanel()
}
myframe.setVisible(true)
La sortie du programme ci-dessus resterait la même que celle de l'exemple précédent.
Générateur DOM
Le générateur DOM peut être utilisé pour analyser HTML, XHTML et XML et les convertir en une arborescence DOM W3C.
L'exemple suivant montre comment le générateur DOM peut être utilisé.
String records = '''
<library>
<Student>
<StudentName division = 'A'>Joe</StudentName>
<StudentID>1</StudentID>
</Student>
<Student>
<StudentName division = 'B'>John</StudentName>
<StudentID>2</StudentID>
</Student>
<Student>
<StudentName division = 'C'>Mark</StudentName>
<StudentID>3</StudentID>
</Student>
</library>'''
def rd = new StringReader(records)
def doc = groovy.xml.DOMBuilder.parse(rd)
JsonBuilder
Le JsonBuilder est utilisé pour créer des objets de type json.
L'exemple suivant montre comment le générateur Json peut être utilisé.
def builder = new groovy.json.JsonBuilder()
def root = builder.students {
student {
studentname 'Joe'
studentid '1'
Marks(
Subject1: 10,
Subject2: 20,
Subject3:30,
)
}
}
println(builder.toString());
La sortie du programme ci-dessus est donnée ci-dessous. La sortie clearlt montre que le Jsonbuilder a pu construire l'objet json à partir d'un ensemble structuré de nœuds.
{"students":{"student":{"studentname":"Joe","studentid":"1","Marks":{"Subject1":10,
"S ubject2":20,"Subject3":30}}}}
Le jsonbuilder peut également prendre une liste et la convertir en un objet json. L'exemple suivant montre comment cela peut être accompli.
def builder = new groovy.json.JsonBuilder()
def lst = builder([1, 2, 3])
println(builder.toString());
La sortie du programme ci-dessus est donnée ci-dessous.
[1,2,3]
Le jsonBuilder peut également être utilisé pour les classes. L'exemple suivant montre comment les objets d'une classe peuvent devenir des entrées dans le générateur json.
def builder = new groovy.json.JsonBuilder()
class Student {
String name
}
def studentlist = [new Student (name: "Joe"), new Student (name: "Mark"),
new Student (name: "John")]
builder studentlist, { Student student ->name student.name}
println(builder)
La sortie du programme ci-dessus est donnée ci-dessous.
[{"name":"Joe"},{"name":"Mark"},{"name":"John"}]
NodeBuilder
NodeBuilder est utilisé pour créer des arborescences imbriquées d'objets Node pour gérer des données arbitraires. Un exemple d'utilisation d'un Nodebuilder est présenté ci-dessous.
def nodeBuilder = new NodeBuilder()
def studentlist = nodeBuilder.userlist {
user(id: '1', studentname: 'John', Subject: 'Chemistry')
user(id: '2', studentname: 'Joe', Subject: 'Maths')
user(id: '3', studentname: 'Mark', Subject: 'Physics')
}
println(studentlist)
FileTreeBuilder
FileTreeBuilder est un générateur pour générer une structure de répertoire de fichiers à partir d'une spécification. Voici un exemple de la façon dont FileTreeBuilder peut être utilisé.
tmpDir = File.createTempDir()
def fileTreeBuilder = new FileTreeBuilder(tmpDir)
fileTreeBuilder.dir('main') {
dir('submain') {
dir('Tutorial') {
file('Sample.txt', 'println "Hello World"')
}
}
}
A partir de l'exécution du code ci-dessus, un fichier appelé sample.txt sera créé dans le dossier main / submain / Tutorial. Et le fichier sample.txt contiendra le texte «Hello World».
Le shell Groovy connu sous le nom de groovysh peut être facilement utilisé pour évaluer des expressions groovy, définir des classes et exécuter des programmes simples. Le shell de ligne de commande est installé lorsque Groovy est installé.
Voici les options de ligne de commande disponibles dans Groovy -
Paramètre de ligne de commande | Nom complet | Détails |
---|---|---|
-C | --couleur [= FLAG] | Activer ou désactiver l'utilisation des couleurs ANSI |
-RÉ | --define = NOM = VALEUR | Définir une propriété système |
-T | --terminal = TYPE | Spécifiez le TYPE de terminal à utiliser |
-V | --version | Afficher la version |
-classpath | Spécifiez où trouver les fichiers de classe - doit être le premier argument | |
-cp | --classpath | Alias pour «-classpath» |
-ré | --déboguer | --debug Activer la sortie de débogage |
-e | --evaluate = arg | Évaluer le premier choix lors du démarrage de la session interactive |
-h | --Aidez-moi | Afficher ce message d'aide |
-q | --silencieux | Supprimer la sortie superflue |
-v | --verbeux | Activer la sortie détaillée |
L'instantané suivant montre un exemple simple d'expression en cours d'exécution dans le shell Groovy. Dans l'exemple suivant, nous imprimons simplement «Hello World» dans le shell groovy.
Classes et fonctions
Il est très facile de définir une classe dans l'invite de commande, de créer un nouvel objet et d'appeler une méthode sur la classe. L'exemple suivant montre comment cela peut être implémenté. Dans l'exemple suivant, nous créons une classe Student simple avec une méthode simple. Dans l'invite de commande elle-même, nous créons un objet de la classe et appelons la méthode Display.
Il est très facile de définir une méthode dans l'invite de commande et d'appeler la méthode. Notez que la méthode est définie à l'aide du type def. Notez également que nous avons inclus un paramètre appelé nom qui est ensuite remplacé par la valeur réelle lorsque la méthode Display est appelée. L'exemple suivant montre comment cela peut être implémenté.
Commandes
Le shell a un certain nombre de commandes différentes, qui fournissent un accès riche à l'environnement du shell. Voici la liste d'entre eux et ce qu'ils font.
Sr.Non | Commande & smp; Description de la commande |
---|---|
1 | :help (: h) Afficher ce message d'aide |
2 | ? (:?) Alias vers:: help |
3 | :exit (: x) Quitter le shell |
4 | :quit (: q) Alias vers:: exit |
5 | import (: i) Importer une classe dans l'espace de noms |
6 | :display (: d) Afficher le tampon actuel |
sept | :clear (: c) Effacer le tampon et réinitialiser le compteur d'invite |
8 | :show (: S) Afficher les variables, classes ou importations |
9 | :inspect (: n) Inspectez une variable ou le dernier résultat avec le navigateur d'objets GUI |
dix | :purge (: p) Purger les variables, classes, importations ou préférences |
11 | :edit (: e) Modifier le tampon actuel |
12 | :load (: l) Chargez un fichier ou une URL dans le tampon |
13 | . (:.) Alias vers:: load |
14 | .save (: s) Enregistrer le tampon actuel dans un fichier |
15 | .record (: r) Enregistrer la session en cours dans un fichier |
16 | :alias (: a) Créer un alias |
17 | :set (: =) Définir (ou lister) les préférences |
18 | :register (: rc) Enregistre une nouvelle commande avec le shell |
19 | :doc (: D) Ouvre une fenêtre de navigateur affichant le document de l'argument |
20 | :history (: H) Afficher, gérer et rappeler l'historique des lignes d'édition |
L'unité fondamentale d'un système orienté objet est la classe. Par conséquent, les tests unitaires consistent en des tests au sein d'une classe. L'approche adoptée consiste à créer un objet de la classe en cours de test et à l'utiliser pour vérifier que les méthodes sélectionnées s'exécutent comme prévu. Toutes les méthodes ne peuvent pas être testées, car il n'est pas toujours pratique de tester chaque chose. Mais des tests unitaires doivent être effectués pour les méthodes clés et critiques.
JUnit est un framework de test open source qui est la norme industrielle acceptée pour les tests unitaires automatisés du code Java. Heureusement, le framework JUnit peut être facilement utilisé pour tester les classes Groovy. Tout ce qui est nécessaire est d'étendre la classe GroovyTestCase qui fait partie de l'environnement Groovy standard. La classe de cas de test Groovy est basée sur le cas de test Junit.
Ecrire un scénario de test Junit simple
Supposons que nous ayons la classe suivante définie dans un fichier de classe d'application -
class Example {
static void main(String[] args) {
Student mst = new Student();
mst.name = "Joe";
mst.ID = 1;
println(mst.Display())
}
}
public class Student {
String name;
int ID;
String Display() {
return name +ID;
}
}
La sortie du programme ci-dessus est donnée ci-dessous.
Joe1
Et maintenant supposons que nous voulions écrire un cas de test pour la classe Student. Un cas de test typique ressemblerait à celui ci-dessous. Les points suivants doivent être notés à propos du code suivant -
- La classe de cas de test étend la classe GroovyTestCase
- Nous utilisons l'instruction assert pour nous assurer que la méthode Display renvoie la bonne chaîne.
class StudentTest extends GroovyTestCase {
void testDisplay() {
def stud = new Student(name : 'Joe', ID : '1')
def expected = 'Joe1'
assertToString(stud.Display(), expected)
}
}
La suite de tests Groovy
Normalement, à mesure que le nombre de tests unitaires augmente, il deviendrait difficile de continuer à exécuter tous les cas de test un par un. Par conséquent, Groovy fournit une fonction pour créer une suite de tests qui peut encapsuler tous les cas de test dans une seule unité logicielle. Le code suivant montre comment cela peut être réalisé. Les choses suivantes doivent être notées à propos du code -
GroovyTestSuite est utilisé pour encapsuler tous les cas de test en un seul.
Dans l'exemple suivant, nous supposons que nous avons deux fichiers de cas de tests, l'un appelé StudentTest et l'autre est EmployeeTest qui contient tous les tests nécessaires.
import groovy.util.GroovyTestSuite
import junit.framework.Test
import junit.textui.TestRunner
class AllTests {
static Test suite() {
def allTests = new GroovyTestSuite()
allTests.addTestSuite(StudentTest.class)
allTests.addTestSuite(EmployeeTest.class)
return allTests
}
}
TestRunner.run(AllTests.suite())
Le moteur de template de Groovy fonctionne comme un publipostage (l'ajout automatique de noms et d'adresses d'une base de données aux lettres et enveloppes afin de faciliter l'envoi de courrier, notamment publicitaire, à de nombreuses adresses) mais il est beaucoup plus général.
Modèles simples dans les chaînes
Si vous prenez l'exemple simple ci-dessous, nous définissons d'abord une variable de nom contenant la chaîne «Groovy». Dans l'instruction println, nous utilisons $ symbol pour définir un paramètre ou un modèle dans lequel une valeur peut être insérée.
def name = "Groovy"
println "This Tutorial is about ${name}"
Si le code ci-dessus est exécuté dans groovy, la sortie suivante sera affichée. La sortie montre clairement que le $ name a été remplacé par la valeur qui a été assignée par l'instruction def.
Moteur de modèle simple
Voici un exemple de SimpleTemplateEngine qui vous permet d'utiliser des scriptlets et des expressions EL de type JSP dans votre modèle afin de générer du texte paramétré. Le moteur de création de modèles vous permet de lier une liste de paramètres et leurs valeurs afin qu'ils puissent être remplacés dans la chaîne contenant les espaces réservés définis.
def text ='This Tutorial focuses on $TutorialName. In this tutorial you will learn
about $Topic'
def binding = ["TutorialName":"Groovy", "Topic":"Templates"]
def engine = new groovy.text.SimpleTemplateEngine()
def template = engine.createTemplate(text).make(binding)
println template
Si le code ci-dessus est exécuté dans groovy, la sortie suivante sera affichée.
Utilisons maintenant la fonctionnalité de création de modèles pour un fichier XML. Dans un premier temps, ajoutons le code suivant à un fichier appelé Student.template. Dans le fichier suivant, vous remarquerez que nous n'avons pas ajouté les valeurs réelles des éléments, mais des espaces réservés. Donc $ name,$is and $subject sont tous placés comme espaces réservés qui devront être remplacés lors de l'exécution.
<Student>
<name>${name}</name> <ID>${id}</ID>
<subject>${subject}</subject>
</Student>
Ajoutons maintenant notre code de script Groovy pour ajouter la fonctionnalité qui peut être utilisée pour remplacer le modèle ci-dessus par des valeurs réelles. Les choses suivantes doivent être notées à propos du code suivant.
Le mappage des espaces réservés aux valeurs réelles est effectué via une liaison et un SimpleTemplateEngine. La liaison est une carte avec les espaces réservés comme clés et les remplacements comme valeurs.
import groovy.text.*
import java.io.*
def file = new File("D:/Student.template")
def binding = ['name' : 'Joe', 'id' : 1, 'subject' : 'Physics']
def engine = new SimpleTemplateEngine()
def template = engine.createTemplate(file)
def writable = template.make(binding)
println writable
Si le code ci-dessus est exécuté dans groovy, la sortie suivante sera affichée. À partir de la sortie, on peut voir que les valeurs sont remplacées avec succès dans les espaces réservés appropriés.
<Student>
<name>Joe</name>
<ID>1</ID>
<subject>Physics</subject>
</Student>
StreamingTemplateEngine
Le moteur StreamingTemplateEngine est un autre moteur de création de modèles disponible dans Groovy. C'est un peu équivalent à SimpleTemplateEngine, mais crée le modèle à l'aide de fermetures inscriptibles, ce qui le rend plus évolutif pour les grands modèles. Plus précisément, ce moteur de modèle peut gérer des chaînes de plus de 64 Ko.
Voici un exemple d'utilisation de StreamingTemplateEngine -
def text = '''This Tutorial is <% out.print TutorialName %> The Topic name
is ${TopicName}'''
def template = new groovy.text.StreamingTemplateEngine().createTemplate(text)
def binding = [TutorialName : "Groovy", TopicName : "Templates",]
String response = template.make(binding)
println(response)
Si le code ci-dessus est exécuté dans groovy, la sortie suivante sera affichée.
This Tutorial is Groovy The Topic name is Templates
XMLTemplateEngine
Le XmlTemplateEngine est utilisé dans les scénarios de création de modèles où la source du modèle et la sortie attendue sont destinées à être XML. Les modèles utilisent la normale${expression} and $des notations de variables pour insérer une expression arbitraire dans le modèle.
Voici un exemple d'utilisation de XMLTemplateEngine.
def binding = [StudentName: 'Joe', id: 1, subject: 'Physics']
def engine = new groovy.text.XmlTemplateEngine()
def text = '''\
<document xmlns:gsp='http://groovy.codehaus.org/2005/gsp'>
<Student>
<name>${StudentName}</name> <ID>${id}</ID>
<subject>${subject}</subject>
</Student>
</document>
'''
def template = engine.createTemplate(text).make(binding)
println template.toString()
Si le code ci-dessus est exécuté dans groovy, la sortie suivante sera affichée
Joe
1
Physics
La programmation de méta-objets ou MOP peut être utilisée pour appeler des méthodes de manière dynamique et également créer des classes et des méthodes à la volée.
Qu'est-ce que cela signifie? Considérons une classe appelée Student, qui est une sorte de classe vide sans variables ni méthodes membres. Supposons que vous deviez invoquer les instructions suivantes sur cette classe.
Def myStudent = new Student()
myStudent.Name = ”Joe”;
myStudent.Display()
Maintenant, dans la programmation de méta-objets, même si la classe n'a pas la variable membre Name ou la méthode Display (), le code ci-dessus fonctionnera toujours.
Comment cela peut-il fonctionner? Eh bien, pour que cela fonctionne, il faut implémenter l'interface GroovyInterceptable pour se connecter au processus d'exécution de Groovy. Voici les méthodes disponibles pour cette interface.
Public interface GroovyInterceptable {
Public object invokeMethod(String methodName, Object args)
Public object getproperty(String propertyName)
Public object setProperty(String propertyName, Object newValue)
Public MetaClass getMetaClass()
Public void setMetaClass(MetaClass metaClass)
}
Donc, dans la description de l'interface ci-dessus, supposons que si vous deviez implémenter invokeMethod (), elle serait appelée pour chaque méthode qui existe ou qui n'existe pas.
Propriétés manquantes
Regardons donc un exemple de la façon dont nous pouvons implémenter la programmation de méta-objets pour les propriétés manquantes. Les éléments clés suivants doivent être notés à propos du code suivant.
La classe Student n'a pas de variable membre appelée Nom ou ID défini.
La classe Student implémente l'interface GroovyInterceptable.
Il existe un paramètre appelé dynamicProps qui sera utilisé pour contenir la valeur des variables membres qui sont créées à la volée.
Les méthodes getproperty et setproperty ont été implémentées pour obtenir et définir les valeurs des propriétés de la classe au moment de l'exécution.
class Example {
static void main(String[] args) {
Student mst = new Student();
mst.Name = "Joe";
mst.ID = 1;
println(mst.Name);
println(mst.ID);
}
}
class Student implements GroovyInterceptable {
protected dynamicProps=[:]
void setProperty(String pName,val) {
dynamicProps[pName] = val
}
def getProperty(String pName) {
dynamicProps[pName]
}
}
La sortie du code suivant serait -
Joe
1
Méthodes manquantes
Regardons donc un exemple de la façon dont nous pouvons implémenter la programmation de méta-objets pour les propriétés manquantes. Les éléments clés suivants doivent être notés à propos du code suivant -
La classe Student implémente maintenant la méthode invokeMethod qui est appelée indépendamment du fait que la méthode existe ou non.
class Example {
static void main(String[] args) {
Student mst = new Student();
mst.Name = "Joe";
mst.ID = 1;
println(mst.Name);
println(mst.ID);
mst.AddMarks();
}
}
class Student implements GroovyInterceptable {
protected dynamicProps = [:]
void setProperty(String pName, val) {
dynamicProps[pName] = val
}
def getProperty(String pName) {
dynamicProps[pName]
}
def invokeMethod(String name, Object args) {
return "called invokeMethod $name $args"
}
}
La sortie du code suivant doit être affichée ci-dessous. Notez qu'il n'y a pas d'erreur d'exception de méthode manquante même si la méthode Display n'existe pas.
Joe
1
Métaclasse
Cette fonctionnalité est liée à l'implémentation MetaClass. Dans l'implémentation par défaut, vous pouvez accéder aux champs sans appeler leurs getters et setters. L'exemple suivant montre comment, en utilisant la fonction metaClass, nous pouvons modifier la valeur des variables privées de la classe.
class Example {
static void main(String[] args) {
Student mst = new Student();
println mst.getName()
mst.metaClass.setAttribute(mst, 'name', 'Mark')
println mst.getName()
}
}
class Student {
private String name = "Joe";
public String getName() {
return this.name;
}
}
La sortie du code suivant serait -
Joe
Mark
Méthode manquante
Groovy prend en charge le concept de methodMissing. Cette méthode diffère de invokeMethod en ce qu'elle n'est appelée qu'en cas d'échec de l'envoi d'une méthode, lorsqu'aucune méthode ne peut être trouvée pour le nom et / ou les arguments donnés. L'exemple suivant montre comment la méthode methodMissing peut être utilisée.
class Example {
static void main(String[] args) {
Student mst = new Student();
mst.Name = "Joe";
mst.ID = 1;
println(mst.Name);
println(mst.ID);
mst.AddMarks();
}
}
class Student implements GroovyInterceptable {
protected dynamicProps = [:]
void setProperty(String pName, val) {
dynamicProps[pName] = val
}
def getProperty(String pName) {
dynamicProps[pName]
}
def methodMissing(String name, def args) {
println "Missing method"
}
}
La sortie du code suivant serait -
Joe
1
Missing method