Forum: PC-Programmierung Mein Programm nach dem Update von Visual Studio läuft nicht mehr


Announcement: there is an English version of this forum on EmbDev.net. Posts you create there will be displayed on Mikrocontroller.net and EmbDev.net.
von B. P. (skorpionx)


Angehängte Dateien:

Lesenswert?

Bis Mittag war heute alles O.K. Mein Programm unter Visual Studio
lief ohne Probleme. Nach dem heutigen Update von Visual Studio
läuft mein Programm nicht mehr. Ein Fehler nach dem Start mit
Debug und der andere ohne Debug…

von Hans H. (loetkolben)


Lesenswert?

Ich weiß was kaputt ist:
Der Heap ist kaputt.

von Carsten S. (dg3ycs)


Lesenswert?

B. P. schrieb:
> Nach dem heutigen Update von Visual Studio
> läuft mein Programm nicht mehr. Ein Fehler nach dem Start mit
> Debug und der andere ohne Debug…

Hast du schon versucht das Programm KOMPLETT neu zu Compilieren?
Also die Projektmappe einmal bereinigt und dann BuildAll?

Gruß
Carsten

von Harald K. (kirnbichler)


Lesenswert?

Wenn Du das Programm auf dem Rechner laufen lässt, auf dem Du es auch 
kompiliert hast, wird im zweiten Fall der zum Visual Studio gehörende 
JIT-Debugger aufgerufen, wenn Du auf den Knopf "Wiederholen" klickst.

Dann kannst Du sehen, was schiefgeht.

Wenn das Problem in irgendeiner DLL auftritt, sieh Dir den Stacktrace 
an, irgendwo dort wird Dein Code zu finden sein, der eine Funktion aus 
der DLL aufruft; sieh Dir die Funktionsargumente etc. genauer an.

von Der M. (steinadler)


Lesenswert?

Manchmal war es auch schon hilfreich, die .suo-Datei des Projektes zu 
löschen. Da sind irgendwelche Nutzer-bezogenen Daten drin. Vielleicht 
vorsichtshalber mal ein Backup machen.

von MaWin O. (mawin_original)


Lesenswert?

Der Fehler ist in Zeile 42 deines Programmquellcodes.

von B. P. (skorpionx)


Lesenswert?

Die Lösung. Ich habe den Visual Studio Installer gestartet
(In der Suchleiste tippen…). Mit „mehr“ weitere Option stehen
zu Verfügung.Zuerst habe ich die Option Reparatur gewählt
( mit der Vermutung,dass das nur Installationsfehler war).
Das Ergebnis war leider weiter,wie auf meinem Screenshot zu
sehen ist. Die nächste Option, die ich ausgewählt habe, war
"Visual Studio zurückrollen".Danach war ich zurück zu der
Version vor dem Update. Jetzt läuft alles ohne Fehler.
Ich programmiere nur C++/CLI mit Forms.

von Frank M. (ukw) (Moderator) Benutzerseite


Lesenswert?

B. P. schrieb:
> Die Lösung.

Du magst es als Lösung ansehen, ich sehe das anders. Du bist jetzt 
einfach auf den alten Stand zurückgegangen.

Ich glaube eher, dass das Übersetzen Deines Codes im aktuellen Visual 
Studio einen Speicher-Überschreiber aufgedeckt hat, der durch einen 
anders übersetzenden/optimierenden Compiler zu Tage getreten ist. Durch 
das Rücksetzen auf den alten Stand hast Du den potentiellen Fehler 
einfach wieder überdeckt.

So kann man natürlich auch Probleme lösen. Wenn Du Pech hast, holt Dich 
der Fehler irgendwann wieder ein. ;-)

: Bearbeitet durch Moderator
von B. P. (skorpionx)


Lesenswert?

Frank M. schrieb:
> Du magst es als Lösung ansehen, ich sehe das anders. Du bist jetzt
> einfach auf den alten Stand zurückgegangen.

Wenn ein Update da ist, dann nutze ich ihn immer. Jedes Programm hat
Potenzial für Fehler. Auch Visual Studio. Ich allokiere in meinem
Programm Speicher mit drei Funktionen: malloc(), HeapAlloc(), und 
VirtualAlloc().Kein Compiler kann voraus feststellen,ob beim Zugriff auf 
allokierten Speicher zur Verletzung kommt. Kein Compiler kann sogar 
feststellen ob wirklich zum Allokieren kommt auch wenn alle drei 
Funktion
im Programmcode erscheinen. Einzige Tatsache die Compiler feststellen
kann, ist dass das solche Art von Allokieren passieren kann und das mit 
Fehlermeldung verbieten.Dazu ist aber nicht gekommen. Das „Erstellen“
lief Fehlerfrei. Das Programm wurde danach aber nicht gestartet. Das
kann ich im Moment als Fehler auf Microsoft Seite interpretieren.

von Harald K. (kirnbichler)


Lesenswert?

B. P. schrieb:
> Das Programm wurde danach aber nicht gestartet.

Meine Güte -- nutze den Debugger! Der ist dafür da, damit Du den Fehler 
in Deinem Code finden kannst.

von B. P. (skorpionx)


Lesenswert?

Harald K. schrieb:
> Meine Güte -- nutze den Debugger! Der ist dafür da, damit Du den Fehler
> in Deinem Code finden kannst.

Aber das Programm startet nicht...

von Frank M. (ukw) (Moderator) Benutzerseite


Lesenswert?

B. P. schrieb:
> Kein Compiler kann voraus feststellen,ob beim Zugriff auf allokierten
> Speicher zur Verletzung kommt.

Natürlich nicht. Aber ein neuerer Compiler kann den Code anders 
optimieren und auch den allokierten Speicher anders anordnen, so dass 
ein Buffer-Overflow in Deinem Code nun Bereiche kaputtschreibt, die 
vorher nicht betroffen waren.

Das heißt: Mit großer Wahrscheinlichkeit hast Du mit dem alten Visual 
Studio einfach nur Glück, dass es zufällig läuft. Das neue VS gibt Dir 
nun die Chance, den Fehler zu finden. Ich würde diese nutzen statt 
einfach den Mantel der Ignoranz drüber zu legen.

> Das kann ich im Moment als Fehler auf Microsoft Seite interpretieren.

Hier wurden schon viele Threads aufgemacht mit sehr vielen angeblichen 
Compilerfehlern, die zum Beispiel dem gcc angedichtet wurden. Wie sich 
am Ende zu 99,5% herausgestellt hat, war nicht der Compiler schuld, 
sondern der Programmierer.

: Bearbeitet durch Moderator
von Frank M. (ukw) (Moderator) Benutzerseite


Lesenswert?

B. P. schrieb:
> Aber das Programm startet nicht...

Heißt Dein Programm etwa nicht BMPinPCB.exe? In deinem Screenshot steht, 
dass dieses Programm auf die Speicherstelle -1 zugreift. Also wird es 
auch gestartet, leider aber auch sehr schnell wegen Zugriffsverletzung 
wieder beendet.

von Harald K. (kirnbichler)


Lesenswert?

B. P. schrieb:
> Aber das Programm startet nicht...

Tut es, denn es wird die von Dir gepostete Fehlermeldung ausgegeben.

Mit dem von mir schon heut früh erwähnten Knopf "Wiederholen".

Und wenn das nicht hilft, gibt es in Deiner IDE eine Funktion, um das 
Programm aus der IDE heraus zu starten. Es gibt sogar eine, die "step 
into" heißt, damit kannst Du Deinem Programm Schritt für Schritt 
zusehen.

von Esmu P. (Firma: privat) (max707)


Lesenswert?

Die Befehlszeile vom alten Kompiler kopieren und in den neuen 
importieren.

Vergleiche die Eigenschaften im Projekt.

: Bearbeitet durch User
von Hans-Georg L. (h-g-l)


Lesenswert?

B. P. schrieb:
> Kein Compiler kann voraus feststellen,ob beim Zugriff auf allokierten
> Speicher zur Verletzung kommt.

Aber ein Compiler kann Code erzeugen der an den Bereichs Enden eine 
Signatur anhängt und auf überschreiben testet. Das ist aber nichts neues 
...

von Heiko (zwergnr8)


Lesenswert?

Meine bescheidene Meinung: Wenn es früher "ging" und nach deinem Update 
nicht mehr, dann ist das natürlich schlecht, muß aber erstmal kein 
"Programmierfehler" sein. Ferndiagnosen sind auch immer so eine Sache. 
Ich sehe also nur "Expression: _CrtIsValidHeapPointer(block)".

Es könnte sein (Achtung Ferndiagnose), daß das neu kompilierte Programm 
mit seiner "neuen" RuntimeLib vom User geladene DLLs benutzt, die 
wiederum eine eigene RuntimeLib benutzen, die jetzt nicht mehr 
untereinander kompatibel sind. Das wäre dann Punkt D im unten verlinkten 
Artikel. Alles andere möchte ich bald (Achtung Ferndiagnose) 
ausschließen, denn doppelte free()'s wären sicher schon früher mal 
aufgefallen.

Es könnte sein, daß das Neu-Kompilieren des Programms mit einer älteren 
"Windows-SDK-Version" in den Projekteinstellungen das Problem behebt. 
Ein anderer Quell der Freude nach VS-Updates ist diese Zeile in den 
Projektfiles:
<VCToolsVersion>14.36.32532</VCToolsVersion>
Aber wenn diese Nummer nicht stimmt (letztendlich der Dateipfad nicht 
gefunden wird), wird das Projekt ja gar nicht erst geöffnet.

https://stackoverflow.com/questions/64418624/why-do-i-get-crtisvalidheappointerblock-and-or-is-block-type-validheader-b

: Bearbeitet durch User
von B. P. (skorpionx)


Lesenswert?

Heiko schrieb:
> Meine bescheidene Meinung: Wenn es früher "ging" und nach deinem Update
> nicht mehr, dann ist das natürlich schlecht, muß aber erstmal kein
> "Programmierfehler"

Mein Windows Programm ist Ereignisgesteuert. Nach dem Start wird
kein Code von meinem Programm Teil ausgeführt aber nur das, was
Visual Studio für GUI Forms vorbereitet hat. Es wird kein Speicher
allokiert. Erst nach dem Bildaufbau fertig ist kann man durch
Button Aktion anleiten und erst dann wird der Speicher allokiert.
Mein (intuitives…) Verdacht geht in die Richtung von Verwendung von
malloc(). So etwas passieren kann wenn mehrere Entwickler an
verschiedenen Fronten einer Entwicklung arbeiten.
Das was ein Entwickler in Compiler zugelassen hat, ein anderer beim
Debuggen abgelehnt hat...

von Harald K. (kirnbichler)


Lesenswert?

B. P. schrieb:
> Es wird kein Speicher allokiert.

Es gibt keine Konstruktoren?

Debuggst Du Programme immer auf diese deterministische Weise?

von B. P. (skorpionx)


Lesenswert?

Harald K. schrieb:
> Es gibt keine Konstruktoren?

Keine. Aber es gibt´s  (sehr wenige...) globale Elemente.

von B. P. (skorpionx)


Lesenswert?

B. P. schrieb:
> Es gibt keine Konstruktoren?

Aber deine Bemerkung ist sehr interessant...
Leider Compiler könnte keinen Fehler finden...

von Heiko (zwergnr8)


Lesenswert?

Mal abgesehen davon, daß ich das Problem verstehe, verstehe ich auch 
nicht so recht, wo das Problem mit dem Debuggen ist.

Die Frage ist doch, wie weit das Programm nach dem Start überhaupt 
kommt. Wird WinMain() überhaupt erreicht, damit etwas später überhaupt 
ein Window aufgemacht werden kann. Das OS ruft den "EntryPoint" des 
Programms (oder einer DLL) auf. Üblicherweise ist das Code einer 
C-Runtimelib. Erst wenn die mit ihrem Init-Zeug fertig ist, wird WinMain 
aufgerufen.

Also mal einen Breakpoint direkt an den Anfang von WinMain setzen. Wenn 
der triggert, ist die CRT erstmal zufrieden und auch alle benötigten 
DLLs wurden geladen. Bisher ist kein eigener Programmcode gelaufen. Dann 
halt weiterhangeln. Ist denn dieser HeapValidate()-Aufruf, der in der 
ntdll.dll für Unheil sorgt, eigener Code oder ist das DBG-Zeug, welches 
VS öffnet, wenn es die Quellen findet?

von Harald K. (kirnbichler)


Lesenswert?

Heiko schrieb:
> Also mal einen Breakpoint direkt an den Anfang von WinMain setzen.

Braucht man nicht, ein "step into" zum Starten des Programmes genügt.

von B. P. (skorpionx)


Angehängte Dateien:

Lesenswert?

Harald K. schrieb:
> ein "step into" zum Starten des Programmes genügt

Gestartet mit F11 Taste. Ergebnis auf dem ScreenShoot.

von Harald K. (kirnbichler)


Lesenswert?

Unten rechts ist ein Fenster namens Aufrufliste. Wenn man das noch 
kleiner macht, sieht man noch weniger und muss noch weiter scrollen.

von Roger S. (edge)


Lesenswert?

B. P. schrieb:
> Harald K. schrieb:
>> ein "step into" zum Starten des Programmes genügt
>
> Gestartet mit F11 Taste. Ergebnis auf dem ScreenShoot.

Wahnsinn, und jetzt scroll mal in der Aufrufliste zu Deiner Funktion - 
Doppelclick - und dann kannst du drueber philosophieren wie du das zum 
Absturz gebracht hast.

von B. P. (skorpionx)


Angehängte Dateien:

Lesenswert?

1
//
2
// debug_heap.cpp
3
//
4
//      Copyright (c) Microsoft Corporation.  All rights reserved.
5
//
6
// The implementation of the CRT Debug Heap.
7
//
8
#ifndef _DEBUG
9
    #error This file is supported only in debug builds
10
    #define _DEBUG // For design-time support, when editing/viewing CRT sources
11
#endif
12
#include <corecrt_internal.h>
13
#include <malloc.h>
14
#include <minmax.h>
15
#include <new.h>
16
#include <stdio.h>
17
#include <stdlib.h>
18
//-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
19
#define _ALLOCATION_FILE_LINENUM "\nMemory allocated at %hs(%d).\n"
Und das passiert in einem File debug_heap.cpp von Microsoft.
Ich habe das File nicht in Projekt eingeführt...

von Roger S. (edge)


Lesenswert?

B. P. schrieb:
> Und das passiert in einem File debug_heap.cpp von Microsoft.
> Ich habe das File nicht in Projekt eingeführt...

Scroll mal in der Aufrufliste ganz runter.
Das was du Zeigst ist das der Code von Microsoft etwas beanstandet was 
Deiner verbrochen hat. Und wo das ist findest du in der Aufrufliste.

von Frank M. (ukw) (Moderator) Benutzerseite


Lesenswert?

B. P. schrieb:
> debug_heap.cpp

Wie ich oben schon schrieb: Wird der Heap korrumpiert, liegts meist an 
einem Überschreiber im Speicher. Der haut nämlich oft Teile der 
Verwaltungsinformationen weg.

Ich tippe daher (wie schon in meiner ersten Antwort) auf einen 
Buffer-Overflow. Es könnte sich zum Beispiel um ein globales Array 
handeln, welches Du in der Größe überschreibst.

Den Stack-Trace, den Du da siehst, ist die Auswirkung, nicht der Fehler. 
Der erfolgte bereits früher. Aus meiner Erfahrung kann ich da nur sagen: 
Das wird schwierig.

Ein Tipp zur Fehlersuche:

Vergrößere nach und nach jedes globale Array um einen Sicherheitswert, 
bis das Programm nicht mehr crasht, also zum Beispiel:

Alt:
1
int myarray[MY_ARRAY_SIZE];

Neu:
1
int myarray[MY_ARRAY_SIZE + 10000];

Dann bekommst Du vielleicht raus, welches Array da überschrieben wird. 
Anschließend suchst Du die Stellen raus, wo das Array beschrieben wird 
und bringst die Stellen ggfls. in Ordnung. Anschließend nimmst Du den 
zusätzlichen Puffer wieder raus und testest neu. Wenns dann läuft, hast 
Du den Fehler gefunden.

Keine Gewähr. Ich schrieb das nur, weil Du sagtest, dass Du at Runtime 
keinen Speicher allokierst. Dann muss es ja eine globale Variable sein 
oder Du hast Dich mit Deiner Aussage geirrt.

von B. P. (skorpionx)


Lesenswert?

HeapAlloc

Frank M. schrieb:
> Wird der Heap korrumpiert, liegts meist an
> einem Überschreiber im Speicher.
Für Testzwecke habe ich alle Stelle im Projekt wo ich den Speicher
allokiere entfernt.. Der Fehler bleibt.

von MaWin O. (mawin_original)


Lesenswert?

Dann kann man wohl nix machen. Microsoft dumm. B.P. schlau.

von Heiko (zwergnr8)


Lesenswert?

Harald K. schrieb:
> Heiko schrieb:
>> Also mal einen Breakpoint direkt an den Anfang von WinMain setzen.
>
> Braucht man nicht, ein "step into" zum Starten des Programmes genügt.

Stimmt - hab ich bisher so nie gebraucht. (Sorry, das konnte ich nicht 
wissen, denn mein Zeug crasht normalerweise nicht gleich in WinMain... 
;))

Ich habe aber trotzdem noch immer keine Antwort auf die Frage, ob das 
Progi vom TE überhaupt bis WinMain() kommt.

von Harald K. (kirnbichler)


Lesenswert?

Heiko schrieb:
> Ich habe aber trotzdem noch immer keine Antwort auf die Frage, ob das
> Progi vom TE überhaupt bis WinMain() kommt.

Das werden wir wohl auch nie erfahren, da den bereits das Konzept des 
Vergrößern eines Fensters und des Scrollens in einer Liste zu 
überfordern scheint.

von Heiko (zwergnr8)


Lesenswert?

Ja, etwas mehr Elan wäre wünschenswert. Es wird aber so sein, daß das 
Progi nicht bis WinMain() kommt, weil der CRT-Code crasht. Anhand der in 
den Bildern schon teilweise zu sehenden Aufrufliste kann man das erahnen 
und vergleichen. Der Kollege im Artikel unten hat ein ähnliches Problem 
und die gepostete Aufrufsequenz ist praktisch identisch.

https://stackoverflow.com/questions/57860879/troubleshooting-a-crash-during-run-time-initialization-in-mixed-native-net-appl

What next?

von Roger S. (edge)


Lesenswert?

Heiko schrieb:
> Der Kollege im Artikel unten hat ein ähnliches Problem
> und die gepostete Aufrufsequenz ist praktisch identisch.

Immerhin hat es der Kollege dort geschafft ein ganzer stacktrace zu 
posten, der crash dort ist im atexit, vermutlich durch ein terminate 
getriggert (nicht gefangene exception?)

von B. P. (skorpionx)


Lesenswert?

Ich habe den Fehler lokalisiert. In vielen Schritten habe ich
meinTeil vom Programm“entleert“.Am Ende ist so etwas geblieben:
1
#pragma comment(lib,"winspool")
2
#include <atlstr.h>
3
/*HANDLE hPrinter;
4
long BytesAnDruckerSenden(HANDLE hPrinter, LPVOID PPufferMitBytes, unsigned long SchreibByteAnzahl);
5
long BytesAnDruckerSenden(HANDLE hPrinter, LPVOID PPufferMitBytes, unsigned long SchreibByteAnzahl)
6
{  unsigned long ByteGeschrieben;
7
    WritePrinter(hPrinter, (LPVOID)PPufferMitBytes, SchreibByteAnzahl, &ByteGeschrieben);
8
    if (SchreibByteAnzahl == ByteGeschrieben)return 0;
9
    else return 1;}*/
Das bring noch Fehler. Aber wenn ich #include <atlstr.h> auskomentiere:
1
//#include <atlstr.h>
 der Fehler ist Weg. Der Fehler auf
Microsoft Seite.

von Harald K. (kirnbichler)


Lesenswert?

B. P. schrieb:
> Der Fehler auf Microsoft Seite.

Nein, das ist er ganz, ganz sicher nicht. Garantiert nicht.

von B. P. (skorpionx)


Lesenswert?

Harald K. schrieb:
> Nein, das ist er ganz, ganz sicher nicht. Garantiert nicht.

Einzige Zeile die ich im Programm schreibe:
1
#include <atlstr.h>
bringt den Fehler. Compiler bringt keien Fehler abe der
kommt bei Ausführung.
Übrigens atlstr.h kommt von Microsoft.

von Roger S. (edge)


Lesenswert?

B. P. schrieb:
> Harald K. schrieb:
> Einzige Zeile die ich im Programm schreibe:
>
1
#include <atlstr.h>

Machst du nun im schnellauf alle alten Technologien durch?
Schon möglich dass bloss das inkludieren eines ATL/COM headers was 
undefiniertes bewirkt wenn Dein Projekt nicht dafür aufgesetzt ist.

von Heiko (zwergnr8)


Lesenswert?

Mmm, der Header ist MBCS-MFC Geraffel. Wenn er das braucht, muß der 
Header halt mit rein. Ich würde jetzt ebenfalls einen ganz tiefen Blick 
in die Projekt-Einstellungen anregen wollen. Speziell unter dem Punkt 
"Zeichensatz".

: Bearbeitet durch User
von Harald K. (kirnbichler)


Lesenswert?

Trotzdem liegt der Fehler bei Dir.

Eine #include-Anweisung ist kein beim Programmablauf sequentiell 
ausgeführter Vorgang, auch wenn Dich das jetzt überraschen mag.

Da Du wohl eine .Net-Anwendung zu, äh, machen scheinst, warum eigentlich 
willst Du in der Funktionen wie malloc, VirtualAlloc etc. verwenden?

Wozu nur?

von Oliver S. (oliverso)


Lesenswert?

Harald K. schrieb:
> Da Du wohl eine .Net-Anwendung zu, äh, machen scheinst, warum eigentlich
> willst Du in der Funktionen wie malloc, VirtualAlloc etc. verwenden?

Die Antwort zu der Frage findet sich in den anderen Threads des/der TO.

Er/Sie/Es programmiert nicht in .Net oder C++ oder managed C++, sondern 
"in Visual Studio", um eine anscheinend in C++ vorliegende 
(Borland-)Anwendung dorthin zu übertragen.

Oliver

von Harald K. (kirnbichler)


Lesenswert?

Oliver S. schrieb:
> Die Antwort zu der Frage findet sich in den anderen Threads des/der TO.

Ach Gott, der ist das.

Weia.

von Some O. (some_one)


Lesenswert?

Frank M. schrieb:
> Vergrößere nach und nach jedes globale Array um einen Sicherheitswert,


Ggf mal mit Valgrind laufen lassen, ode gibts das nicht unter Windows?

von Harald K. (kirnbichler)


Lesenswert?

Some O. schrieb:
> Ggf mal mit Valgrind laufen lassen

Bei den elementaren Problemen, die hier vorliegen, ist das leider 
vollkommen sinnlos.

Der Threadstarter kann das Programm im Debugger laufen lassen, scheitert 
aber an elementaren Dingen wie der Bedienung des Debuggers (Call Stack 
bei auftretender Exception ansehen).

Dazu wird auch krampfhaft gegen die verwendete Programmiersprache (ein 
C++-ähnliches Konstrukt für den .Net-Unterbau) gearbeitet, weil gar 
nicht verstanden wird, was der Unterschied zu nativem C++ ist, aber ein 
natives C++-Programm, das für ein völlig anderes Framework eines anderen 
Herstellers geschrieben war, "portiert" werden soll.

Da geht schon lange annähernd alles schief, was schiefgehen kann.

Da hilft Valgrind auch nicht mehr als 'ne homöopathische 
Kopfschmerztablette.

von B. P. (skorpionx)


Lesenswert?

Harald K. schrieb:
> B. P. schrieb:
>> Der Fehler auf Microsoft Seite.
>
> Nein, das ist er ganz, ganz sicher nicht. Garantiert nicht.

Das erlebe ich oft. Ich fahre mit dem Auto. Daneben sitzt meine
Partnerin. Auf eine Kreuzung, ein Auto (ein Mädchen mit der Nase
auf der Windscheibe…) nimmt mir Vorfahrt.
Meine Partnerin:
1. Vielleicht war sie in Eile...
2. Warum sagst du das? Ich könnte auch als Fahrerin im  Auto sein.
...

Jedes Programm hat Potenzial für Fehler. Über vielen Jahren war
dein Programm Weltweit im Einsatz. Nach vielen Jahren bekommst
einen Anruf aus einem weit entfernten Land. Es wird genaue
beschrieben wie und wenn es zu einem Fehler kommt. Einziges Wort
mit dem du reagierst kann ist“Danke“.
Den Microsoft Fehler habe ich schon an Entwickler gemeldet...

von Harald K. (kirnbichler)


Lesenswert?

B. P. schrieb:
> Über vielen Jahren war dein Programm Weltweit im Einsatz.

Dein Programm hier aber nicht.

B. P. schrieb:
> Den Microsoft Fehler habe ich schon an Entwickler gemeldet...

Und Dich damit lächerlich gemacht. Jemand, der mit einem Werkzeug nicht 
ansatzweise umgehen kann, der die einfachsten Dinge die zur Diagnose 
dazugehören, nicht auf die Reihe bekommt, der ausgerechnet will einen 
Fehler gefunden haben?

von J. S. (jojos)


Lesenswert?

Harald K. schrieb:
> Dazu wird auch krampfhaft gegen die verwendete Programmiersprache (ein
> C++-ähnliches Konstrukt für den .Net-Unterbau) gearbeitet,

welches denn genau? ATL hat nichts mit .Net zu tun, die Verwendung mit 
MFC ist erlaubt.

Für einen Fehlerbericht ist aber ein Minimalbeispiel nötig, also z.B. 
das aus der Doku:
https://learn.microsoft.com/de-de/cpp/atl-mfc-shared/using-cstring?view=msvc-170&source=recommendations
Wenn das den Fehler zeigt, dann könnte man das melden.
Ich würde aber eher vermuten das irgendwelche 
Compiler/Linkereinstellungen für die Verwendung von ATL nicht richtig 
eingestellt sind. Wenn der Compiler nicht meckert, dann wird ja auch 
keine ATL Funktion verwendet.

Trotzdem sollte über ein Redesign mit managed Code in C++ oder gleich C# 
nachgedacht werden. Die wilden Zeigerorgien sind viel zu gefährlich und 
schon lange überflüssig.

von Harald K. (kirnbichler)


Lesenswert?

J. S. schrieb:
> welches denn genau? ATL hat nichts mit .Net zu tun, die Verwendung mit
> MFC ist erlaubt.

Sieh Dir mal die anderen Threads zum gleichen Thema an:

Beitrag "Microsoft Visual Studio und Forms in C++"

Beitrag "Visual Studio erlaubt keine Zeiger auf eine C++/CLI-Verweisklasse!"

Beitrag "Eine class von Borland Builder in Visual Studio übernehmen."

von B. P. (skorpionx)


Lesenswert?

J. S. schrieb:
> Für einen Fehlerbericht ist aber ein Minimalbeispiel nötig, also z.B.
> das aus der Doku:
1
#include <atlstr.h>
Und das ist das Minimalbeispiel.

: Bearbeitet durch User
von Harald K. (kirnbichler)


Lesenswert?

B. P. schrieb:
> Und das ist das Minimalbeispiel.


Und welche Compiler-/Projekteinstellungen? Welche Sprache benutzt Du 
überhaupt, hast Du das schon herausgefunden?

von J. S. (jojos)


Lesenswert?

Damit bekomme ich keine Fehler mit aktuellem VS2019, 
Kommandozeilenprojekt mit atlstr.h und auch der CString Klasse aus dem 
Beispiel. Auch mit /clr Option geht es.

von B. P. (skorpionx)


Lesenswert?

J. S. schrieb:
> mit aktuellem VS2019

Ja. Mit allen Versionen vor dem letzten Update geht das ohne
Fehler...

von J. S. (jojos)


Lesenswert?

gut, das VS2022 muss ich sowieso noch installieren, dann teste ich es 
damit auch mal.

getan, mit frisch installiertem VS2022 läuft es immer noch. Das unter 
VS2019 angelegte Projekt geöffnet, Plattformtoolset wurde von v142 auf 
v143 aktualisiert, kompiliert, läuft.
In Debug/Release, mit und ohne /clr.

Vielleicht mal dein Minimalprojekt hier posten, dann kann man sehen ob 
es Installationsabhängig ist.

: Bearbeitet durch User
von B. P. (skorpionx)


Angehängte Dateien:

Lesenswert?

J. S. schrieb:
> Vielleicht mal dein Minimalprojekt hier posten, dann kann man sehen ob
> es Installationsabhängig ist.

von J. S. (jojos)


Lesenswert?

ich kann das Problem nur bestätigen, mit Toolset v142 funktioniert es 
und mit v143 nicht. Geändert wurde da etwas am CAtlStringMgr, damit 
scheint es zusammenzuhängen. Im neueren Code crasht es wenn eine 
Funktion für das Programm beenden hinzugefügt werden soll, da gibt es 
keinen Speicher für die Liste der Funktionen.
Auch die Forms Includes habe ich rausgeworfen, es scheint wirklich am 
User Code zu liegen. Ich sehe nur nicht viel Unterschied zu meinem Test, 
kann jetzt aber gerade nicht mehr weitersuchen.

von B. P. (skorpionx)


Lesenswert?

J. S. schrieb:
> Vielleicht mal dein Minimalprojekt hier posten, dann kann man sehen ob
> es Installationsabhängig ist.

Alles was im Minimalprojekt ist wurde von Visual Studio
generiert außer eingefügten #include <atlstr.h>. Das
Mininimalprojekt habe ich an Microsoft Entwickler weiter geleitet.

von Roger S. (edge)


Angehängte Dateien:

Lesenswert?

Hier die Korrigierte variante wo du nun dein ATL header inkludieren 
kannst.
Das Problem ist dass du den Einstiegspunkt in die Applikation verbogen 
hast, womit die CRT initialisiertung umgangen wurde. Das hat einen 
Einfluss auf atexit(), welches von dem ATL code aufgerufen wird.

Extra gratis Tip: Wenn du Deine Projekte postetst, dann entferne die 
binaries und .vs Ordner, 38MB fuer nix.

von MaWin O. (mawin_original)


Lesenswert?

Roger S. schrieb:
> Das Problem ist dass du den Einstiegspunkt in die Applikation verbogen
> hast, womit die CRT initialisiertung umgangen wurde.

Das ist ja ein Ding. Also doch ein Fehler im Programm und kein Fehler 
von Microsoft.
Das kommt jetzt völlig überraschend.

Merksatz: Wenn man einen Fehler im Compiler vermutet, dann liegt der 
Fehler praktisch immer im eigenen Programm. Compilerfehler kommen extrem 
selten vor. Fehler im eigenen Programm kommen hingegen ständig vor. 
Einfachste Wahrscheinlichkeitsrechnung.

von B. P. (skorpionx)


Lesenswert?

MaWin O. schrieb:
> Das ist ja ein Ding. Also doch ein Fehler im Programm und kein Fehler
> von Microsoft.
Alles was im Minimalprojekt ist wurde von Visual Studio
generiert außer eingefügten #include <atlstr.h>.
Und mit älteren Versionen (vor dem update...) läuft das
fehlerfrei.

: Bearbeitet durch User
von Harald K. (kirnbichler)


Lesenswert?

B. P. schrieb:
> Alles was im Minimalprojekt ist wurde von Visual Studio
> generiert

Ach ja?

Roger S. schrieb:
> Das Problem ist dass du den Einstiegspunkt in die Applikation verbogen
> hast,

von Roger S. (edge)


Lesenswert?

Harald K. schrieb:
> B. P. schrieb:
>> Alles was im Minimalprojekt ist wurde von Visual Studio
>> generiert
>
> Ach ja?

Fairer Weise muss man sagen, dass es wohl vom Projekt Template so 
aufgesetzt wurde. Aber dennoch sollte man sich ein wenig mit der Materie 
auseinandersetzen, erst recht, wenn man den Schwierigkeitsgrad anhebt 
indem man Technologien einsetzt die für fortgeschrittene Spieler gedacht 
sind.

von MaWin O. (mawin_original)


Lesenswert?

Roger S. schrieb:
> Fairer Weise muss man sagen, dass es wohl vom Projekt Template so
> aufgesetzt wurde.

So ist das halt. Ein Template kann eben nicht für jeden Einsatzzweck 
vorbereitet sein. Da muss sich der Entwickler selbst drum kümmern.

Und dass es mit einer alten Version funktioniert hat, ist ja purer 
Zufall. Der Fehler ist und bleibt beim Projektentwickler.

von Roger S. (edge)


Lesenswert?

MaWin O. schrieb:
> Und dass es mit einer alten Version funktioniert hat, ist ja purer
> Zufall. Der Fehler ist und bleibt beim Projektentwickler.

Ja, eindeutig.

von J. S. (jojos)


Lesenswert?

ATL und CLR ist aber genauso in MS Beispielcode zu finden. Das es vorher 
funktioniert hat und nachdem MS etwas an der globalen CAtlStringMgr 
Instanz geändert hat, kann es genauso gut sein das MS da nicht alles 
bedacht hat.

von Joachim B. (jar)


Lesenswert?

Frank M. schrieb:
> Hier wurden schon viele Threads aufgemacht mit sehr vielen angeblichen
> Compilerfehlern, die zum Beispiel dem gcc angedichtet wurden. Wie sich
> am Ende zu 99,5% herausgestellt hat, war nicht der Compiler schuld,
> sondern der Programmierer.

+1

aber neue Versionen sind ja auch nie fehlerfrei und bringen neue bis 
jetzt unentdeckte Fehler mit.

von B. P. (skorpionx)


Lesenswert?

Joachim B. schrieb:
> aber neue Versionen sind ja auch nie fehlerfrei

NIE!

: Bearbeitet durch User
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.