0

我正在为我的应用程序构建撤消/重做功能。我正在使用 NSUndoManager 的 NSInvocation 方法。

这就是我构建调用的方式

NSNumber *firstState = [NSNumber numberWithInt:fsNumber];
NSInvocation *initialState = [self restoreStateInvocation:firstState];
// ... the code continues...

这些是相关的方法

- (NSInvocation *) restoreStateInvocation:(NSNumber*)number {
  NSMethodSignature *executeMethodSignature = [self methodSignatureForSelector:
                                                 @selector(makeUNDO:)];
  NSInvocation *moveInvocation = [NSInvocation invocationWithMethodSignature: executeMethodSignature];
  [moveInvocation setTarget:self];
  [moveInvocation setSelector:@selector(makeUNDO:)];

  [moveInvocation setArgument:&number atIndex:2];
  return moveInvocation;
}


- (void) makeUNDO:(NSNumber*)number {

  int num = (int)[number intValue];
  // code crashes at this line... number appears to be deallocated at this time
  //
...
}

当 UNDO/REDO 调用 initialState 时,应用程序在 makeUNDO 的第一行崩溃,如代码所示。

如何保留号码而不泄漏?

谢谢。

4

2 回答 2

1

正确答案是将以下行添加到 restoreStateInvocation...

[moveInvocation retainArguments];
于 2011-05-31T04:05:14.907 回答
0

您可以保留NSNumber对象,因为它继承自NSObject.

NSNumber* myNumber = [number retain];

release完成使用myNumber后,您还需要这样做。

[myNumber release].

编辑:

使用下面描述的方法...

您可以将myNumber作为您的班级成员。

在.h

   @interface myClass {
     NSNumber* myNumber;
     }
     ............
     ............
     @property(nonautomic,retain)  NSNumber* myNumber;

     @end

在实现文件(.m 文件)中。

@implementation myClass 
@synthesize myNumber;

-(void) dealloc{

   if(myNumber)
   {
       [myNumber release];
       myNumber  = nil ;
   }
}

- (void) makeUNDO:(NSNumber*)number {

  self.myNumber  = nil;
  self.myNumber  = number;


  int num = (int)[self.myNumberintValue];
  NSLog(@"My Number -->%d", num )

  //
  ...
}
于 2011-05-31T03:43:29.460 回答