Articles

Approche fonctionnelle de la manipulation de chaînes en Java

La manipulation de chaînes en Java peut être abordée de manière fonctionnelle grâce aux nombreuses fonctionnalités offertes par le langage. Découvrons ensemble cette approche !

Les dernières mises à jour de Java ont vu la classe String subir une série d’ajouts méthodologiques significatifs. Certaines méthodes donnent maintenant des instances de la classe Stream, tandis que certaines sont des fonctions d’ordre supérieur. L’intention derrière l’incorporation de ces méthodes est d’offrir une approche simplifiée pour gérer les chaînes de caractères d’une manière orientée flux. 

La gestion des chaînes de caractères d’une manière orientée flux présente l’avantage de simplifier le code et d’améliorer l’expressivité. Cela rend plus facile l’application d’opérations telles que le filtrage, le mappage, la réduction et plus encore.

Testing is an important part of the development process, and it is essential to ensure that the code is functioning as expected. With the new methods, testing strings has become more efficient and straightforward. Developers no longer need to write complex code to test strings, as the new methods can be used to perform the same operations in a more concise manner. 

Dans les dernières mises à jour de Java, la classe String a subi une série d’ajouts de méthodes significatives. Certaines méthodes donnent maintenant des instances de la classe Stream, tandis que certaines sont des fonctions à haut niveau. L’intention derrière l’incorporation de ces méthodes est d’offrir une approche simplifiée pour manipuler les chaînes de caractères d’une manière orientée flux. 

La gestion des chaînes de caractères d’une manière orientée flux présente l’avantage de simplifier le code et d’améliorer l’expressivité. Cela permet d’appliquer plus facilement des opérations telles que le filtrage, le mappage, la réduction et bien plus encore.

Le test est une partie importante du processus de développement et il est essentiel de s’assurer que le code fonctionne comme prévu. Avec les nouvelles méthodes, le test des chaînes de caractères est devenu plus efficace et plus simple. Les développeurs n’ont plus besoin d’écrire du code complexe pour tester les chaînes de caractères, car les nouvelles méthodes peuvent être utilisées pour effectuer les mêmes opérations de manière plus concise. 

Source de l’article sur DZONE

Explorer les nouvelles fonctionnalités de Java 17 avec exemples

Découvrez les nouvelles fonctionnalités de Java 17 et explorez leurs possibilités avec des exemples concrets !

Java, l’un des langages de programmation les plus populaires, continue d’évoluer et de s’améliorer à chaque nouvelle version. Java 17, la dernière version à support à long terme (LTS), apporte plusieurs fonctionnalités et améliorations intéressantes au langage. Dans cet article, nous explorerons certaines des nouvelles fonctionnalités notables de Java 17 et fournirons des exemples pratiques pour vous aider à comprendre comment les utiliser efficacement.

Java 17, l’une des langues de programmation les plus populaires, continue d’évoluer et de s’améliorer à chaque nouvelle version. La dernière version à long terme (LTS) apporte plusieurs fonctionnalités et améliorations intéressantes à la langue. Dans cet article, nous allons explorer certaines des nouvelles fonctionnalités remarquables de Java 17 et fournir des exemples pratiques pour vous aider à comprendre comment les utiliser efficacement.

Classes scellées

Les classes scellées vous permettent de restreindre les classes ou interfaces qui peuvent les étendre ou les implémenter. Cette fonctionnalité améliore l’encapsulation et aide à maintenir l’intégrité du code en contrôlant qui peut hériter d’une classe scellée. Voyons un exemple :

public sealed class Animal permits Cat, Dog {

// …

}

public class Cat extends Animal {

// …

}

public class Dog extends Animal {

// …

}

Dans cet exemple, nous déclarons une classe scellée Animal qui autorise uniquement les classes Cat et Dog à étendre. Si une autre classe tente d’étendre Animal, elle générera une erreur de compilation. Les classes scellées sont très utiles pour contrôler l’héritage et améliorer la sécurité et la robustesse du code.

Pattern Matching pour le type instanceof

Le pattern matching pour le type instanceof est une autre nouvelle fonctionnalité intéressante de Java 17. Il permet aux développeurs de vérifier le type d’un objet et d’extraire des valeurs à partir de celui-ci en une seule instruction. Voyons un exemple :

if (obj instanceof String s) {

System.out.println(s.length());

}

Dans cet exemple, nous vérifions si l’objet obj est une instance de String. Si c’est le cas, la variable s est initialisée avec la valeur de obj. Nous pouvons ensuite utiliser la variable s pour accéder aux méthodes et propriétés de la chaîne. Le pattern matching pour le type instanceof est très pratique et peut être utilisé pour simplifier le code.

Conclusion

Java 17 apporte plusieurs nouvelles fonctionnalités intéressantes et utiles aux développeurs Java. Les classes scellées permettent de contrôler l’héritage et le pattern matching pour le type instanceof permet de vérifier le type d’un objet et d’extraire des valeurs à partir de celui-ci en une seule instruction. Ces fonctionnalités peuvent être utilisées pour améliorer la sécurité et la robustesse du code et simplifier le processus de codage.

Source de l’article sur DZONE

Utiliser les fonctionnalités de prévisualisation JDK21 et/ou les classes incubatrices

Découvrez comment tirer le meilleur parti des fonctionnalités de prévisualisation JDK21 et des classes incubatrices pour améliorer votre code Java.

Comment configurer votre build Maven pour prendre en charge une leçon de jeu avec les nouvelles fonctionnalités de JDK21 (ou même plus récentes) comme les fonctionnalités d’aperçu et peut-être certaines classes de l’incubateur ? C’est plus facile que vous ne le pensez. Commençons la configuration. Je suppose que vous souhaitez jouer avec les fonctionnalités d’aperçu de JDK21, par exemple les modèles de chaînes (JEP430). Je viens de sélectionner ce JEP pour la démonstration. Vous pouvez sélectionner n’importe quel JEP en aperçu. La première chose à savoir est que vous devez activer les fonctionnalités d’aperçu via :

Parfois, vous souhaitez jouer avec les nouvelles fonctionnalités de JDK21 (ou même des JDK plus récents) comme les fonctionnalités de prévisualisation et peut-être certaines classes de l’incubateur. Alors, comment pouvez-vous configurer votre build Maven pour prendre en charge une telle leçon de jeu? C’est plus facile que vous ne le pensez. Commençons la configuration. Mon hypothèse est que vous souhaiteriez jouer avec les fonctionnalités de prévisualisation de JDK21, par exemple les modèles de chaîne (JEP430). Je n’ai sélectionné ce JEP que pour la démonstration. Vous pouvez sélectionner n’importe quel JEP en prévisualisation. La première chose à savoir est que vous devez activer les fonctionnalités de prévisualisation via:

XML

org.apache.maven.plugins

maven-compiler-plugin

true

Une fois cette étape terminée, vous pouvez ajouter des dépendances supplémentaires à votre projet pour prendre en charge les fonctionnalités de prévisualisation. Pour le JEP430, vous devez ajouter la dépendance suivante:

XML

org.openjdk.jmh

jmh-core

1.21.0-SNAPSHOT

test

Une fois cette étape terminée, vous pouvez commencer à utiliser les fonctionnalités de prévisualisation dans votre projet. Vous pouvez également utiliser des outils tels que JMH pour mesurer les performances des fonctionnalités de prévisualisation et comparer leurs performances avec les versions stables. Vous pouvez également utiliser des outils tels que JUnit pour tester le comportement des fonctionnalités de prévisualisation et vous assurer qu’elles fonctionnent comme prévu. Enfin, vous pouvez utiliser des outils tels que SonarQube pour surveiller la qualité du code et vous assurer que les fonctionnalités de prévisualisation ne compromettent pas la qualité du code.

Une fois que vous avez configuré votre projet pour prendre en charge les fonctionnalités de prévisualisation, vous pouvez commencer à explorer les données et à tirer parti des nouvelles fonctionnalités. Vous pouvez par exemple analyser les données pour voir comment les nouvelles fonctionnalités affectent les performances ou la qualité du code. Vous pouvez également utiliser des outils tels que Spark ou Hadoop pour traiter et analyser des jeux de données volumineux et tirer des conclusions sur les performances et la qualité des fonctionnalités de prévisualisation. Vous pouvez même créer des modèles d’apprentissage automatique pour prédire le comportement des n

Source de l’article sur DZONE

Conversion chaîne en énumération - CVE-2020-36620 (50 Go)

Conversion chaîne en énumération – CVE-2020-36620 (50 Go): Découvrez comment convertir une chaîne en énumération avec 50 Go de données à l’aide de CVE-2020-36620.

## Discuter de la vulnérabilité CVE-2020-36620 et voir comment un package NuGet pour convertir une chaîne en énumération peut rendre une application C# vulnérable aux attaques DoS

En tant qu’informaticien enthousiaste, je vais discuter de la vulnérabilité CVE-2020-36620 et voir comment un package NuGet pour convertir une chaîne en énumération peut rendre une application C # vulnérable aux attaques DoS.

Imaginons une application serveur qui interagit avec un utilisateur. Dans l’un des scénarios, l’application reçoit des données de l’utilisateur sous forme de chaîne et les convertit en éléments d’énumération (chaîne -> énumération).

Le package NuGet en question est conçu pour faciliter ce processus de conversion. Cependant, le package ne vérifie pas si la chaîne reçue est valide et peut donc être exploité par un attaquant pour provoquer un déni de service. Lorsqu’un attaquant envoie une chaîne qui n’est pas valide, le package tente de convertir la chaîne en énumération et cela peut entraîner une exception et un plantage de l’application.

Pour résoudre ce problème, nous devons vérifier que la chaîne reçue est valide avant de l’utiliser. Nous pouvons le faire en utilisant le code C # pour vérifier si la chaîne est comprise dans l’énumération. Si ce n’est pas le cas, nous pouvons alors retourner une erreur à l’utilisateur et éviter ainsi tout plantage de l’application.

En résumé, le package NuGet pour convertir une chaîne en énumération peut être exploité par un attaquant pour provoquer un déni de service. Pour éviter cela, nous devons vérifier que la chaîne reçue est valide avant de l’utiliser. Nous pouvons le faire en codant une fonction qui vérifie si la chaîne est comprise dans l’énumération et retourne une erreur à l’utilisateur si ce n’est pas le cas. En appliquant cette méthode, nous pouvons éviter les attaques DoS et assurer la sécurité de notre application.

Source de l’article sur DZONE

java.lang.String#intern() is an interesting function in Java. When used in the right place, it has the potential to reduce the overall memory consumption of your application by eliminating duplicate strings in your application. To learn how the intern() function works, you may refer to this blog. In this post let’s discuss the performance impact of using java.lang.String#intern() function in your application.

Intern() Function Demo

To study the performance behaviour of the intern() method, we created these two simple programs:

Source de l’article sur DZONE

Java for a lot of time has been accused and mocked for its verbosity. Even the most passionate Java developers have to admit that it felt ridiculous to declare a bean class with two attributes. If you follow the right recommendations, you end up adding not only getters and setters, but also the implementations of toString hashcode and equals methods. The final result is a chunk of boilerplate that invites you to start learning another language. 

Java

 

import java.util.Objects; public class Car { private String brand; private String model; private int year; public String getBrand() { return brand; } public void setBrand(String brand) { this.brand = brand; } public String getModel() { return model; } public void setModel(String model) { this.model = model; } public int getYear() { return year; } public void setYear(int year) { this.year = year; } @Override public String toString() { return "Car{" + "brand='" + brand + ''' + ", model='" + model + ''' + ", year=" + year + '}'; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Car car = (Car) o; return year == car.year && Objects.equals(brand, car.brand) && Objects.equals(model, car.model); } @Override public int hashCode() { return Objects.hash(brand, model, year); }
}

Source de l’article sur DZONE

Java

 

class Base<T> { T obj; Base(T obj) { this.obj = obj; } T getob() { return obj; } } class Sub extends Base<String> { Sub(String str) { super(str); } String getob() { return obj; } }

How many methods of the sub-class in the above code snippet will have after compilation, and why? Let’s make it a little bit simpler: How many methods the sub-class will have, excluding the methods inherited from java.lang.Object?

Source de l’article sur DZONE

Sometimes on Linux/UNIX computers, you will want to do a search for any files containing a particular string within it. This can be particularly useful when searching for specific things for a CI/CD pipeline.

On Linux or Mac, if we want to search a set of files for a specific string in a terminal, we use the grep.

Source de l’article sur DZONE

Mulesoft DataWeave is a simple powerful tool to transform data inside a flow. Numerous core operators and functions are already present to perform various operations such as capitalize, camelize, upper, and lower.

For string operations, there are no core functions present to resolve a wildcard. I hope the DataWeave(DWL 1.0) function below helps you to perform a requirement where you want to resolve a wildcard using a set of parameters.

Source de l’article sur DZONE

‘java.lang.System.getProperty()’ is a common API used by Java developers to read the System properties that are configured during application startup time. i.e. when you pass “-DappName=buggyApp” as your application’s startup JVM argument, the value of the ‘appName’ system property can be read by invoking the ‘java.lang.System.getProperty()’. Example:

Java

 

public static String getAppName() { String app = System.getProperty("appName");   return app;
}

Source de l’article sur DZONE