Анонимные классы могут быть реализованы с помощью библиотеки.Несколько месяцев назад я работал над MMMutableMethods
fork, чтобы улучшить старую реализацию (обсуждая с автором) и добавить свой собственный механизм без каких-либо манипуляций во время выполнения obj-c.
https://github.com/k06a/MMMutableMethods
A,Первый механизм работает над созданием класса среды выполнения obj-c:
MM_CREATE(MM_REUSE,^(Class class){
[class addMethod:@selector(onResultWithId:)
fromProtocol:@protocol(AMCommandCallback)
blockImp:^(id this,id res){
NSLog(@"onResultWithId: %@",res);
}];
[class addMethod:@selector(onErrorWithJavaLangException:)
fromProtocol:@protocol(AMCommandCallback)
blockImp:^(id this,JavaLangException *e){
NSLog(@"onErrorWithJavaLangException: %@",e);
}];
})
B.Второй механизм работает с простой реализацией пересылки сообщений:
MM_ANON(^(MMAnonymousClass *anon){
[anon addMethod:@selector(onResultWithId:)
fromProtocol:@protocol(AMCommandCallback)
blockImp:^(id this,id res){
NSLog(@"onResultWithId: %@",res);
}];
[anon addMethod:@selector(onErrorWithJavaLangException:)
fromProtocol:@protocol(AMCommandCallback)
blockImp:^(id this,JavaLangException *e){
NSLog(@"onErrorWithJavaLangException: %@",e);
}];
})
Первый создает новые классы obc-j во время выполнения, он позволяет создавать классы MM_CREATE_CLASS(MM_REUSE, *)
и непосредственно экземпляры с MM_CREATE(MM_REUSE, *)
.Классы будут создаваться только при первом выполнении и повторно использоваться по умолчанию, но вы можете избежать повторного использования, вызывая MM_CREATE_CLASS_ALWAYS(*)
и MM_CREATE_ALWAYS(*)
.
Второй механизм не создает никаких экземпляров времени выполнения, просто запомните блоки для селекторови переадресация вызовов методов к ним.
Я предпочитаю второй способ не создавать много классов во время выполнения.ИМХО, это гораздо безопаснее и достаточно мощно.
Чтобы использовать эту библиотеку, просто:
pod 'MMMutableMethods', :git => 'https://github.com/k06a/MMMutableMethods'