unexpected value for nargout when returning a class/struct

4 vues (au cours des 30 derniers jours)
Markus Leuthold
Markus Leuthold le 10 Juin 2014
What values for nargout would you expect for the last two lines in the run block: 0 or 1?
Class A
classdef A < handle
methods
function r=fctA(~)
disp(['nargout=' num2str(nargout)])
r=B;
end
end
end
Class B
classdef B < handle
methods
function fctB(~,~)
end
end
end
run
a=A;
a.fctA.fctB;
a.fctA.fctB(1);
  2 commentaires
Matt J
Matt J le 10 Juin 2014
Modifié(e) : Matt J le 10 Juin 2014
I think the bigger surprise is that you can directly dot-index the output of a function call. Since when has that been possible????
Markus Leuthold
Markus Leuthold le 10 Juin 2014
Modifié(e) : Markus Leuthold le 10 Juin 2014
it only works with methods from new-style classes (classdef). Following code doesn't work, as you've expected:
function r=fcn
r.value=1;
end
this won't work
fcn.value
Even worse, this code crashes Matlab:
function matlabcrash
mytest.value
function a=mytest
a.value=1;
end
end
So I'm asking myself if dot-index the output of a method is illegal as well and only works by coincidence?

Connectez-vous pour commenter.

Réponses (1)

Philip Borghesani
Philip Borghesani le 11 Juin 2014
Modifié(e) : Philip Borghesani le 11 Juin 2014
In general you cannot index into the output of a function call in MATLAB.
You have found an under documented feature of dot indexing on objects and a bug in that feature. The ability to index into the output of a dot function call on MATLAB class objects leaked into a previous version. This ability has always existed for Java objects. Because this feature just worked in many places it has been frequently exploited in MATLAB code and removing it would be quite difficult making supporting it necessary. In general we believe that the following code is more conformant MATLAB code for calling a method and will have similar performance:
a=A;
Bobj=fctA(a);
fctB(Bobj);
Nargout in your example code should be 1 and this is fixed in a future version of MATLAB. Note that a.fctA().fctB also returns 1.
I have entered a bug report for the crash with a nested function but I would not expect that code to be legal MATLAB code in the foreseeable future.
Information stated here is not an official guarantee of support or statement of policy from MathWorks.

Catégories

En savoir plus sur Argument Definitions dans Help Center et File Exchange

Produits

Community Treasure Hunt

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

Start Hunting!

Translated by