在 OSX 收到应用程序启动通知
Get notified of application launch on OSX
我希望在 Mac OSX 启动应用程序时收到通知。我找到了 Cocoa Application Finished Launch,这似乎回答了我的问题,但是当启动 Preview get 时,回调方法 appDidLaunch
没有被调用。
这是我目前的情况,
#import <Foundation/Foundation.h>
#import <Appkit/Appkit.h>
@interface test_case: NSObject
-(void)run;
@end
@implementation test_case: NSObject
- (void)appDidLaunch:(NSNotification*)note
{
NSLog(@"app launched: %@", [note userInfo]);
}
-(void)run {
[[[NSWorkspace sharedWorkspace] notificationCenter] addObserver:self selector:@selector(appDidLaunch:) name:NSWorkspaceDidLaunchApplicationNotification object:nil];
[[NSWorkspace sharedWorkspace] openFile:@"/Users/nah/Desktop/bsd_hacks.pdf"
withApplication:@"Preview"];
}
@end
int main(int argc, const char * argv[]) {
@autoreleasepool {
test_case * t = [[test_case alloc] init];
[t run];
}
return 0;
}
那么为什么 appDidLaunch
没有被调用?
您的应用程序在您有机会收到通知之前结束执行(退出 main
函数)。此外,您需要正确设置主 运行 循环来处理通知。通常,NSApplicationMain
调用会为您完成所有应用程序设置。因此,解决问题的最简单方法是 main
函数的下一个更改:
int main(int argc, const char * argv[]) {
@autoreleasepool {
test_case * t = [[test_case alloc] init];
[t run];
return NSApplicationMain(argc, argv);
}
}
我希望在 Mac OSX 启动应用程序时收到通知。我找到了 Cocoa Application Finished Launch,这似乎回答了我的问题,但是当启动 Preview get 时,回调方法 appDidLaunch
没有被调用。
这是我目前的情况,
#import <Foundation/Foundation.h>
#import <Appkit/Appkit.h>
@interface test_case: NSObject
-(void)run;
@end
@implementation test_case: NSObject
- (void)appDidLaunch:(NSNotification*)note
{
NSLog(@"app launched: %@", [note userInfo]);
}
-(void)run {
[[[NSWorkspace sharedWorkspace] notificationCenter] addObserver:self selector:@selector(appDidLaunch:) name:NSWorkspaceDidLaunchApplicationNotification object:nil];
[[NSWorkspace sharedWorkspace] openFile:@"/Users/nah/Desktop/bsd_hacks.pdf"
withApplication:@"Preview"];
}
@end
int main(int argc, const char * argv[]) {
@autoreleasepool {
test_case * t = [[test_case alloc] init];
[t run];
}
return 0;
}
那么为什么 appDidLaunch
没有被调用?
您的应用程序在您有机会收到通知之前结束执行(退出 main
函数)。此外,您需要正确设置主 运行 循环来处理通知。通常,NSApplicationMain
调用会为您完成所有应用程序设置。因此,解决问题的最简单方法是 main
函数的下一个更改:
int main(int argc, const char * argv[]) {
@autoreleasepool {
test_case * t = [[test_case alloc] init];
[t run];
return NSApplicationMain(argc, argv);
}
}