Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Win32/Win64 API (native code) (https://www.delphipraxis.net/17-win32-win64-api-native-code/)
-   -   Software verhält sich auf Betriebssystemen unterschiedlich (https://www.delphipraxis.net/195540-software-verhaelt-sich-auf-betriebssystemen-unterschiedlich.html)

günni0 8. Mär 2018 08:30

Software verhält sich auf Betriebssystemen unterschiedlich
 
Seit längerer Zeit fällt mir auf, dass meine Software sich auf unterschiedlichen Betriebssystemen immer anders verhält.
Am PC, Windows 7 Home 64 gibt es keine Probleme. PC, Windows 10 Pro 64 letztes Build was es hier in Deutschland gibt, keine Probleme.
4K-Laptop, Windows 10 Pro 64 plötzlich irgendwelche Probleme an Stellen im Code, wo eigentlich keine sein sollten. Exceptions gibt es aber nie.
Die Auflösung des Laptops kann ich ausschließen. Die DPI auch.
Ist das normal?

TiGü 8. Mär 2018 08:42

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Die Glaskugel sagt:
Vielleicht! :glaskugel:

Im Ernst:
Merkwürdiger Threadtitel! Du hast drei Systeme. Zwei verhalten sich normal, eins nicht.
Das Betriebssystem ist irrelevant, weil "es" auf einen Win10 Pro geht und auf den anderen nicht.

Was ist zu tun:
Uns genau erläutern was "irgendwelche Probleme" konkret bedeutet.
Danach können wir dir nämlich je nachdem die üblichen Tipps wie Process Monitor, FPU-Exception-Mask, Virenscanner/Firewall-Einstellungen usw. hinwerfen.

hoika 8. Mär 2018 08:45

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Hallo,
welche Delphi-Version, welche Fremdkomponenten benutzt Dein Programm?

Zitat:

irgendwelche Probleme an Stellen im Code
Das ist nicht gerade eine genaue Fehlerbeschreibung. Dann zeig doch mal ein paar Stellen.

Zitat:

Die Auflösung des Laptops kann ich ausschließen. Die DPI auch.
Wie kommst Du denn darauf? Delphi-Programm haben prinzipiell Probleme mit Large Fonts (DPI)
und krummen Auflösungen), bzw. können Probleme haben.

Mit jeder Windows-Version gibt es neue Sachen, z.B. DEP (Data Execution Prevention).
Damit findet Windows plötzlich Fehler in deinem Programm, die vorher scheinbar nicht da waren.
Ich hatte einmal das Problem, dass ein installierter Teamviewer (als Dienst gestartet) Probleme bereitet hat,
aber nur beim Beenden eines bestimmten Formulars (mit einer Fremdkomponente drauf ...).

günni0 8. Mär 2018 09:02

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Dass die Auflösung oder DPI dran schuld ist kann ich ausschließen, weil ich schon sämtliche Standard-Auflösungen und -Seitenverhältnisse sowie DPI getestet habe.

Die Windows DEP habe ich für einen Test für alle Programme und Dienste eingestellt.
Funktioniert ohne Probleme auf allen Computern außer auf diesem Laptop mit 4K Bildschirm aber normalerweise 1920er-Auflösung und 16:9 Seitenverhältnis.

sakura 8. Mär 2018 09:51

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Zitat:

Zitat von günni0 (Beitrag 1395544)
Funktioniert ohne Probleme auf allen Computern außer auf diesem Laptop mit 4K Bildschirm aber normalerweise 1920er-Auflösung und 16:9 Seitenverhältnis.

Wie schon gesagt wurde, was ist denn das Problem, was ist anders auf dem einem System...? Alles andere ist nur sinnloses Raten.

...:cat:...

hoika 8. Mär 2018 11:05

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Hallo,
Zitat:

Seit längerer Zeit fällt mir auf, dass meine Software sich auf unterschiedlichen Betriebssystemen immer anders verhält.
Wir haben hier einen älteren Laptop, da sieht der Ausdruck (Barcode) etwas komisch aus (Schlieren).
Auf einem anderen Rechner klappt alles wunderbar.

Aber ohne zu wissen, was Deine Software für Probleme hat -> *Glaskugel nehm*

günni0 9. Mär 2018 14:54

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Ich komme der Problemstelle näher.
Könnte es sein, dass eine der beiden folgenden Zeilen bei manchen Windows 10-Installationen Probleme verursacht?

Delphi-Quellcode:
DateTimePicker1.Time := StrToTime('12:00:00');
DateTimePicker2.DateTime := Now + 1;
Schon vor diesem Fehler beim Programmstart rufe ich eine Prozedur auf die das hier ausführt
Delphi-Quellcode:
 FormatSettings.TimeSeparator := System.SysUtils.TimeSeparator;
 FormatSettings.DateSeparator := System.SysUtils.DateSeparator;

Lemmy 9. Mär 2018 15:11

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Zitat:

Zitat von günni0 (Beitrag 1395663)
Ich komme der Problemstelle näher.

nochmal: WAS IST DAS PROBLEM? und wie äußert sich das?

Wenn das Problem darin besteht, dass auf dem einen Windows die Darstellung im DateTimePicker "unterirdisch" ist, d.h. nur ein, zwei Zeichen des Timestamps sichtbar sind, dann liegt das am Updatestand von Windows

günni0 9. Mär 2018 15:12

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Die Prozedur wird an dieser Stelle einfach ohne Fehlermeldung unterbrochen.

Lemmy 9. Mär 2018 15:19

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Zitat:

Zitat von günni0 (Beitrag 1395665)
Die Prozedur wird an dieser Stelle einfach ohne Fehlermeldung unterbrochen.

d.h. weder DateTimepicker1 noch DateTimepicker2 ändern den Inhalt?

Welche Delphi-Version hast Du zur Verfügung? Was halbwegs aktuelles? Steht der PRoblemPC zufällig bei Dir im LAN? Dann könntest Du über RemoteDebugging das Problem vermutlich deutlich schneller finden...

TiGü 9. Mär 2018 15:21

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Zitat:

Zitat von günni0 (Beitrag 1395663)
Ich komme der Problemstelle näher.
Könnte es sein, dass eine der beiden folgenden Zeilen bei manchen Windows 10-Installationen Probleme verursacht?

Delphi-Quellcode:
DateTimePicker1.Time := StrToTime('12:00:00');
DateTimePicker2.DateTime := Now + 1;
Schon vor diesem Fehler beim Programmstart rufe ich eine Prozedur auf die das hier ausführt
Delphi-Quellcode:
 FormatSettings.TimeSeparator := System.SysUtils.TimeSeparator;
 FormatSettings.DateSeparator := System.SysUtils.DateSeparator;

Lass mich raten: Das eine Windows 10, wo es funktioniert, hat deutsche Spracheinstellungen und das andere Windows 10, bei dem es nicht funktioniert, hat eine andere Sprache, bspw. Englisch?

Delphi.Narium 9. Mär 2018 15:21

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Und was steht im System.SysUtils.TimeSeparator?
Der : oder eine andere Systemeinstellung?

Die Windowskonfiguration bezüglich der Datums- und Zeiteinstellungen eventuell mal überprüfen?

günni0 9. Mär 2018 15:30

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Zitat:

Lass mich raten: Das eine Windows 10, wo es funktioniert, hat deutsche Spracheinstellungen und das andere Windows 10, bei dem es nicht funktioniert, hat eine andere Sprache, bspw. Englisch?
Richtig. Der Problem-PC steht irgendwo auf der Welt wo ich keinen Zugriff habe. Wenn ich mich nicht irre irgendwo in Indien.

Ich nutze Delphi für Windows Version 10.2 (kostenlos).

TiGü 9. Mär 2018 15:36

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Zitat:

Zitat von günni0 (Beitrag 1395673)
Zitat:

Lass mich raten: Das eine Windows 10, wo es funktioniert, hat deutsche Spracheinstellungen und das andere Windows 10, bei dem es nicht funktioniert, hat eine andere Sprache, bspw. Englisch?
Richtig. Der Problem-PC steht irgendwo auf der Welt wo ich keinen Zugriff habe. Wenn ich mich nicht irre irgendwo in Indien.

Ich nutze Delphi für Windows Version 10.2 (kostenlos).

Denk mal drüber nach, was passiert, wenn du einen String mit deutschen Zeitformat versuchst in eine Zeit auf einen (wahrscheinlich) englischen Betriebssystem umzuwandeln.

Delphi.Narium 9. Mär 2018 15:38

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Das ist jetzt geraten und nur so als Idee gedacht:
Delphi-Quellcode:
var
  sUhrZeit : String;
begin
  sUhrZeit := Format('%.2d%s%.2d%s%.2d',[12, System.SysUtils.TimeSeparator, 0, System.SysUtils.TimeSeparator, 0]);
  DateTimePicker1.Time := StrToTime(sUhrzeit);
  DateTimePicker2.DateTime := Now + 1;
end;

günni0 9. Mär 2018 15:39

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Ich dachte StrToTime berücksichtigt das alles.

Mein Workaround sieht so aus

Delphi-Quellcode:

function CustomFormatSettings(TimeSeparator: Char = ':'; DateSeparator: Char = '/'): TFormatSettings;
begin
 Result := TFormatSettings.Create(GetUserDefaultLCID);
 Result.TimeSeparator := TimeSeparator;
 Result.DateSeparator := DateSeparator;
 Result.ShortDateFormat := 'dd' + DateSeparator + 'mm' + DateSeparator + 'yyyy';
 Result.LongDateFormat := 'dddd, dd. mm yyyy';
end;

DateTimePicker1.Time := StrToTime('12:00:00', CustomFormatSettings);

hoika 9. Mär 2018 15:49

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Hallo,
endlich mal eine Problembeschreibung von Dir ;)

Bei manchen Windows-Installationen ist das Datumsformat vermurkst.
Ich weiß, wir sind hier bei der Uhrzeit.

Unter Windows gibt es 2 Einstellungsstellen für die Region.
Die eine Stelle siehst unter Systemsteuerung/ Region, Delphi benutzt die andere ...

Lösung1:
Unter Region auf "Weitere Einstellungen" und dort unten auf "Zurücksetzen".

Lösung2:
DateTimePicker1.Time := EncodeTime(12,0,0,0);
Also weg von den StrToX-Funktionen.

Wir haben uns wie auch Du eine eigene Methode gebaut.

günni0 9. Mär 2018 16:02

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Was ist denn zu bevorzugen.

EncodeTime oder StrToTime mit FormatSettings als Parameter?

Delphi.Narium 9. Mär 2018 16:03

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
EncodeTime

günni0 9. Mär 2018 16:06

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Letzte Frage. Wie gehe ich denn am besten an einer Stelle vor, wo ich StrToTime verwenden muss, weil der Parameter ein String ist und ich dessen Format nicht immer zu 100% sicherstellen kann?

Delphi.Narium 9. Mär 2018 16:22

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Die Frage verstehe ich nicht so ganz:

Heißt das, Du bekommst eine Uhrzeitangabe als Zeichenfolge, ohne dass Du weißt, wie sie konkret aufgebaut ist und muss daraus einen gültigen DateTime machen?

Ist die Zeitangabe denn zumindest immer in der Reihenfolge Stunde, Minute, Sekunde?

Dann könnte man zeichenweise von links nach rechts durch den String gehen und jedes Zeichen prüfen, ob's 'ne Ziffer ist. Die Stunden gehen bis vor die erste "Nichtziffer", dann folgen die Minuten bis zur nächsten "Nichtziffer", dann folgen die Sekunden bis zur nächsten "Nichtziffer" und alle Ziffern dahinter wären dann die Sekundenbruchteile.

Die so erhaltenen vier Zahlen kann man dann an EncodeTime übergeben. Hat man weniger als vier Zahlen, übergibt man für die entsprechenden Werte dem EncodeTime jeweils eine 0.

Damit kann man dann aus 12 EncodeTime(12,0,0,0) machen.
Aus 12:15 EncodeTime(12,15,0,0) ebenso aber auch aus 12/15 oder 12h15m.

Man könnte auch zuerst alle Nichtziffern durch ein Leerzeichen ersetzen, dann mehrfache Leerzeichen durch ein Leerzeichen. Danach dürfte man dann sowas alles übernehmen können:

12:00:00,0000
12/00/00.0000
12h00m00s
12h00m
12h
12
12h 00m 00s
12h 00m
12h
...

Ist halt ein bisserl "Zeichenfolgenbröselei" in 'ner Schleife.

Solange die Reihenfolge von Stunde, Minute, Sekunde und ggfls. Sekundenbruchteilen eingehalten wird, dürfte das übergebene Format in der Zeichenfiolge dann fast schon egal sein.

hoika 9. Mär 2018 20:15

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Hallo,
Zitat:

Letzte Frage. Wie gehe ich denn am besten an einer Stelle vor, wo ich StrToTime verwenden muss, weil der Parameter ein String ist und ich dessen Format nicht immer zu 100% sicherstellen kann?
Da kannst Du gar nichts machen.

Ich hatte mal eine StrToTimeLazy geschrieben,
aber wenn z.B. die Sekunden zuerst kommen, was willst Du denn da machen?

p80286 9. Mär 2018 21:59

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Zitat:

Zitat von hoika (Beitrag 1395697)
aber wenn z.B. die Sekunden zuerst kommen, was willst Du denn da machen?

Ein Format vorgeben. Die ISO8601 gibt es zwar seit 1988, aber auch die digital natives scheinen noch nicht viel von ihr gehört zu haben.
https://de.wikipedia.org/wiki/ISO_8601
Hier die Kurzform falls man nicht nachschlagen will:
YYYY-MM-DDTHH.MM:SS
2018-03-09T23.00:00
Gruß
K-H

günni0 9. Mär 2018 22:11

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Ich werde eh irgendwann von Timestamp zu ISO 8601 wechseln.
Dann erledigen sich viele Probleme von alleine. Aber gegen einen DAN (dümmster anzunehmender Nutzer) der absichtlich Falscheingaben einarbeitet kann man wenig machen.

p80286 9. Mär 2018 22:44

AW: Software verhält sich auf Betriebssystemen unterschiedlich
 
Naja, man kann die Möglichkeit von Fehlern minimieren (Plausibilitätsprüfung), aber leider nicht ausschließen. Schließlich sollte auch für die Nutzer ein wenig Verantwortung übrig bleiben.

Gruß
K-H


Alle Zeitangaben in WEZ +1. Es ist jetzt 16:30 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz