AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi W1048 Unsichere Typumwandlung obwohl völlig ok
Thema durchsuchen
Ansicht
Themen-Optionen

W1048 Unsichere Typumwandlung obwohl völlig ok

Ein Thema von Der schöne Günther · begonnen am 17. Jan 2018 · letzter Beitrag vom 17. Jan 2018
Antwort Antwort
Der schöne Günther

Registriert seit: 6. Mär 2013
6.212 Beiträge
 
Delphi 10 Seattle Enterprise
 
#1

AW: W1048 Unsichere Typumwandlung obwohl völlig ok

  Alt 17. Jan 2018, 12:09
Die Vereinfachung bezog sich nur auf den geposteten Code. Ich bekomme es mit EXAKT den gleichen Units nicht in einem leeren Projekt reproduziert. Oder habe ich das jetzt falsch verstanden?

Edit:
Die Ursache lag in der Unit welche sich eine Instanz von TMyObject erstellt hat. Sie hatte uses [...], Spring und ebendiese Unit redeklariert in ihrem Interface-Teil (weshalb auch immer) TTimeSpan = TimeSpan.TTimeSpan; .
Wenn ich dort nun ein reines "TTimeSpan" benutze, dann ist es ein Spring.TTimeSpan und kein System.TimeSpan.TTimeSpan, obwohl es eigentlich nur ein Alias ist.

Warum der Compiler nun den Konstruktor anstreicht und nicht die Zeile wo ein Spring.TTimeSpan einer System.TimeSpan.TTimeSpan-Property zugewiesen weiß ich allerdings auch nicht.

Immerhin bin ich die Warnung los.

Geändert von Der schöne Günther (17. Jan 2018 um 12:19 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.757 Beiträge
 
Delphi 12 Athens
 
#2

AW: W1048 Unsichere Typumwandlung obwohl völlig ok

  Alt 17. Jan 2018, 12:17
Ich bekomme es mit EXAKT den gleichen Units nicht in einem leeren Projekt reproduziert.
Dann überprüf mal, ob eventuell bei den Suchpfaden irgendetwas zu finden ist, bei dem TTimeSpan neu deklariert wurde.

Also z.B. im interface-Teil wird TTimeSpan aus System.TimeSpan verwendet und im implementation-Teil hängt sowas wie dies dazwischen:

Delphi-Quellcode:
uses
  System.TimeSpan;

type
  TTimeSpan = type System.TimeSpan.TTimeSpan;
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.212 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

AW: W1048 Unsichere Typumwandlung obwohl völlig ok

  Alt 17. Jan 2018, 12:19
Siehe mein Edit darüber: Du liegst (wie immer) absolut richtig

Ich würde es einsehen wenn, wie in deinem Beispiel, ein neuer Typ deklariert wird. Hier ist es eigentlich nur ein Alias. Komisch.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.557 Beiträge
 
Delphi 12 Athens
 
#4

AW: W1048 Unsichere Typumwandlung obwohl völlig ok

  Alt 17. Jan 2018, 12:43
Arbeitest du mit Laufzeitpackages?

Der Typ in im nachfolgenden Package ist nur eine Variable, die beim Laden der BPL die Referenz des aktuellen Typ im ersten Package bekommt.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.212 Beiträge
 
Delphi 10 Seattle Enterprise
 
#5

AW: W1048 Unsichere Typumwandlung obwohl völlig ok

  Alt 17. Jan 2018, 12:52
Arbeitest du mit Laufzeitpackages?
Nein, nie.

Vielleicht aber liegt es daran dass er von Spring natürlich nicht jedes mal neu kompiliert sondern fertige DCUs nimmt?
  Mit Zitat antworten Zitat
Benutzerbild von Sherlock
Sherlock

Registriert seit: 10. Jan 2006
Ort: Offenbach
3.821 Beiträge
 
Delphi 12 Athens
 
#6

AW: W1048 Unsichere Typumwandlung obwohl völlig ok

  Alt 17. Jan 2018, 13:46
Delphi-Quellcode:
uses
  System.TimeSpan;

type
  TTimeSpan = type System.TimeSpan.TTimeSpan;
Man darf sich aber schon wundern, wozu das gut ist, oder?

Sherlock
Oliver
Geändert von Sherlock (Morgen um 16:78 Uhr) Grund: Weil ich es kann
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.557 Beiträge
 
Delphi 12 Athens
 
#7

AW: W1048 Unsichere Typumwandlung obwohl völlig ok

  Alt 17. Jan 2018, 13:50
PS: Das von Uwe war nur ein Beispiel, was wohl im Delphi nicht wirklich so aussieht.


Ein Typ gleichen Aufbaus, der aber nicht mit dem Anderen "kompatibel" ist?
z.B. für Typen, welche eine andere Art von Daten enthalten, aber wo man sich sparen möchte es neu zu definieren.

Delphi-Quellcode:
type
  TMyType = type Integer;

procedure Test(X: Integer); overload;
procedure Test(W: TMyType); overload;
Bei TMyType = Integer; wüsste der Compiler garnicht welche Funktion er nehmen soll.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Benutzerbild von Sherlock
Sherlock

Registriert seit: 10. Jan 2006
Ort: Offenbach
3.821 Beiträge
 
Delphi 12 Athens
 
#8

AW: W1048 Unsichere Typumwandlung obwohl völlig ok

  Alt 17. Jan 2018, 14:29
Das ist mir klar, und wenn man einen Bezeichner für den "neuen" Typen verwendet, der nicht für Unmut sorgt zB TSherlockTimeSpan = type System.TimeSpan.TTimeSpan; , ist auch alles Bestens. Aber Spring scheint das ja nicht getan zu haben, darum meine Frage: "Wozu?".

Sherlock
Oliver
Geändert von Sherlock (Morgen um 16:78 Uhr) Grund: Weil ich es kann
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.757 Beiträge
 
Delphi 12 Athens
 
#9

AW: W1048 Unsichere Typumwandlung obwohl völlig ok

  Alt 17. Jan 2018, 14:53
Solche Typ-Aliase werden gerne verwendet, damit das Aufnehmen der Original-Unit in das uses nicht mehr notwendig ist. Ein Beispiel aus der VCL findet sich in VCL.Graphics

  TColor = System.UITypes.TColor; Bei der Migration eines alten Projekts müssten andernfalls die meisten Uses-Anweisungen (zumindest in den Units, wo TColor verwendet wird) um System.UITypes ergänzt werden. Durch den Alias kann man das vermeiden. Das ist insbesondere für Bibliotheken interessant, die auf mehrere Delphi-Versionen zielen.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.557 Beiträge
 
Delphi 12 Athens
 
#10

AW: W1048 Unsichere Typumwandlung obwohl völlig ok

  Alt 17. Jan 2018, 15:00
Oder siehe Hier im Forum suchenTntUnicodeHack, wo nur die gehackte Unit ins Uses rein muß und man sich die oritinalen sparen kann.
Bzw. in Bestandsprojekten muß per Suchen&Ersetzen nur das "Hack" an die Units angehängt werden, um von TNT auf TNTHack zustellen.
Das Unveränderte wird wort von via Alias über die TNTHack zum TNT durchgereicht.
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (17. Jan 2018 um 15:04 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:17 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz