objective-c – 使用setReturnValue从NSInvocation返回NSString
发布时间:2020-12-16 09:50:55 所属栏目:百科 来源:网络整理
导读:当我将NSInvocation的返回值设置为NSString时,调用者正在接收NSCFString. 在我的情况下,我嘲笑从单元测试包含的文件中拉出一个包路径: [[[_bundlePartial stub] andDo:^(NSInvocation *invocation) { NSString* resourceName = [invocation getArgumentAtIn
当我将NSInvocation的返回值设置为NSString时,调用者正在接收NSCFString.
在我的情况下,我嘲笑从单元测试包含的文件中拉出一个包路径: [[[_bundlePartial stub] andDo:^(NSInvocation *invocation) { NSString* resourceName = [invocation getArgumentAtIndexAsObject:2]; NSString* type = [invocation getArgumentAtIndexAsObject:3]; NSString* path = [[NSBundle bundleForClass:self.class] pathForResource:resourceName ofType:type]; if (!path) { path = [_bundleOriginal pathForResource:resourceName ofType:type]; } [invocation setReturnValue:(void*)path]; }] pathForResource:OCMOCK_ANY ofType:OCMOCK_ANY]; 我称之为: NSString* jsonPathInBundle = [[NSBundle mainBundle] pathForResource:self.fileName ofType:self.fileExtension]; 不幸的是我回来了NSCFString.这是有道理的,因为我的NSString由NSCFString支持,但是当我丢失桥时,我不能再在对象上调用NSString实例方法.有没有办法可以将值作为NSString返回? 解决方法
在检查了OCMock代码后,我发现了我的问题.实际上是一个错字,但它的微妙,我不认为值得删除这个问题.
更改: [invocation setReturnValue:(void*)path]; 至: [invocation setReturnValue:&path]; 我最初的写作方式破坏了一层抽象,因为NSString被视为一个地址,而不是使用它的实际地址. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |