Jump to content

Re-entrant VI: beyond the wiki basics


Recommended Posts

Posted

OK, so I read the Labview wiki on re-entrant VIs. And it gives a few useful examples of when to use or avoid re-entrancy. But what about everyday workhorse VIs? For example, MultiColumnSort.vi (thanks again, JFM). I use this pretty often, occasionally with large data sets, and I could easily see where two of my threads might be trying to use it simultaneously.

post-4616-1191929660.png?width=400

Should I make it re-entrant just in case? And similarly for all potentially large number-crunching operations?

What about database communication VIs? Say I've got a mid-level VI that opens a connection to an Oracle database, reads a table, and closes the connection, and I use this mid-level VI all over the place. Make it re-entrant?

In general: any good rules of thumb, not already contained in the aforementioned wiki, would be appreciated.

Posted

QUOTE(torekp @ Oct 9 2007, 01:40 PM)

In general: any good rules of thumb, not already contained in the aforementioned wiki, would be appreciated.

I'm no expert but as far as I know a VI with only primitives (like yours) can easily be set reentrant since there aren't subVIs that are loaded into memory.

Ton

Posted

QUOTE(tcplomp @ Oct 9 2007, 08:21 AM)

I'm no expert but as far as I know a VI with only primitives (like yours) can easily be set reentrant since there aren't subVIs that are loaded into memory.

Ton

Rules of thumb can change with the passage of time.

The "Old-Timer" in me says "Oh No!" since setting VI's that could use a lot of memory as re-entrant could result in big blocks of memory being allocated for those VI instances and becoming un-available for the rest of the application.

But now that memory no longer requires crochet hooks to build, and since people are starting to expect fast results (how long do YOU wait before you hit ctrl-alt-del?) the re-entrancy setting can help.

Just my thoughts...

Ben

Posted

quick follow up question:

i never tried reentrant with uninitialised shift register.

how to recover a specific copy of the LV2 in such case? is there any other way than keeping a reference to each vi call?

Posted

QUOTE(Gabi1 @ Oct 9 2007, 08:49 AM)

quick follow up question:

i never tried reentrant with uninitialised shift register.

how to recover a specific copy of the LV2 in such case? is there any other way than keeping a reference to each vi call?

Well aside from the obvious of having the VI simply in a BD and accessing that particular instance from there, no! Unlike non-reentrant VIs where the name of a VI is enough to reopen a VI reference to it, reentrant VIs maintain their data space attached to the VI instance (reference) and once you loose such a reference you loose the data space.

But then using reentrant VIs through VI Server is usually more trouble than it is worth so I personally wouldn't really do it.

Rolf Kalbermatter

Posted

QUOTE(rolfk @ Oct 9 2007, 04:03 PM)

But then using reentrant VIs through VI Server is usually more trouble than it is worth so I personally wouldn't really do it.

thanks Rolfk. do you mean you would not do reentrant LV2, and keep separate names? i kind of see an interresting recursive solution for these...altough it might not worth the trouble.

Posted

QUOTE(Gabi1 @ Oct 9 2007, 09:18 AM)

thanks Rolfk. do you mean you would not do reentrant LV2, and keep separate names? i kind of see an interresting recursive solution for these...altough it might not worth the trouble.

Yes I do mean that and it's because of what you mention in your last sentence. A lot of work to create something which is hard to debug, maintain and use. I have some experience with this but with templates, since reentrancy was not possible for dynamic VIs back then. And it is a pain in the ###### whenever I have to go back and change something about it and then consequently test it too.

Rolf Kalbermatter

Posted

QUOTE(torekp @ Oct 9 2007, 04:40 AM)

Just in case? Just in case of what? What will happen if it's not re-entrant?

QUOTE(torekp @ Oct 9 2007, 04:40 AM)

...Say I've got a mid-level VI that opens a connection to an Oracle database, reads a table, and closes the connection, and I use this mid-level VI all over the place. Make it re-entrant?

How does it work now? Is it broken? I would assume the answer is no. Everything works just fine doesn't it?

Re-entrancy is overated. In fact, it may make break a perfectly working program. Normal (non re-entrant) VI's provide Mutexing for free. Most people forget this and end up adding a lot more code to get something that a standard VI provides for free.

My rule of thumb is, don't use reentrant VI's unless you are having serious timing issues with parallel processes waiting too long to access a common VI. There are also other use case that can only be done with re-entrant VI's. For example recursion, cloned front panels etc. other uses are common subVI's used in XControls.

QUOTE(torekp @ Oct 9 2007, 04:40 AM)

In general: any good rules of thumb, not already contained in the aforementioned wiki, would be appreciated.

Reminder to all. If you participate in a forum thread and realize that something you are discussing should go on the LabVIEW Wiki, then put it in the LabVIEW Wiki. Even if it's incomplete, others will fill in the gaps.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.