Creating and using a dummy NSData subclass doesn't work

后端 未结 2 1830
逝去的感伤
逝去的感伤 2021-01-20 22:26

I have a problem with creating my own subclass of NSData, which I want to have a custom description method. Even creating a dummy NSData

2条回答
  •  天涯浪人
    2021-01-20 22:58

    Making an NSData subclass is difficult because (as drewag noted) it is a member of a class cluster. From the Binary Data Programming Guide:

    ...data objects are not actual instances of the NSData or NSMutableData classes but instead are instances of one of their private subclasses.

    When you do [[NSData alloc] initWith...] you don't get back an NSData; you probably get back an NSConcreteData. The extraordinary Cocoa With Love has a discussion and demonstration of subclassing class clusters.

    The best (and most idiomatic) option is probably composition: your custom class should simply contain an NSData ivar, and implement a description method that operates on that enclosed object.

    While drewag's response is technically correct, this is a dangerous technique to use on Cocoa classes; it will override the description method of every NSData object in the program, whether you create it directly or not.

    In the specific case of the description method this may be okay, but for another method more likely to be relied upon by other objects in the framework, it could cause large, hard-to-trace problems. You should only do this if you are sure that there is no other way.

    It would be far better to create a category and method with a prefix:

    @interface NSData (FX_Description) 
    - (NSString *)FX_description;
    @end
    

    The Apple docs specifically mention this category-override technique and advise against it:

    Because the methods declared in a category are added to an existing class, you need to be very careful about method names.

    If the name of a method declared in a category is the same as a method in the original class, or a method in another category on the same class (or even a superclass), the behavior is undefined as to which method implementation is used at runtime.

    An earlier version of the docs went on to say:

    The very presence of some category methods may cause behavior changes across all frameworks. For example, if you override the windowWillClose: delegate method in a category on NSObject, all window delegates in your program then respond using the category method; the behavior of all your instances of NSWindow may change. Categories you add on a framework class may cause mysterious changes in behavior and lead to crashes. [Emphasis mine.]

提交回复
热议问题