我正在使用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
仅仅因为该方法是静态的,并不意味着您可以使用它,就好像它是搜索路径中的单独函数一样.你需要打电话obj.getPropertyValue或FigureObjects.getPropertyValue代替.