- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我一直遵循的规则是:
类头文件中的@MyClassName
&&
#import "MyClassName"在实现中
我现在决定子类化我的一个 View Controller 。如果我覆盖一个方法,那么我会收到以下消息:
类消息的接收者'MyClassName'是前向声明
为了克服这个问题,我需要将 #import 放入头文件中,这似乎没有遵循我认为的最佳实践。
如果我误解了 @class 的用法,谁能解释一下?
或者如果我做的正确,有人可以解释一下您需要打破最佳实践并在子类化时在头文件中使用#import 吗?
非常感谢。
编辑:
感谢您的回答。我想我需要添加更多细节来澄清我的情况并希望我的理解。这是我的基类的标题:
#import <UIKit/UIKit.h>
#import "CorePlot-CocoaTouch.h"
@class Organisation;
@interface LongCallDetailViewController : UIViewController <UITableViewDelegate, UITableViewDataSource>
在我的实现中我有
#import "Organisation.h"
我的子类头包含以下内容:
#import "LongCallDetailViewController.h"
@interface LongCallSubclassViewController : LongCallDetailViewController
@end
如果我重写子类中的方法并尝试使用组织对象,它会给我上面所述的错误。因此,我要么需要将#import "Organisation.h"添加到基类 header 中,要么将#import "Organisation.h"复制到子类实现文件中。这两个对我来说似乎都是错误的。
非常感谢。
最佳答案
在头文件中,您应该为您子类化的任何类导入其他头文件。您不需要为仅被引用而不是子类化的类导入头文件。例如,头文件可能如下所示:
#import "MySuperClass.h"
@class MyObjectType;
@interface MySubClass : MySuperClass
@property (strong) MyObjectType *value;
@end
编辑:根据您的新编辑,您似乎正在正确编写头文件。当你只声明 @class
在范围内,您将无法访问与该类关联的任何选择器或属性。可以用@class
声明在您不打算使用该类类型的选择器或属性而只是传递引用的地方(如我在上面描述的标题中所示),但是一旦您想对该对象执行任何其他操作,您将需要导入描述 @interface
的头文件.
定义 @class MyObjectType
时在头文件中,通常预期 #import "MyObjectType.h"
出现在关联的源文件中。头文件旨在作为结构声明,而源文件将包含实现。例如,与我上面描述的头文件关联的源文件可能如下所示:
#import "MySubClass.h"
#import "MyObjectType.h"
@implementation MySubClass
- (void)overriddenFunction {
[self.value anObjectTypeSelector];
}
@end
当它们在两个不同的范围内时,您不应该考虑“复制”导入语句。当你转发声明 @class Organisation
在你的LongCallDetailViewController
头文件,你将有一个 #import "Organisation.h"
在你的LongCallDetailViewController
源文件。如果您还需要在 LongCallSubclassViewController
中访问此对象的属性和选择器类,你需要#import "Organisation.h"
在你的LongCallSubclassViewController
实现文件。记住:实现文件不知道彼此的内容;他们只知道头文件的内容。
关于ios - 子类化 View Controller : Forward declaration,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26240206/
以下操作是否完全相同: request.setAttribute(name,"visited"); requestDispatcher.forward(request,response) 和
有两个 header 用于处理请求转发。首先是 X-Forwarded-For第二个是 Forwarded . 我应该使用哪一个? X-Forwarded-For 是事实上的,而 Forwarded
看the documentation for std::forward , template constexpr T&& forward( typename std::remove_reference
给定一个手电筒的nn.Module带有预前钩,例如 import torch import torch.nn as nn class NeoEmbeddings(nn.Embedding):
为了在我的 ASP.NET 应用程序中获取客户端 IP 地址,我使用了 X-Forwarded-For,并从列表中获取第一个 IP 地址(根据我找到的信息,有一个客户端,代理1、代理2..)。但我最近
以下 header 有什么区别? X 转发主机 X 转发服务器 在 Apache 作为代理、Tomcat 作为源服务器的设置中,我在到达 Tomcat 的 HTTP 请求中看到它们。值是(这是我自己的
假设我想要一个通用的高阶函数。最常见的方法是: 一个。通用 lambda auto F1 = [](auto f) { /*...*/ } B.函数模板 template auto F2(F&& f)
为了在我的 ASP.NET 应用程序中获取客户端 IP 地址,我使用了 X-Forwarded-For,并从列表中获取第一个 IP 地址(根据我找到的信息,有一个客户端,代理 1、代理 2 ..)。但
我有一个场景,我想使用 Context.Forward 将上下文转发到另一个对话框,它工作得很好。现在,如果我更新代码以获取对话框堆栈并使用 DialogStack.Forward,则会导致 Stac
我遇到了 std::forward 的两种变体与可变参数模板参数一起使用。 template void foo(Args&&... arga) { bar(std::forward(args
考虑 std::apply 的可能实现: namespace detail { template constexpr decltype(auto) apply_impl(F &&f, Tuple &
我在 Foo Controller 中有一个需要参数的 Action 方法: public function fooAction($one, $two) { $a = one; $b
这些功能是否等效? template void foo(T && t) { bar(std::forward(t)); } template void foo2(T && t) {
在建立从 Fedora 23 到 Centos 7 的 ssh 连接时,我遇到了一个不幸的问题。命令 ssh -X user@centos7和 ssh -Y user@centos7都打印 警告:没有
作为从 Struts 1.x 迁移到 Spring Boot 的一部分,我一直在努力正确转发应有的信息。 最初的 Struts 版本依赖于 web.xml,尽管我想将该项目转换为更新的、完全基于 Ja
我使用了net = cv2.dnn.readNetFromCaffe(protoFile, WeightsFile),然后循环播放实时视频帧以使用net.forward()") bre
我注册了域名 www.a.com 然后我将屏蔽(使用 GoDaddy)流量从 www.a.com 转发到 www.really.long.url.com,因此用户在访问我的网站时只会在地址栏中看到 w
我有一个域,例如 domain.org以及地址为 http://server/node/myname 的服务器上的托管空间. 我如何映射 domain.org至 http://server/node/
我有jsp,具体取决于我正在转发到另一个页面的某些条件。 我有/myjsp/first.jsp 其代码如下, 在这段代码中,if flow come to else 条件控
前向声明和前向引用有什么区别? 在我看来,前向声明是当你声明一个尚未实现的函数时,但这不正确吗?您是否必须查看特定情况以声明案例“前向引用”或“前向声明”? 最佳答案 一个 前向声明是在实现和使用方法
我是一名优秀的程序员,十分优秀!