unexpected value for nargout when returning a class/struct

1 Ansicht (letzte 30 Tage)
Markus Leuthold
Markus Leuthold am 10 Jun. 2014
Bearbeitet: Philip Borghesani am 11 Jun. 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 Kommentare
Matt J
Matt J am 10 Jun. 2014
Bearbeitet: Matt J am 10 Jun. 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 am 10 Jun. 2014
Bearbeitet: Markus Leuthold am 10 Jun. 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?

Melden Sie sich an, um zu kommentieren.

Antworten (1)

Philip Borghesani
Philip Borghesani am 11 Jun. 2014
Bearbeitet: Philip Borghesani am 11 Jun. 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.

Kategorien

Mehr zu Argument Definitions finden Sie in Help Center und File Exchange

Produkte

Community Treasure Hunt

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

Start Hunting!

Translated by