INFO: Dieses Forum nutzt Cookies...
Cookies sind für den Betrieb des Forums unverzichtbar. Mit der Nutzung des Forums erklärst Du dich damit einverstanden, dass wir Cookies verwenden.

Es wird in jedem Fall ein Cookie gesetzt um diesen Hinweis nicht mehr zu erhalten. Desweiteren setzen wir Google Adsense und Google Analytics ein.


Antwort schreiben 

Dieses Thema hat akzeptierte Lösungen:

SubVI Referenz blinkt ABER keine Fehlermeldung



Wenn dein Problem oder deine Frage geklärt worden ist, markiere den Beitrag als "Lösung",
indem du auf den "Lösung" Button rechts unter dem entsprechenden Beitrag klickst. Vielen Dank!

21.11.2013, 10:50
Beitrag #1

Blinky_Bill Offline
LVF-Grünschnabel
*


Beiträge: 14
Registriert seit: Sep 2013

2009
2013
kA



SubVI Referenz blinkt ABER keine Fehlermeldung
Hallo an alle LV-User, Bahn

Ich habe ein Problem mit einer SubVI-Referenz.

In meinem Programm werden Werte in einem Diagramm (->SubVi) aufgezeichnet. Das SubVi "Diagramm" läuft
kontinuierlich in meinem Hauptprogramm. Ich möchte hierbei nur das Frontpanel des SubVI`s öffnen und schließen.

Das mache ich über die Methodenknoten "FP öffnen" und "FP schließen" und es läuft fehlerfrei. Lasse ich das Programm
jedoch einige Stunden laufen klappt mir das Blockdiagramm auf und die Referenz-VI`s (ich habe 2) werden abwechselnd markiert und blinken.
Das Programm ist jedoch weiter nutzbar bis auf die SubVI`s die an den Referenzen hängen.

Es wird dabei KEINE Fehlermeldung oder ein sonstiger Hinweis ausgegeben. Untern dargestellt ist der Aufruf des VI`s
und das SubVI Diagramme


Schonmal Danke im Vorraus

Bill


Angehängte Datei(en) Thumbnail(s)
       
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
Anzeige
21.11.2013, 10:57
Beitrag #2

GerdW Offline
______________
LVF-Team

Beiträge: 17.467
Registriert seit: May 2009

LV2021
1995
DE_EN

10×××
Deutschland
RE: SubVI Referenz blinkt ABER keine Fehlermeldung
Hallo Bill,

zu der Schleife mit der FP-Steuerung:
- warum musst du die Referenz dauernd öffnen und schließen? Reicht das nicht jeweils einmal (vor/nach der Schleife) aus?
- warum musst du das FP so oft wie möglich öffnen/schließen? Wo ist hier die Wartezeit in der Schleife?
- warum verwendest du keine Eventstruktur, die den Button "Diagramme" abfragt und nur bei einer Wertänderung eine Aktion ausführt?

Zum anderen VI:
- Sind wirklich so viele globale Variablen nötig?
- warum die RaceCondition bei "Schliessen"?
- warum auch hier das ständige Öffnen von VI-Referenzen? Werden die Referenzen im FALSE-Case auch wieder geschlossen oder bleiben die im Speicher hängen?
- warum gibt es gleich 4 Buttons mit dem Namen "Schliessen"? Würdest du so in irgendeiner textbasierten Programmiersprache arbeiten?

Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
21.11.2013, 13:59
Beitrag #3

Blinky_Bill Offline
LVF-Grünschnabel
*


Beiträge: 14
Registriert seit: Sep 2013

2009
2013
kA



RE: SubVI Referenz blinkt ABER keine Fehlermeldung
Hallo Gerd,

1) Du hast Recht, mir ist bei den ganzen Versuchen gar nicht aufgefallen,
dass es die Referenz andauernd lädt. Aber da ich Sie immer wieder schließe
sollte mein Problem nicht davon kommen oder? (jedenfalls nicht an der Stelle)

2) Das ist ein Minimalbeispiel, mir geht es selbstverständlich nicht darum
ein FP so oft wies geht zu öffnen. Der Aufruf ist Teil eines Programmes.
Die Schleife ist der Vollständigkeit halber ergänzt. Daher auch keine
Wartezeit. Der Schalter Diagramme ist auf "Latch" gestellt. Sprich beim
betätigen wird mir nur einmal das FP geöffnet. Das wird dann angezeigt bis ich es schließe.

3) Die GV sind notwendig, ja.

4) Die 4 Buttons sind nicht notwedig, stimmt. Ich hatte zu Beginn nur versucht Platz
zu sparen und dafür lieber 4 Buttons in Kauf genommen (wegen der Tab-Struktur).

5) Das Öffnen der Referenz im SubVI selber passiert sicher auch im FLASE Case. Das würde
dann bedeuten, die Referenz wird irgendwo gespeichert.. und wenn dann der Speicher
(Teil des Arbeitsspeichers?) voll ist hängt mein Programm? Dann sollte das aber immer
nach einer konstanten Zeit passieren.


Du hast mir ne Menge Hinweise und Anregungen gegeben und man kann vieles sicherlich besser machen,
aber was genau kann denn mein Problem ausgelöst haben bzw. hast davon schonmal gehört?

Gruß Bill
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
21.11.2013, 14:15
Beitrag #4

GerdW Offline
______________
LVF-Team

Beiträge: 17.467
Registriert seit: May 2009

LV2021
1995
DE_EN

10×××
Deutschland
RE: SubVI Referenz blinkt ABER keine Fehlermeldung

Akzeptierte Lösung

Hallo Bill,

2) Das hättest du auch vorher schreiben können. Wie soll man Probleme untersuchen, wenn du ganz anderen Code zeigst?

4) Mir ging es nicht um die Notwendigkeit dieser Buttons, sondern um deren Namen. Benennst du in einem C-Programm auch alle Variablen mit dem identischen Namen?

5) Geöffnete Referenzen benötigen Speicher. Den sollte man durch Schließen der Referenz auch wieder freigeben...
Das mit der "konstanten Zeit" kannst du auf einem modernen Multitasking-OS einfach mal knicken!

Wenn ein Problem erst nach längerer Laufzeit eines Programms auftritt, hat dies oft mit schlechtem Memorymanagment zu tun (z.B. offene Referenzen). Also:
- Referenzen nur so oft öffnen wie nötig. Bei statischen Dingen (wie z.B. die Referenz auf immer das gleiche VI) reicht also einmaliges öffnen (und Speichern in einem Schieberegister o.ä.) aus.
- Geöffnete Referenzen auch wieder schließen - aber immer zum richtigen Zeitpunkt Smile
- Nutzereingaben sollte man nicht pollen, sondern per Eventstruktur bearbeiten.

Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
21.11.2013, 14:50
Beitrag #5

Blinky_Bill Offline
LVF-Grünschnabel
*


Beiträge: 14
Registriert seit: Sep 2013

2009
2013
kA



RE: SubVI Referenz blinkt ABER keine Fehlermeldung
Hi Gerd,

2) Sry, ich wollte meinen Beitrag auf das Problem fokussieren
und hab das wohl vergessen. Blush

4) Da hast du natürlich recht, aber da ich die 4 durch einen
ersetze erübrigt sich das.

5) Ok, das wusste ich nicht, aber das ist interessant. Sprich
mein "Referenz-Müll" türmt sich bis die Funktion letzendlich
ausfällt.

Ich hab das jetzt mal geändert und warte ab was passiert. Nach
spätestens 12h hatte ich bisher immer nen Ausfall. Construction


-> Was meinst du mit "pollen" ? Hab ich noch nicht gehört.

Danke dir erstmal. Gruß Bill
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
21.11.2013, 16:53
Beitrag #6

jg Offline
CLA & CLED
LVF-Team

Beiträge: 15.864
Registriert seit: Jun 2005

20xx / 8.x
1999
EN

Franken...
Deutschland
RE: SubVI Referenz blinkt ABER keine Fehlermeldung
VI-Referenz auf das "eigene" VI geht so schneller:
   
Gruß, Jens

Wer die erhabene Weisheit der Mathematik tadelt, nährt sich von Verwirrung. (Leonardo da Vinci)

!! BITTE !! stellt mir keine Fragen über PM, dafür ist das Forum da - andere haben vielleicht auch Interesse an der Antwort!

Einführende Links zu LabVIEW, s. GerdWs Signatur.
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
Anzeige
22.11.2013, 07:32
Beitrag #7

Morpheus Offline
LVF-Gelegenheitsschreiber
**


Beiträge: 205
Registriert seit: Jul 2009

2019 SP1, 2020 SP1
2005
EN

8000
Schweiz
RE: SubVI Referenz blinkt ABER keine Fehlermeldung
(21.11.2013 14:50 )Blinky_Bill schrieb:  -> Was meinst du mit "pollen" ? Hab ich noch nicht gehört.

Mit pollen bezeichnet man in der Informatik die Methode, das Ereignis einer Wertänderung mittels zyklischem Abfragen zu ermitteln. Sprich, eine Schleife (z.B. While-Loop) überwacht zyklisch den Wert eines Controls (oder Hardware, etc.).
Die Event-Struktur dagegen warte bis ein vom Programmierer definiertes Ereignis (z.B. Wertänderung) eintrifft und ist somit zu bevorzugen. Big Grin

Gruss
Chris
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
28.11.2013, 08:12
Beitrag #8

Blinky_Bill Offline
LVF-Grünschnabel
*


Beiträge: 14
Registriert seit: Sep 2013

2009
2013
kA



RE: SubVI Referenz blinkt ABER keine Fehlermeldung
Hi,

also nach ausführlicher Ausführung kann ich nun mit ziemlicher Sicherheit sagen, dass es an einer
Referenz lag, die ständig geöffnet wurde. Erstmal vielen Dank.

Zur Eventstruktur: würde mir das hier denn wirklich einen Vorteil bringen? Wenn ich das richtig verstanden hab
tritt die Aktion (hier "Werte ins Diagramm schreiben") bei Änderung der Größe (hier Temperatur) auf. Die Temperatur
an einem Thermoelement schwankt unentwegt. Ob ich nun eine Schleife mit einer bestimmten Wartezeit oder
eine Eventstruktur benutze kommt bei den Abarbeitungszyklen sicher aufs gleiche raus.


Grüße Bill
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
Antwort schreiben 


Möglicherweise verwandte Themen...
Themen Verfasser Antworten Views Letzter Beitrag
  Übergabe einer Referenz vom HauptVI in das SubVI alan 1 3.730 09.03.2015 16:11
Letzter Beitrag: jg
  SubVi - Referenz Refnum vescon 2 5.259 01.10.2014 08:44
Letzter Beitrag: vescon
  Array Element als Referenz von Referenz Benjamin Fuchs 15 20.572 18.02.2014 11:56
Letzter Beitrag: RabenFlug
  Xcontrol: Übergabe Referenz an SubVI kwakz 2 3.907 07.08.2013 12:45
Letzter Beitrag: kwakz
  kann keine strict type def Referenz mehr erstellen GT123 2 4.001 11.06.2013 13:34
Letzter Beitrag: GT123
  SubVI-Eigenschaften über Referenz aus HauptVI heraus beeinflussen (als Exe) dereinzug 6 6.107 28.08.2012 16:55
Letzter Beitrag: Falk

Gehe zu: