55 votos

-[MyClassName copyWithZone:] no reconocido selector enviado a instancia

Mi aplicación se estrelló con la razón:

-[MyClassName copyWithZone:] no reconocido selector enviado a la instancia

Tengo dos clases. Digamos que Clase1 y Clase2.

Class1 parece:

Class1.h

@interface Class1 : NSObject {
    NSString *imagemd5CheckSum;
    UIImage *image;
    NSData *fileChunkData;
}

@property (nonatomic, copy)NSString *imagemd5CheckSum;
@property (nonatomic, copy)UIImage *image;
@property (nonatomic, copy)NSData *fileChunkData;

@end

Class1.m

@implementation Class1

@synthesize image;
@synthesize fileChunkData;
@synthesize imagemd5CheckSum;

-(id) init{
    [self setImage:nil];
    [self setFileChunkData:nil];
    [self setImagemd5CheckSum:@""];

    return self;
}

-(void)dealloc{
    [imagemd5CheckSum release];
    [image release];
    [fileChunkData release];

    fileChunkData = nil;
    imagemd5CheckSum = nil;
    image = nil;

    [super dealloc];
}
@end

**

Class2 parece

**

Class2.h


#import "Class2.h"
@interface Class2 : NSObject {
    Class1 *obj1;
    Class1 *obj2;
    Class1 *obj3;
}

@property (nonatomic, copy)Class1 *obj1;
@property (nonatomic, copy)Class1 *obj2;
@property (nonatomic, copy)Class1 *obj3;

@end

Class2.m


@implementation Class2

@synthesize obj1,obj2,obj3;

-(id) init{
    [self setObj1:nil];
    [self setObj2:nil];
    [self setObj3:nil];

    return self;
}

-(void)dealloc{
    [obj1 release];
    [obj2 release];
    [obj3 release];

    obj1 = nil;
    obj2 = nil;
    obj3 = nil;

    [super dealloc];
}
@end

Se Estrelló Situación

Class2 *class2 = [[Class2 alloc] init];

Class1 *class1 = [[Class1 alloc] init];

[class1 setImagemd5CheckSum:@"this is md5"];
[class1 setImage:myimage];
[class1 setFileChunkData:myData];

[class2 setObj1:class1]; // This line is crashed..

...

Cuando llamé [class2 setObj1:class1];, la aplicación se estrelló con razón:

-[Class1 copyWithZone:] no reconocido selector enviado a la instancia

¿Cómo puedo solucionar este problema?

73voto

Wevah Puntos 17636

Su -setObj1: método se declara como copy , por lo que llama -copy en su Class1 objeto. -copy llama a -copyWithZone:nil . Así que cualquiera necesita implementar el NSCopying Protocolo (que significa implementar -copyWithZone: ), o cambiar su propiedad de copy a retain .

53voto

Mathew Varghese Puntos 2535

Para hacer su clase de responder a copyWithZone:, usted tiene que aplicar el NSCopying protocolo en su clase. Y se debe reemplazar la copyWithZone: método.

Por ejemplo:

Primero usted tiene que aplicar el NSCopying protocolo en su declaración de interfaz.

@interface MyObject : NSObject <NSCopying>

A continuación, reemplazar el copyWithZone método como,

- (id)copyWithZone:(NSZone *)zone
{
    id copy = [[[self class] alloc] init];

    if (copy)
    {
        // Copy NSObject subclasses
        [copy setVendorID:[[self.vendorID copyWithZone:zone] autorelease]];
        [copy setAvailableCars:[[self.availableCars copyWithZone:zone] autorelease]];

        // Set primitives
        [copy setAtAirport:self.atAirport];
    }

    return copy;
}

Me alegro si esto le ayuda.

(Referencia)

-1voto

shturm64 Puntos 24

He tenido este problema cuando estaba tratando de hacer algo como esto:

[self.textView setText : MyNonStringClassObject];

Iteramos.com

Iteramos es una comunidad de desarrolladores que busca expandir el conocimiento de la programación mas allá del inglés.
Tenemos una gran cantidad de contenido, y también puedes hacer tus propias preguntas o resolver las de los demás.

Powered by:

X