DylanMuir/SimpleMap

版本 1.0.0.0 (21.3 KB) 作者: Dylan Muir
Handle class for storing a mapping between an index and arbitrary data
40.0 次下载
更新时间 2017/8/16

A matlab handle class for persistent storage of arbitrary data. Provides a mapping from a single subscript to arbitrary data.
Usage
-------
Create an empty map
>> smObj = SimpleMap
smObj =
SimpleMap containing 0 stored values, max index of 0.
Assign some data

>> smObj(1) = [1 2 3];
>> smObj(2) = 'a';
>> smObj(4) = {4 5 6}
smObj =
SimpleMap containing 3 stored values, max index of 4.
Extract the data

>> a = smObj(1);
>> b = smObj(3)
b =
[]
Find out which indices are used in the map

>> vbIndices = spy(smObj)
vbIndices =
1 1 0 1

>> find(smObj)
ans =
1 2 4
SimpleMaps are a handle class

>> smObj = SimpleMap; % Make a new empty SimpleMap
>> smObj2 = smObj; % Copy the SimpleMap object
>> smObj(1) = 'Map 1'; % Assign data to the first map
>> smObj2(1) % The data is also present in the copy
ans =
Map 1
The benefit of SimpleMap being a handle class, is to enable persistent data store within objects that are not themselves handle classes.

Using a SimpleMap for persistent data storage within a value class

classdef ValueClass
properties (Hidden)
smPersistent = SimpleMap;
end

methods
function fResult = LongCalculation(vcObj, nIndex)
% - Check whether the result has already been calculated
if (~isempty(vcObj.smPersistent(nIndex)))
fResult = vcObj.smPersistent(nIndex);
else
% - No, so compute the result from scratch
fResult = PerformLongCalculation(nIndex);

% - Cache the result
vcObj.smPersistent(nIndex) = fResult;
end
end
end
end

The property smPersistent will maintain data assigned to it from within methods of ValueClass, even though it is not a handle class. This is useful for internal hidden caching of results, not as useful for user-facing properties.

In the example above, a SimpleMap is used for "memoization" of the result of a long calculation. The result is cached, and this cache is maintained even though the object vcObj is not returned by the LongCalculation method.

This is most useful if the semantics of a class do not lend themselves to being a handle class.

引用格式

Dylan Muir (2024). DylanMuir/SimpleMap (https://github.com/DylanMuir/SimpleMap), GitHub. 检索来源 .

MATLAB 版本兼容性
创建方式 R2016a
兼容任何版本
平台兼容性
Windows macOS Linux
类别
Help CenterMATLAB Answers 中查找有关 Scope Variables and Generate Names 的更多信息

Community Treasure Hunt

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

Start Hunting!

无法下载基于 GitHub 默认分支的版本

版本 已发布 发行说明
1.0.0.0

Updated description
Updated description
Updated the image
Updated description
Updated description

Updated description

要查看或报告此来自 GitHub 的附加功能中的问题,请访问其 GitHub 仓库
要查看或报告此来自 GitHub 的附加功能中的问题,请访问其 GitHub 仓库