Этот пример показывает, как записать код, чтобы инициализировать и настроить Систему object™.
В этом примере вы выделяете ресурсы файла путем открытия файла, таким образом, Системный объект может записать в тот файл. Вы делаете эти, инициализация определяет задачу для одного времени во время настройки, а не каждый раз, когда вы запускаете объект.
В этом примере вы задаете общедоступное свойство Filename
и задаете значение того свойства как ненастраиваемый вектор символов, default.bin
. Пользователи не могут изменить свойства nontunable после того, как метод setup
был назван.
properties (Nontunable) Filename = "default.bin" end
Пользователи не могут получить доступ к свойствам private непосредственно, но только через методы Системного объекта. В этом примере вы задаете свойство pFileID
как частную собственность. Вы также задаете это свойство как hidden, чтобы указать, что это - внутреннее свойство, которое никогда не отображается пользователю.
properties (Hidden,Access = private)
pFileID;
end
Вы используете метод setupImpl
, чтобы выполнить задачи настройки и инициализации. Необходимо включать код в метод setupImpl
, который вы хотите выполнить только один раз. Метод setupImpl
называется однажды в первый раз, когда вы запускаете объект. В этом примере вы выделяете ресурсы файла путем открытия файла для записи двоичных данных.
methods function setupImpl(obj) obj.pFileID = fopen(obj.Filename,"wb"); if obj.pFileID < 0 error("Opening the file failed"); end end end
Несмотря на то, что не часть настройки, необходимо закрыть файлы, когда код сделан с помощью них. Вы используете метод releaseImpl
, чтобы высвободить средства.
classdef MyFile < matlab.System % MyFile write numbers to a file % These properties are nontunable. They cannot be changed % after the setup method has been called or the object % is running. properties (Nontunable) Filename = "default.bin" % the name of the file to create end % These properties are private. Customers can only access % these properties through methods on this object properties (Hidden,Access = private) pFileID; % The identifier of the file to open end methods (Access = protected) % In setup allocate any resources, which in this case % means opening the file. function setupImpl(obj) obj.pFileID = fopen(obj.Filename,'wb'); if obj.pFileID < 0 error("Opening the file failed"); end end % This System object writes the input to the file. function stepImpl(obj,data) fwrite(obj.pFileID,data); end % Use release to close the file to prevent the % file handle from being left open. function releaseImpl(obj) fclose(obj.pFileID); end end end
matlab.System Constructor
| releaseImpl
| setupImpl
| stepImpl