AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Cross-Platform-Entwicklung XE4 ARC Problem / Debuginfos ausgeben
Thema durchsuchen
Ansicht
Themen-Optionen

XE4 ARC Problem / Debuginfos ausgeben

Ein Thema von arnof · begonnen am 7. Mai 2013 · letzter Beitrag vom 18. Mai 2013
Antwort Antwort
arnof

Registriert seit: 25. Apr 2013
1.254 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#1

XE4 ARC Problem / Debuginfos ausgeben

  Alt 7. Mai 2013, 21:42
Hallo,

ich habe eine komplexe Komponente, nun auf Firemonkey umgeschrieben (Bitmap Vektorisierung). Unter Windows und Mac OSX läufts so wie es soll!

Unter IOS fliegt mir die Anwendung um die Ohren mit Schutzverletzungen! Ich habe hier das ARC in verdacht, da in der Komponente mit sehr vielen Objekten gearbeitet wird, die auch noch wieder manuell freigegeben werden (FREE und NIL).

Im Debugger sehe ich das es beim Freigeben die Schutzverletzung gibt, leider kann ich nicht genau feststellen wann und wo das passiert, da das so tief geschachtelt ist das das APP im Schritt für Schritt Modus im Simulator zu macht, bevor ich an die eigentliche Stelle komme.


Nun meine Frage kann ich irgenwie eine Debugmeldung ausgeben, so das ich diese in Delphi sehen könnte oder geht das nur mit Instruments

Geändert von arnof ( 7. Mai 2013 um 21:55 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von RWarnecke
RWarnecke

Registriert seit: 31. Dez 2004
Ort: Stuttgart
4.408 Beiträge
 
Delphi XE8 Enterprise
 
#2

AW: XE4 ARC Problem / Debuginfos ausgeben

  Alt 8. Mai 2013, 06:00
OutputDebugString heißt der Befehl, damit tauchen die Meldungen im Event Log der IDE auf.
Rolf Warnecke
App4Mission
  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.492 Beiträge
 
Delphi 7 Enterprise
 
#3

AW: XE4 ARC Problem / Debuginfos ausgeben

  Alt 8. Mai 2013, 08:27
OutputDebugString heißt der Befehl, damit tauchen die Meldungen im Event Log der IDE auf.
Und die Windows-Funktion OutputDebugString läuft unter iOS? Witzig, das wusste ich ja noch gar nicht

Ich meine, dass die NSLog wäre, z.b:
NSLog(NSStr(PChar(Format('Windows: %d', [UIApplication.sharedApplication.Windows.Count]))));
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
Benutzerbild von RWarnecke
RWarnecke

Registriert seit: 31. Dez 2004
Ort: Stuttgart
4.408 Beiträge
 
Delphi XE8 Enterprise
 
#4

AW: XE4 ARC Problem / Debuginfos ausgeben

  Alt 8. Mai 2013, 11:40
Ich habe es jetzt nicht direkt ausprobiert. Aber da der Befehl nur Messages ins Eventlog der IDE schreibt, warum sollte der nicht funktionieren.

Ich meine, dass die NSLog wäre, z.b:
NSLog(NSStr(PChar(Format('Windows: %d', [UIApplication.sharedApplication.Windows.Count]))));
Das wäre doch das Device-Log, welches ich in XCode einsehen kann.
Rolf Warnecke
App4Mission
  Mit Zitat antworten Zitat
daywalker9

Registriert seit: 1. Jan 2010
Ort: Leer
594 Beiträge
 
Delphi XE3 Professional
 
#5

AW: XE4 ARC Problem / Debuginfos ausgeben

  Alt 8. Mai 2013, 13:05
OutputDebugString ist aber eine Windows-API Funktion (daher nicht verfügbar auf iOS). Jedes Windows Programm kann diese Nachrichten empfangen.
Lars
  Mit Zitat antworten Zitat
arnof

Registriert seit: 25. Apr 2013
1.254 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#6

AW: XE4 ARC Problem / Debuginfos ausgeben

  Alt 8. Mai 2013, 15:38
OutputDebugString ist aber eine Windows-API Funktion (daher nicht verfügbar auf iOS). Jedes Windows Programm kann diese Nachrichten empfangen.
Stimmt, ich kanns nicht starten, da er dieses nicht kennt unter ios bzw. macosx

Was muss man in die uses nehmen, damit nslog geht
  Mit Zitat antworten Zitat
Daniel
(Co-Admin)

Registriert seit: 30. Mai 2002
Ort: Hamburg
13.920 Beiträge
 
Delphi 10.4 Sydney
 
#7

AW: XE4 ARC Problem / Debuginfos ausgeben

  Alt 8. Mai 2013, 15:44
Olaf hat ein NSLog implementiert und eine Unit dafür erstellt. Nähere Infos in seinem Blog:

http://www.monien.net/blog/
Daniel R. Wolf
mit Grüßen aus Hamburg
  Mit Zitat antworten Zitat
Benutzerbild von Union
Union

Registriert seit: 18. Mär 2004
Ort: Luxembourg
3.492 Beiträge
 
Delphi 7 Enterprise
 
#8

AW: XE4 ARC Problem / Debuginfos ausgeben

  Alt 8. Mai 2013, 17:25
Was muss man in die uses nehmen, damit nslog geht
iOSApi.Foundation
Ibi fas ubi proxima merces
sudo /Developer/Library/uninstall-devtools --mode=all
  Mit Zitat antworten Zitat
arnof

Registriert seit: 25. Apr 2013
1.254 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#9

AW: XE4 ARC Problem / Debuginfos ausgeben

  Alt 18. Mai 2013, 13:16
Falls das Thema noch jemanden interessiert hier erstmal die Lösung:

NSLog((NSStr('Hallo Welt') As ILocalObject).GetObjectID);


Benötigte Units:

iOSapi.Foundation,MacAPI.ObjectiveC

Wo sieht man die Ausgabe: im XCODE Organiser -> Geräteconsole

Geändert von arnof (18. Mai 2013 um 15:40 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 08:05 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