我曾经在我的类NSObject构造函数中使用以下代码来使用Objective-c:-(id)init{self=[superinit];returnself;}我如何在Swift中使用它?我试着这样做:overrideinit(){self=super.init()returnself;}我遇到了两个错误:cannotassignvalueselfisimmutablenilistheonlyreturnvaluepermittedinthisinitializer 最佳答案 您不能在Swift中分配给self。只需使用super.
我很好奇在您的init方法中是否有调用方法来设置类的实例属性。本质上我只是有一个子类UIView的类,在init中添加了一些subview,其中一些subview是该类的实例变量。classMyView:UIView{varcollectionView:UICollectionViewconvenienceinit(){self.init(frame:CGRectZero)}overrideinit(frame:CGRect){super.init(frame:frame)addSubviews()}requiredinit(coderaDecoder:NSCoder){super.i
我想将一个func链接到superimpl,如下所示classBaseClass{funcmyFunc(){//dosomething}}classMyClass:BaseClass{overridefuncmyFunc(){self.myOtherFunc(completionHandler:{super.myFunc()//error:'super'memberscannotbereferencedinanon-classtype})}...}编译错误其实很清楚的告诉了我原因:闭包不是类类型,是不允许的。寻找任何建议如何调用父类(superclass)中定义的方法?
我有以下代码:classILProperty{varvalue:T?init(_value:T){self.value=value}}typealiasILStringProperty=ilStringPropertyclassilStringProperty:ILProperty{}letx=ILStringProperty("X")最后一行是编译错误:'ILStringProperty'cannotbeconstructedbecauseithasnoaccessibleinitializers如果我覆盖初始化:overrideinit(_value:String){super.i
我是swift的新手,我不明白如何初始化一个类。成功在类定义中被初始化为falseif(succeeded&&(time>1000)){errormessage+=";connectionslow"}时间初始化为time=data[3].toInt()数据在哪里vardata=split(raw_data){$0==","}而raw_data是一个字符串。类定义:classgeocodeObject:NSObject{init定义:init(lat:String,long:String,userstate:String){(没有任何类型的super初始化)完整的代码与切入方式:clas
如果我有一个swift子类:不需要访问self不需要访问self的任何属性我还需要在子类的init()方法中调用super.init()吗?*注意:这是一个不同于提问和回答的问题hereonSO因为上面1和2中列出的细节。 最佳答案 不,你不必。假设您有以下类(class)。classa{letname:Stringinit(){name="james"}}classb:a{lettitle:Stringoverrideinit(){title="supervisor"}}如果你用实例化一个变量让myVar=b()然后,overri
在UIViewController中,这段代码:publicoverridefuncsupportedInterfaceOrientations()->UIInterfaceOrientationMask{ifletmainController=self.mainViewController{returnmainController.supportedInterfaceOrientations}returnUIInterfaceOrientationMask.all}给出错误Methoddoesn'toverrideanymethodfromitssuperclass我使用的是Xcod
每个人都告诉我“使用super.viewDidLoad()因为它就是那样”或者“我一直都是这样做的,所以保持它”,“如果你不调用super是错误的”等等。overridefuncviewDidLoad(){super.viewDidLoad()//otherstuffgoeshere}我只找到了一些关于Objective-C案例的主题,它们并不是很有启发性,但我是在Swift3中开发的,所以任何专家都可以给我一个很好的详细解释吗?这是一个很好的实践案例还是有任何隐藏的影响? 最佳答案 通常,为您覆盖的所有没有返回值的函数调用supe
此代码在第一个XCode6Beta上运行,但在最新的Beta上无法运行并出现此类错误必须调用父类(superclass)SKSpriteNode的指定初始化程序:importSpriteKitclassCreature:SKSpriteNode{varisAlive:Bool=false{didSet{self.hidden=!isAlive}}varlivingNeighbours:Int=0init(){//throws:mustcalladesignatedinitializerofthesuperclassSKSpriteNodesuper.init(imageNamed:"b
考虑这两个类:classA{varx:Intinit(x:Int){self.x=x}convenienceinit(){self.init(x:0)}}classB:A{init(){super.init()//Error:Mustcalladesignatedinitializerofthesuperclass'A'}}我不明白为什么不允许这样做。最终,每个类的指定初始值设定项都会用它们需要的任何值调用,所以为什么我需要通过为指定默认值在B的init中重复自己x再次,当A中的便利init可以正常工作时? 最佳答案 这是Swift