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 

LVOOP im Kommen!



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!

17.03.2010, 11:09
Beitrag #11

abrissbirne Offline
LVF-Stammgast
***


Beiträge: 480
Registriert seit: Aug 2007

LV2009, LV2010
2007
EN

66123
Deutschland
LVOOP im Kommen!
' schrieb:Ein wichtiger Aspekt der OOP-Programmierung ist eben die "Ableitbarkeit". Und das entsprechend "anwenderfreundlich" zu gestalten bedarf eben bestimmter Mechanismen (siehe oben diese abstrakten Methoden sowie weitere Mechanismen). Diese Mechanismen sind in LVOOP, so wie es aussieht, aber noch nicht gelöst.
Doch ist es. Es funktioniert ähnlich wie die in C++ als virtuell deklarierten Funktionen. Des ganze nennt sich dynamic dispatching. Dort wird zur laufzeit die Methode bestimmt.
LVOOP Webcast
Schau dir ab 36:32 zum Thema dynamic dispatching an.
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
Anzeige
17.03.2010, 11:14
Beitrag #12

Y-P Offline
☻ᴥᴥᴥ☻ᴥᴥᴥ☻
LVF-Team

Beiträge: 12.612
Registriert seit: Feb 2006

Developer Suite Core -> LabVIEW 2015 Prof.
2006
EN

71083
Deutschland
LVOOP im Kommen!
Ich sehe immer noch keinen Sinn in LVOOP. Ich kann doch mit SubVIs und herkömmlicher Programmierung nicht weniger und nicht umständlicher programmieren als mit LVOOP. Bei LVOOP muss man beim Programmieren doch komplett umdenken. Wobei ich muss sagen, ich habe das in C++ schon nicht richtig verstanden. Darum werde ich es auch weiterhin meiden.

Gruß Markus

--------------------------------------------------------------------------
Bitte stellt mir keine Fragen über PM, dafür ist das Forum da - andere haben vielleicht auch Interesse an der Antwort !!
--------------------------------------------------------------------------
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
17.03.2010, 11:17
Beitrag #13

cb Offline
LVF-SeniorMod


Beiträge: 1.731
Registriert seit: Feb 2006

2018SP1
2001
EN

40xxx
Deutschland
LVOOP im Kommen!
' schrieb:Allerdings stellt für mich OOP noch etwas anderes, wichtiges bereit. OOP sollte eine komplexe Programmieraufgabe abstrahieren und in logische Objekte unterteilen. Dann kann der Entwickler bzw. das Entwicklerteam in Objekten "denken" was die Entwicklung vereinfacht. Es wird leichter OOP Code zu schreiben, ihn zu skalieren oder zu warten. Das ist für mich ein riesen Vorteil gegenüber herkömmlicher Programmierung.

das ist letztenendes eine Geschmacks-Frage, aber ich stimme in dem Punkt "IchSelbst" zu, genau diese Abstraktion, bzw. dieses Denken in Modulen löse ich im Moment durch FGVs und parallel laufende State-Machines, die in der Art wie sie funktionieren einem Objekt in C++ sehr nahe kommen, aber leider halt keine Vererbung etc. bieten.

Für mich bedeutet OOP:
--> Wikipedia-Artikel: Objektorientierte Programmierung

und an dieses Leitbild kommt man mit der Methode FGV+parallel laufende State Machine deutlich näher ran (leider, leider halt ohne Vererbung) als mit LVOOP

so sieht bei mir ein Hauptprogramm (der RT-Teil aus):
   

und so sieht es in einem Modul aus:
   

http://www.rotabench.com - rotierende Prüfstände nach dem Baukasten-Prinzip
Webseite des Benutzers besuchen Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
17.03.2010, 11:28 (Dieser Beitrag wurde zuletzt bearbeitet: 17.03.2010 11:29 von abrissbirne.)
Beitrag #14

abrissbirne Offline
LVF-Stammgast
***


Beiträge: 480
Registriert seit: Aug 2007

LV2009, LV2010
2007
EN

66123
Deutschland
LVOOP im Kommen!
' schrieb:Für mich bedeutet OOP:
--> Wikipedia-Artikel: Objektorientierte Programmierung
Aus Wikipedia:
Die objektorientierte Programmierung (kurz OOP) ist ein auf dem Konzept der Objektorientierung basierendes Programmierparadigma. Die Grundidee dabei ist, Daten und Funktionen, welche auf diese Daten angewandt werden können, möglichst eng in einem sogenannten Objekt zusammenzufassen und nach außen hin zu kapseln, so dass Methoden fremder Objekte diese Daten nicht versehentlich manipulieren können.

Das ist mit FGV's eben nicht gegeben. Schon der erste Satz lässt sich mit den herkömmlichen LV Mitteln nur schwer (umständlich) realisieren.

Ich möchte LVOOP nicht als das Allerheilmittel darstellen, aber ich finde einige Aspekte sehr interessant.
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
17.03.2010, 11:33
Beitrag #15

Y-P Offline
☻ᴥᴥᴥ☻ᴥᴥᴥ☻
LVF-Team

Beiträge: 12.612
Registriert seit: Feb 2006

Developer Suite Core -> LabVIEW 2015 Prof.
2006
EN

71083
Deutschland
LVOOP im Kommen!
Arbeitest Du in der Marketing-Abteilung von NI? HeheTongue

Gruß Markus

' schrieb:Aus Wikipedia:
Die objektorientierte Programmierung (kurz OOP) ist ein auf dem Konzept der Objektorientierung basierendes Programmierparadigma. Die Grundidee dabei ist, Daten und Funktionen, welche auf diese Daten angewandt werden können, möglichst eng in einem sogenannten Objekt zusammenzufassen und nach außen hin zu kapseln, so dass Methoden fremder Objekte diese Daten nicht versehentlich manipulieren können.

Das ist mit FGV's eben nicht gegeben. Schon der erste Satz lässt sich mit den herkömmlichen LV Mitteln nur schwer (umständlich) realisieren.

Ich möchte LVOOP nicht als das Allerheilmittel darstellen, aber ich finde einige Aspekte sehr interessant.

--------------------------------------------------------------------------
Bitte stellt mir keine Fragen über PM, dafür ist das Forum da - andere haben vielleicht auch Interesse an der Antwort !!
--------------------------------------------------------------------------
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
17.03.2010, 11:40
Beitrag #16

IchSelbst Online
LVF-Guru
*****


Beiträge: 3.689
Registriert seit: Feb 2005

11, 14, 15, 17, 18
-
DE

97437
Deutschland
LVOOP im Kommen!
' schrieb:Die Grundidee dabei ist, Daten und Funktionen, welche auf diese Daten angewandt werden können, möglichst eng in einem sogenannten Objekt zusammenzufassen
Geht hervorragend mit SubVIs. Ich denke mir mein MainVI mit seinen SubVIs als Objekt. Diese SubVIs gibt es nur für dieses MainVI.

Zitat:nach außen hin zu kapseln
Meine FGVs enthalten diverse Daten, alles in Schieberegistern, die keineswegs von außen zugänglich sind. Demzufolge sind sie gekapselt.

Zitat:so dass Methoden fremder Objekte diese Daten nicht versehentlich manipulieren können
Richtig! Ein weiterer schwerwiegender Punkt, warum eine Kapselung (nicht zwangsweise OOP) gemacht werden soll. Es gibt keine Möglichkeit von außerhalb, meine gekapselten Daten im FGV zu manipulieren!

Zitat:Das ist mit FGV's eben nicht gegeben. Schon der erste Satz lässt sich mit den herkömmlichen LV Mitteln nur schwer (umständlich) realisieren.
Ich konnte alle meine Wünsche - Kapselung von Daten und Methoden - alles mit FGV's machen.

Naja gut, vielleicht sollte ich mal sagen, dass meine FGV's eher zu einer Klasse ausarten. Sie haben nämlich Propertys (hinter einem Property kann eine Methode stehen!) und können Daten entgegennehmen und liefern - wenn sie denn wollen.

Jeder, der zur wahren Erkenntnis hindurchdringen will, muss den Berg Schwierigkeit alleine erklimmen (Helen Keller).
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
Anzeige
17.03.2010, 12:34
Beitrag #17

cb Offline
LVF-SeniorMod


Beiträge: 1.731
Registriert seit: Feb 2006

2018SP1
2001
EN

40xxx
Deutschland
LVOOP im Kommen!
' schrieb:Das ist mit FGV's eben nicht gegeben. Schon der erste Satz lässt sich mit den herkömmlichen LV Mitteln nur schwer (umständlich) realisieren.

aber sicher doch, GENAU DAS ist bei meinem "Modul" Modell gegeben:

alle Daten die das Modul betreffen sind in den Schieberegistern der While-Schleife gespeichert. Der einzige Weg um die Daten in den SRs zu manipulieren ist über die Queue eine "Methode" (=State) aufzurufen, der irgendwas mit den Daten macht. Besser kann man in LV Daten momentan gar nicht kapseln.

Das gleiche gilt für FGVs: auch da sind alle Daten, die die FGV betreffen in den Schieberegistern der selbigen gespeichert. Ein Zugriff von Außen ist nur möglich in dem man die FVG mit dem entsprechenden State "aufruft". Das ist genauso als würde man bei einem Objekt eine Methode aufrufen, die irgendwas mit den Members macht ... da besteht KEIN Unterschied!

' schrieb:Ich möchte LVOOP nicht als das Allerheilmittel darstellen, aber ich finde einige Aspekte sehr interessant.

jau, ich finde es im Prinzip auch sehr interessant, aber das was es ATM kann reicht mir halt nicht um es effizient in der Produktion einsetzen zu können, das finde ich sehr schade ... aber in der Werbung wird so getan als wär es das Allheilmittel ... und desswegen bin ich - fürnehm ausgedrückt: slightly pissed off!

http://www.rotabench.com - rotierende Prüfstände nach dem Baukasten-Prinzip
Webseite des Benutzers besuchen Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
17.03.2010, 12:38
Beitrag #18

abrissbirne Offline
LVF-Stammgast
***


Beiträge: 480
Registriert seit: Aug 2007

LV2009, LV2010
2007
EN

66123
Deutschland
LVOOP im Kommen!
@ IchSelbst:
Hast du meinen Beitrag gesehen? Abstraktion ist mit LVOOP möglich.
' schrieb:Doch ist es. Es funktioniert ähnlich wie die in C++ als virtuell deklarierten Funktionen. Des ganze nennt sich dynamic dispatching. Dort wird zur laufzeit die Methode bestimmt.
LVOOP Webcast
Schau dir ab 36:32 zum Thema dynamic dispatching an.

@ All:
Leseberechtigung hat bei FGV's jedes VI egal ob von der gleichen "Klasse" oder nicht.
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
17.03.2010, 12:59
Beitrag #19

IchSelbst Online
LVF-Guru
*****


Beiträge: 3.689
Registriert seit: Feb 2005

11, 14, 15, 17, 18
-
DE

97437
Deutschland
LVOOP im Kommen!
' schrieb:@ IchSelbst: Hast du meinen Beitrag gesehen? Abstraktion ist mit LVOOP möglich.
Hab ich gesehen. Wenn du sagst, das geht, reicht mir das - vorerst. Wink

Zitat:Leseberechtigung hat bei FGV's jedes VI egal ob von der gleichen "Klasse" oder nicht.
Stimmt.
Aber: Wer lässt denn lesen? Nicht das VI. Der Programmierer! Der baut nämlich sein Programm auf. Und wenn der weis, dieses VI gehört dieser Klasse, und es trotzdem anders verwendet - ist der Programmierer Schuld. Nicht das VI. Eine FGV kann zwar von anderen VIs gelesen werden - wird aber nicht, weil der Programmierer nicht will.

Auch bei OOP muss sich der Programmierer an Vorschriften halten. Man muss Variablen innerhalb einer Klasse nicht zwingend private definieren und per Property ansprechen. Man sollte. Man kann alle Variablen und Methoden public machen - nur: dann ist auch hier bei OOP der Sinn verfehlt.

Jeder, der zur wahren Erkenntnis hindurchdringen will, muss den Berg Schwierigkeit alleine erklimmen (Helen Keller).
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
17.03.2010, 13:06 (Dieser Beitrag wurde zuletzt bearbeitet: 17.03.2010 13:09 von Y-P.)
Beitrag #20

Y-P Offline
☻ᴥᴥᴥ☻ᴥᴥᴥ☻
LVF-Team

Beiträge: 12.612
Registriert seit: Feb 2006

Developer Suite Core -> LabVIEW 2015 Prof.
2006
EN

71083
Deutschland
LVOOP im Kommen!
Wenn ich das alles so lese, bin ich froh, dass ich mit meiner Meinung nicht alleine dastehe. Big Grin
So wie id2x und IchSelbst (und auch ich nach Bedarf) verfahren, so wird es bei NI auch bei den Schulungen beigebracht.
Und wie (in einem anderen Thread) schon mal gesagt, wird LVOOP nicht mal vom Referenten des Advanced 1 - Lehrgangs verwendet.
Dort wurde uns gesagt, dass man zwar LVOOP verwenden kann, aber das ALLES auch mit den "normalen" LabVIEW-Programmiermethoden erreicht werden kann. LVOOP ist im Prinzip nur eine Spielerei, die man verwenden kann, aber nicht muss, weil es problemlos auch anders geht.
Und wieso sollte man sich in irgendwas einarbeiten, wenn man das andere schon kann.

Gruß Markus

EDIT: Interessehalber werde ich mir aber vielleicht trotzdem mal die neue Schulung zu LVOOP anhören, die ja offensichtlich geplant ist. Vielleicht gibt es sie aber auch schon.

--------------------------------------------------------------------------
Bitte stellt mir keine Fragen über PM, dafür ist das Forum da - andere haben vielleicht auch Interesse an der Antwort !!
--------------------------------------------------------------------------
Alle Beiträge dieses Benutzers finden
Diese Nachricht in einer Antwort zitieren to top
30
Antwort schreiben 


Möglicherweise verwandte Themen...
Themen Verfasser Antworten Views Letzter Beitrag
  CS++ - A LVOOP Actor based Framework BNT 18 30.309 14.03.2015 14:26
Letzter Beitrag: BNT
  LVOOP und DAQmx - Resource ist reserviert Sundypha 2 10.411 13.08.2012 12:42
Letzter Beitrag: Sundypha
  Neuling, was bringen mir Klassen, LVOOP dali4u 6 18.377 24.02.2012 13:40
Letzter Beitrag: Kiesch
  LVOOP - wann wird Kopie erstellt? Kiesch 7 14.889 21.10.2011 14:23
Letzter Beitrag: Kiesch
Information LVOOP-Anfänger, Kommentar zu Programm Martin Heller 11 25.247 09.03.2011 14:32
Letzter Beitrag: Martin Heller
  LVOOP-Beispiel - Stimmt das so? Matze 12 26.573 29.06.2010 13:14
Letzter Beitrag: jg

Gehe zu: