[CIContext initWithOptions:]: непризнанный селектор, отправленный в экземпляр 0x170400960 в xcode8

выполняется в ios8.3, но запуск в ios9 или 10 не имеет этой проблемы.

-[CIContext initWithOptions:]: unrecognized selector sent to instance 0x170400960
2016-09-19 18:08:21.025 *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[CIContext initWithOptions:]: unrecognized selector sent to instance 0x170400960'
*** First throw call stack:
(0x186d8c2d8 0x1985b00e4 0x186d933a4 0x186d90154 0x186c92ccc 0x1001c1e74 0x1001c1b7c 0x1001c143c 0x1001c1cfc 0x100311e0c 0x1003116d0 0x1001d7690 0x101f3025c 0x101f2fc08 0x101eee29c 0x103db8fd4 0x103db8f94 0x103dbdc28 0x186d437f8 0x186d418a0 0x186c6d2d4 0x1904836fc 0x18b832fac 0x100401fd8 0x198c2ea08)
libc++abi.dylib: terminating with uncaught exception of type NSException

Ответ 1

Если вы посмотрите отчет о сбое, кажется, что Xcode 8 имеет некоторую проблему, конвертирующую метод Swift CIContext(options: [String : Any]?) в его Objective-C копию + (CIContext *)contextWithOptions:(NSDictionary<NSString *,id> *)options;.

Вместо этого он преобразуется как -[CIContext initWithOptions:], следовательно, непризнанный селектор.

Возможным обходным путем является объявление категории Objective-C следующим образом:

@interface CIContext (Workaround)

+ (CIContext *)yourprefix_contextWithOptions:(NSDictionary<NSString *, id> *)options;

@end

@implementation CIContext (Workaround)

+ (CIContext *)yourprefix_contextWithOptions:(NSDictionary<NSString *, id> *)options {
    return [CIContext contextWithOptions:options];
}

@end

Затем импортируйте эту категорию в заголовок моста моста и замените исходный вызов init CIContext на тот, который указан в этой категории.

Я предполагаю, что это проблема компиляции, которая может быть исправлена ​​с помощью обновления Xcode. Тем временем это решение может оказаться полезным.