Heim > Java > javaLernprogramm > Wie behebe ich Kompilierungsfehler bei der gemeinsamen Verwendung von MapStruct und Lombok in Java?

Wie behebe ich Kompilierungsfehler bei der gemeinsamen Verwendung von MapStruct und Lombok in Java?

Linda Hamilton
Freigeben: 2024-12-06 21:06:16
Original
941 Leute haben es durchsucht

How to Resolve Compilation Errors When Using MapStruct and Lombok Together in Java?

MapStruct und Lombok sind zwei beliebte Java-Bibliotheken, die zur Verbesserung der Produktivität und Wartbarkeit von Java-Code verwendet werden können. Wenn sie jedoch zusammen verwendet werden, kann es aufgrund von Konflikten bei der Annotationsverarbeitung manchmal zu Kompilierungsfehlern kommen. Dieser Artikel bietet eine Lösung für dieses Problem und erklärt, wie Sie MapStruct und Lombok richtig konfigurieren, damit sie nahtlos zusammenarbeiten.

Das Problem

Wenn MapStruct und Lombok zusammen verwendet werden , kann der Kompilierungsprozess mit einer Fehlermeldung ähnlich der folgenden fehlschlagen:

Unknown property "id" in result type com.vg.once.dto.OneDto. Did you mean "null"?
Nach dem Login kopieren

Dieser Fehler tritt auf, weil MapStruct erwartet, Getter zu finden und Setter für die Eigenschaften der DTO-Klasse, aber Lombok generiert stattdessen synthetische Accessoren und Mutatoren. Daher ist MapStruct nicht in der Lage, die Eigenschaften der Entitätsklasse den entsprechenden Eigenschaften in der DTO-Klasse zuzuordnen.

Die Lösung

Um dieses Problem zu beheben, müssen Sie Sie müssen MapStruct anweisen, die synthetischen Accessoren und Mutatoren von Lombok zu verwenden. Dies kann durch Hinzufügen der folgenden Annotation zur Mapper-Schnittstelle erfolgen:

@Mapper(config = LombokProcessorConfig.class)
Nach dem Login kopieren

Die LombokProcessorConfig-Klasse ist eine integrierte MapStruct-Konfigurationsklasse, die MapStruct anweist, die synthetischen Accessoren und Mutatoren von Lombok zu verwenden.

Beispiel

Hier ist ein Beispiel einer Mapper-Schnittstelle, die verwendet die synthetischen Accessoren und Mutatoren von Lombok:

@Mapper(config = LombokProcessorConfig.class)
public interface OneMapper {

    @Mapping(target="id", source="one.id")
    OneDto createOne (One one);

}
Nach dem Login kopieren

Zusätzliche Überlegungen

Zusätzlich zum Hinzufügen der LombokProcessorConfig-Annotation gibt es noch ein paar andere Dinge, die Sie bei der Verwendung berücksichtigen müssen MapStruct und Lombok zusammen:

  • Stellen Sie sicher, dass Sie kompatible Versionen von verwenden MapStruct und Lombok. Die neuesten Versionen von MapStruct und Lombok werden immer empfohlen.
  • Stellen Sie sicher, dass das Annotation-Verarbeitungs-Plugin für Lombok in Ihrer IDE aktiviert ist.
  • Wenn Sie Maven verwenden, müssen Sie möglicherweise das hinzufügen Fügen Sie die LombokProcessorConfig-Klasse Ihrem Klassenpfad hinzu. Dies kann erreicht werden, indem Sie die folgende Abhängigkeit zu Ihrer pom.xml-Datei hinzufügen:
<dependency>
    <groupId>org.mapstruct</groupId>
    <artifactId>mapstruct-processor</artifactId>
    <version>${mapstruct.version}</version>
    <classifier>ap</classifier>
</dependency>
Nach dem Login kopieren

Fazit

Indem Sie diese Schritte befolgen, können Sie MapStruct verwenden und Lombok zusammen, um die Produktivität und Wartbarkeit Ihres Java-Codes zu verbessern.

Das obige ist der detaillierte Inhalt vonWie behebe ich Kompilierungsfehler bei der gemeinsamen Verwendung von MapStruct und Lombok in Java?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage