Inputname statement - useful example

1 vue (au cours des 30 derniers jours)
Gennaro Arguzzi
Gennaro Arguzzi le 29 Mai 2017
Commenté : Walter Roberson le 29 Mai 2017
Hi everyone,
could you help me to understand what is the useful of the inputname statement? I run the following example:
function c = somma(a, b)
disp(inputname(1))
c = a + b;
in workspace:
x = 1;
y = 2;
somma(x, y) %x is the result
From my example is not clear the useful of inputname. If you have a best example, let me know please.
Thank you.
  1 commentaire
Stephen23
Stephen23 le 29 Mai 2017
Modifié(e) : Stephen23 le 29 Mai 2017
In general it is not useful: the names that variables have inside and outside of functions should be totally irrelevant from outside and inside respectively.

Connectez-vous pour commenter.

Réponse acceptée

Walter Roberson
Walter Roberson le 29 Mai 2017
inputname() is useful for giving error messages that reference variable names in the form the user knowns them.
  4 commentaires
Gennaro Arguzzi
Gennaro Arguzzi le 29 Mai 2017
Walter, unfortunately matlab shows the following errors:
tryme(1)
Error using exist The optional second input to exist must be 'var', 'builtin', 'class', 'dir' or 'file'.
Error in tryme (line 2) if ~exist('var1', 'variable') isempty(var1) ndims(var1) ~= 3
Walter Roberson
Walter Roberson le 29 Mai 2017
function tryme(var1)
if ~exist('var1', 'var') || isempty(var1) || ndims(var1) ~= 3
varname = inputname(1);
if isempty(varname); varname = 'first input'; end
error('%s must be a 3D array', varname);
end

Connectez-vous pour commenter.

Plus de réponses (2)

Jan
Jan le 29 Mai 2017
The command inputname is not useful. The name of a variable should not matter. Some inputs do not even have a name, e.g. in: somma(1, 2) or somma(x+1, y+2).
There are some rare situations, where the name is useful, e.g. when you want to display a variable.
I'm programming for many years now and was never faced with the need of using inputname. If the name of a value matters, I create a struct, which carries the name in an extra field.

dpb
dpb le 29 Mai 2017
I don't know as I have a directly useful real example on hand, and in general functions shouldn't rely on needing outside knowledge for their use, but one could imagine places in which what the function should do depends on what the variable passed is.
A totally generic routine for reading some data could by this mechanism create a labeled output of the inputs if it were called with different arguments at different points in the code. One could envision this particularly in cases using the dreaded eval in the calling routine so that the calling routine actually is also variable.
I would NOT recommend this as a common practice; it's there for those rare situations that might call for it.
  2 commentaires
Stephen23
Stephen23 le 29 Mai 2017
"One could envision this particularly in cases using the dreaded eval in the calling routine"
The inputname documentation explicitly warns against this: "Avoid using inputname in the critical path of code or to obtain variable names to be used with commands such as eval, evalin, and assignin. This use of inputname can lead to code that is difficult to maintain."
dpb
dpb le 29 Mai 2017
Oh, yeah, did say it is "the dreaded eval" and I meant that explicitly, NOT tongue-in-cheek. I was just trying to come up with a reason why one could need to retrieve a name from the caller in the callee, not recommending same.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Startup and Shutdown dans Help Center et File Exchange

Tags

Aucun tag saisi pour le moment.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by