Инициализации свойств и установка одноразовых вычислений

В этом примере показано, как записать код, чтобы инициализировать и настроить Систему object™.

В этом примере вы выделяете ресурсы файла путем открытия файла, таким образом, Системный объект может записать в тот файл. Вы делаете эти, инициализация определяет задачу для одного времени во время настройки, а не каждый раз, когда вы запускаете объект.

Определение общественных собственностей, чтобы инициализировать

В этом примере вы задаете общедоступный Filename свойство и задает значение того свойства как ненастраиваемый вектор символов, default.bin. Пользователи не могут изменить свойства nontunable после setup метод был назван.

properties (Nontunable)
  Filename = "default.bin"
end

Определение частных собственностей, чтобы инициализировать

Пользователи не могут получить доступ к свойствам private непосредственно, но только через методы Системного объекта. В этом примере вы задаете pFileID свойство как частная собственность. Вы также задаете это свойство как hidden, чтобы указать, что это - внутреннее свойство, которое никогда не отображается пользователю.

properties (Hidden,Access = private)
  pFileID;
end

Определение Setup

Вы используете 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 метод, чтобы высвободить средства.

Полный файл определения класса с инициализацией и Setup

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

Смотрите также

| | |

Похожие темы