在向方法发送单元格时,MATLAB中使用OOP的问题

Cel*_*dor 0 oop matlab class

我正在使用MATLAB中的OOP(面向对象编程)进行简单的测试.我做了一个包含构造函数的简单类.另外,我做了三个关于属性的部分:三个常规属性; 一个常数; 和三个依赖属性.我为常规属性包含了一些get/set方法,一个输出方法和一个构造函数使用的protected/Static方法:'getPropertyValue(propertyName,inputCell).

静态方法会导致问题.我发送两个参数:字符串类型的'propertyName'和单元格类型的'inputCell'.最后一个参数应该发送从构造函数中定义的varargin复制的所有输入参数.

当我尝试使用该类并在命令行中创建其实例时,

a = FigureObjects('promien',10)
Run Code Online (Sandbox Code Playgroud)

我收到此错误:

未定义的函数'getPropertyValue'用于'cell'类型的输入参数.

FigureObjects中的错误(第26行)[temp,status,msgStatus] = getPropertyValue('podstawa',inputCell);

我虽然可以发送任何功能,如字符串,单元格,矩阵等.有没有办法发送单元格到这个功能,并阅读其内容?

谢谢

PS.这是我的代码:

classdef FigureObjects
%FIGUREOBJECTS Summary of this class goes here
%   Detailed explanation goes here

properties
    podstawa
    wysokosc
    promien
end

properties (Constant = true, Hidden = true)
    liczbaPi = 3.14
end

properties (Dependent = true)
    obwodKola
    obwodProstokata
    obwodKwadratu
end

methods
    % Constructor
    function obj = FigureObjects(varargin)
        inputCell = varargin;
        if nargin > 0
            [temp,status,msgStatus] = getPropertyValue('podstawa',inputCell);
            if status
                obj.podstawa = temp;
            else
                error(msgStatus);
            end
            [temp,status,msgStatus] = getPropertyValue('wysokosc',inputCell);
            if status
                obj.wysokosc = temp;
            else
                error(msgStatus);
            end
            [temp,status,msgStatus] = getPropertyValue('promien',inputCell);
            if status
                obj.promien = temp;
            else
                error(msgStatus);
            end
        end
    end

    % get functions
    function obwodKola = get.obwodKola(obj)
        if ~isempty(obj.promien)
            obwodKola = 2*FigureObjects.liczbaPi*obj.promien;
        else
            error('''promien'' is not defined.');
        end
    end
    function obwodProstokata = get.obwodProstokata(obj)
        if (~isempty(obj.podstawa) && ~isempty(obj.wysokosc))
            obwodProstokata = 2*(obj.podstawa*obj + obj.wysokosc);
        else
            error('Either ''podstawa'' or/and ''wysokosc'' are not defined.');
        end
    end
    function obwodKwadratu = get.obwodKwadratu(obj)
        if ~isempty(obj.podstawa)
            obwodKwadratu = 4*obj.podstawa;
        else
            error('''podstawa'' is not defined.');
        end
    end
    function promien = get.promien(obj)
        promien = obj.promien;
    end
    function podstawa = get.podstawa(obj)
        podstawa = obj.podstawa;
    end
    function wysokosc = get.wysokosc(obj)
        wysokosc = obj.wysokosc;
    end

    % set functions
    function obj = set.promien(obj,promien)
        if isnumeric(promien)
            obj.promien = promien;
        else
            error('''promien'' must be numeric.');
        end
    end
    function obj = set.podstawa(obj,podstawa)
        if isnumeric(promien)
            obj.podstawa = podstawa;
        else
            error('''podstawa'' must be numeric.');
        end
    end
    function obj = set.wysokosc(obj,wysokosc)
        if isnumeric(wysokosc)
            obj.wysokosc = wysokosc;
        else
            error('''wysokosc'' must be numeric.');
        end
    end

    % output functions
    function output = obwod(theFigureObj, rodzajFigury)
        if strcmpi(rodzajFigury,'kolo')
            output = theFigureObj.obwodKola;
        elseif strcmpi(rodzajFigury,'prostokat')
            output = theFigureObj.obwodProstokata;
        elseif strcmpi(rodzajFigury,'kwadrat')
            output = theFigureObj.obwodKwadratu;
        else
            error('Cannot identify a figure.');
        end
    end % obwod
end % methods

methods (Access = protected, Static)
    function [propertyValue, status, msgString] = ...
            getPropertyValue(propertyName, inputCell)
        I = strcmpi(propertyName,inputCell);
        if sum(I) ~= 0
            if (find(I)+1) <= length(inputCell)
                propertyValue = inputCell{find(I)+1};
                status = true;
                msgString = 'No errors';
            else
                propertyValue = [];
                status = false;
                msgString = ['Too few arguments for ''' propertyName '''.'];
            end
        else
            propertyValue = [];
            status = false;
            msgString = ['No property ' propertyName];
        end
    end % getPropertyValue(propertyName, cellArray)
end % methods (Access = protected, Static)
Run Code Online (Sandbox Code Playgroud)

结束%classdef

wak*_*jah 6

仅仅因为该方法是静态的,并不意味着您可以使用它,就好像它是搜索路径中的单独函数一样.你需要打电话obj.getPropertyValueFigureObjects.getPropertyValue代替.