Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
564 views
in Technique[技术] by (71.8m points)

matlab - Difference of handle and values classes

I have some C++ background and want to use classes in Matlab.

What is the difference between a handle and a value class?

I know that I would use a value class if I wanted to define a matrix class with overloaded operators such as "+" and "*". However, sometimes it seems that things only work for me as I want when I pick a handle class.

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

The MathWorks provide some information on which to be used for which purpose in their help and also in their PDF documentation. I've also found this article from the Yagtom Project (originally by Matt Dunham) to be a great introduction to OOP in MATLAB.

In the help this was explained as follows (emphasis mine):

MATLAB support two kinds of classes — handle classes and value classes. The kind of class you use depends on the desired behavior of the class instances and what features you want to use.

Use a handle class when you want to create a reference to the data contained in an object of the class, and do not want copies of the object to make copies of the object data. For example, use a handle class to implement an object that contains information for a phone book entry. Multiple application programs can access a particular phone book entry, but there can be only one set of underlying data.

The reference behavior of handles enables these classes to support features like events, listeners, and dynamic properties.

Use value classes to represent entities that do not need to be unique, like numeric values. For example, use a value class to implement a polynomial data type. You can copy

In the article by Matt Dunham, another good point is made to distinguish both types of classes:

We previously mentioned that objects in Matlab are, (by default) passed by value, meaning that full copies are passed back and forth in method calls. Matlab graphics objects, however, are passed by reference, (via handles). If we subclass the built in handle class [...] then objects of our class will be passed by reference too, not value.

I personally tend to use handle classes to get some of the syntax I'm used to with Java: for a handle class, you can have the object store all information, such that you can have operations like sort(a) (or a.sort()) be performed in place. For value classes the equivalent of this is a = sort(a) (or a = a.sort()). For operators the first syntax makes no sense at all, but the second is obviously in general use: e.g. a = a + b (this is equivalent to a = plus(a,b) and a = a.plus(b)).

  • If the main concern of your class is to store (numeric) values of some kind and to be able to perform operations, the value class is most likely the way to go.
  • If you want to store a state, group related values, connect different objects together (linked lists, graphs, ...), the handle class might be the way to go.

Or at least, that's what I tend to use to make the distinction.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...