Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/cocoa/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Objective c 使用分布式对象时NSPortTimeoutException_Objective C_Cocoa_Gnustep - Fatal编程技术网

Objective c 使用分布式对象时NSPortTimeoutException

Objective c 使用分布式对象时NSPortTimeoutException,objective-c,cocoa,gnustep,Objective C,Cocoa,Gnustep,我使用分布式对象进行进程间通信。我正在运行一台服务器和四个客户端实例,但我得到了NSPortTimeoutException。我想将客户端对象存储在服务器上,以便客户端之间进一步通信。 //客户端代码 int main(int argc, char *argv[]) { NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; ClientCode *client = [[ClientCode alloc] init]; /* G

我使用分布式对象进行进程间通信。我正在运行一台服务器和四个客户端实例,但我得到了NSPortTimeoutException。我想将客户端对象存储在服务器上,以便客户端之间进一步通信。
//客户端代码

int main(int argc, char *argv[])
{
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];

ClientCode *client = [[ClientCode alloc] init];

/* Get the proxy */
id <myProtocol> proxy = (id <myProtocol>)[NSConnection rootProxyForConnectionWithRegisteredName: @"DirectoryServer" host:nil usingNameServer: [NSSocketPortNameServer sharedInstance]];

if ([proxy conformsToProtocol:@protocol(myProtocol)]) {
    NSLog(@"YES");
}
else {
    NSLog(@"NO");
}

NSString *recDataFromServer = [proxy print: client];
NSLog(@"%@", recDataFromServer);
/* Release the pool */
[pool release]
return 0;
}

@protocol myProtocol
-(NSString *)print : (id)client;
@end
@interface ClientCode : NSObject {


}
@end
@implementation ClientCode

-(void)startClient
{
NSLog(@"server called me");
}
@end
输出@server

2011-10-11 20:50:36.095 DistributedServer[54579:1303] client calling.....
2011-10-11 20:50:36.098 DistributedServer[54579:1303] client calling.....
2011-10-11 20:50:36.100 DistributedServer[54579:1303] client calling.....
2011-10-11 20:50:36.102 DistributedServer[54579:1303] client calling.....
2011-10-11 20:50:36.115 DistributedServer[54579:1303] (
    "<ClientCode: 0x100111250>",
    "<ClientCode: 0x100111250>",
    "<ClientCode: 0x100111250>",
    "<ClientCode: 0x100111250>"
)

有没有关于如何修复NportTimeoutException的想法?

NportTimeoutException
是因为我正在保存client@server的对象,而不是在客户端终止后删除该对象。现在我的代码工作正常。

NSPortTimeoutException
即将到来,因为我正在保存client@server的对象,而不是在客户端终止后删除该对象。现在我的代码运行良好

2011-10-11 20:50:35.415 client[54606:903] called
2011-10-11 20:50:35.424 client[54606:903] (null)
2011-10-11 20:50:35.420 client[54608:903] called
2011-10-11 20:50:35.425 client[54608:903] (null)
2011-10-11 20:50:35.424 client[54607:903] called
2011-10-11 20:50:35.428 client[54607:903] (null)
2011-10-11 20:50:35.434 client[54609:903] called
2011-10-11 20:50:35.437 client[54609:903] (null)
2011-10-11 20:50:36.091 client[54606:903] YES
2011-10-11 20:50:36.093 client[54609:903] YES
2011-10-11 20:50:36.093 client[54607:903] YES
2011-10-11 20:50:36.094 client[54608:903] YES
2011-10-11 20:50:36.098 client[54606:903] server called me
2011-10-11 20:50:36.103 client[54608:903] server called me
2011-10-11 20:50:36.117 client[54608:903] parag
2011-10-11 20:50:36.119 client[54609:903] server called me
2011-10-11 20:50:36.125 client[54607:903] server called me
2011-10-11 20:50:36.127 client[54606:903] parag
2011-10-11 20:50:36.125 client[54609:903] *** Terminating app due to uncaught exception 'NSPortTimeoutException', reason: '[NOTE: this exception originated in the server.]
[NSPortCoder sendBeforeTime:sendReplyPort:] timed out (10340039236.124821 340039236.124922) 1'
*** Call stack at first throw:
(
    0   CoreFoundation                      0x00007fff825487b4 __exceptionPreprocess + 180
    1   libobjc.A.dylib                     0x00007fff84d95f03 objc_exception_throw + 45
    2   Foundation                          0x00007fff86416483 -[NSConnection sendInvocation:internal:] + 4304
    3   CoreFoundation                      0x00007fff8251a98c ___forwarding___ + 860
    4   CoreFoundation                      0x00007fff82516a68 _CF_forwarding_prep_0 + 232
    5   client                              0x0000000100000d4f main + 307
    6   client                              0x0000000100000c14 start + 52
    7   ???                                 0x0000000000000001 0x0 + 1
)
2011-10-11 20:50:36.095 DistributedServer[54579:1303] client calling.....
2011-10-11 20:50:36.098 DistributedServer[54579:1303] client calling.....
2011-10-11 20:50:36.100 DistributedServer[54579:1303] client calling.....
2011-10-11 20:50:36.102 DistributedServer[54579:1303] client calling.....
2011-10-11 20:50:36.115 DistributedServer[54579:1303] (
    "<ClientCode: 0x100111250>",
    "<ClientCode: 0x100111250>",
    "<ClientCode: 0x100111250>",
    "<ClientCode: 0x100111250>"
)
2011-10-11 20:53:54.514 client[54801:903] called
2011-10-11 20:53:54.518 client[54801:903] (null)
2011-10-11 20:53:54.521 client[54800:903] called
2011-10-11 20:53:54.526 client[54800:903] (null)
2011-10-11 20:53:54.516 client[54804:903] called
2011-10-11 20:53:54.526 client[54804:903] (null)
2011-10-11 20:53:54.529 client[54803:903] called
2011-10-11 20:53:54.533 client[54803:903] (null)
2011-10-11 20:53:54.955 client[54803:903] YES
2011-10-11 20:53:54.956 client[54800:903] YES
2011-10-11 20:53:54.956 client[54801:903] YES
2011-10-11 20:53:54.956 client[54804:903] YES
2011-10-11 20:53:54.961 client[54804:903] server called me
2011-10-11 20:53:54.963 client[54801:903] server called me
2011-10-11 20:53:54.964 client[54801:903] parag
2011-10-11 20:53:54.965 client[54800:903] server called me
2011-10-11 20:53:54.966 client[54800:903] parag
2011-10-11 20:53:54.966 client[54804:903] parag
2011-10-11 20:53:54.969 client[54803:903] server called me
2011-10-11 20:53:54.970 client[54803:903] parag