类的构造函数

简介: 类的构造函数
  • 1.构造函数的介绍


  • 构造函数类似于OC中的初始化方法:init方法
  • 默认情况下载创建一个类时,必然会调用一个构造函数
  • 即便是没有编写任何构造函数,编译器也会提供一个默认的构造函数。
  • 如果是继承自NSObject,可以对父类的构造函数进行重写


  • 2.构造函数的基本使用


  • 类的属性必须有值
  • 如果不是在定义时初始化值,可以在构造函数中赋值


class Person: NSObject {
var name : String
var age : Int
// 重写了NSObject(父类)的构造方法
   override init() {
   name = ""
   age = 0
 }
}
// 创建一个Person对象
let p = Person()


3.初始化时给属性赋值


  • 很多时候,我们在创建一个对象时就会给属性赋值
  • 可以自定义构造函数
  • 注意:如果自定义了构造函数,会覆盖init()方法.即不在有默认的构造函数
    class Person: NSObject {
    var name : String
    var age : Int


// 自定义构造函数,会覆盖init()函数
   init(name : String, age : Int) {
   self.name = name
   self.age = age
  }
}
// 创建一个Person对象
   let p = Person(name: "why", age: 18)


  • 4.字典转模型(初始化时传入字典)


  • 真实创建对象时,更多的是将字典转成模型
  • 注意:
  • 去字典中取出的是NSObject,任意类型.
  • 可以通过as!转成需要的类型,再赋值(不可以直接赋值)


class Person: NSObject {
var name : String
var age : Int
// 自定义构造函数,会覆盖init()函数
init(dict : [String : NSObject]) {
  name = dict["name"] as! String
  age = dict["age"] as! Int
 }
}
// 创建一个Person对象
   let dict = ["name" : "why3", "age" : 18] as [String : Any]
   let p3 = Person(dict: dict as! [String : NSObject])


  • 5.字典转模型(利用KVC转化)


  • 利用KVC字典转模型会更加方便
  • 注意:
  • KVC并不能保证会给所有的属性赋值
  • 因此属性需要有默认值
  • 基本数据类型默认值设置为0
  • 对象或者结构体类型定义为可选类型即可(可选类型没有赋值前为nil)


class Person: NSObject {
   // 结构体或者类的类型,必须是可选类型.因为不能保证一定会赋值
   var name : String?
   // 基本数据类型不能是可选类型,否则KVC无法转化
var age : Int = 0
// 自定义构造函数,会覆盖init()函数
init(dict : [String : NSObject]) {
// 必须先初始化对象
super.init()
// 调用对象的KVC方法字典转模型
setValuesForKeysWithDictionary(dict)
  }
}
// 创建一个Person对象
   let dict = ["name" : "why", "age" : 18]
   let p = Person(dict: dict)
  • 6.综合的使用


/*
 *  类的构造函数
 */
 class Person : NSObject{
 // 如果定义属性的时候没有初始化,那么必须在后面写上一个
 // swift要求,属性时必须有初始值的
 // 只要在构造函数中对属性进行了初始化,那么就不写?
 var name: String?
  /*
   * 如果是定义一个 “对象属性” 那么后面可以写上 ?
   * 如果是定义一个 “基本数据类型属性”,那么直接赋值为0
   * 因为supe.init()方法在分配存储空间的时候,如果发现属性是一个对象,并且是一个可选类型,那么会给这个属性分配存储空间
   * 但是如果属性是一个基本的数据类型,并且是可选类型,那么super.init()不会给该属性分配存储空间
   *
   */
 var age : Int?
 // 注意:如果自定义了构造方法,并且没有重写父类默认的构造方法
 // 那么默认的构造方法就会失效
 override init(){
  self.name = "joanking"
  self.age = 30
 }
// 自定义构造方法
// Swift 中有方法重载的概念
// 允许有同名的方法,只要形参或返回值不一样即可
init(name : String, age:Int) {
  self.name = name
  self.age = age
 }
 // KVC
 init(dict:[String : NSObject]) {
  super.init()
  // 注意点 : Swift 中如果想在构造方法中使用kvc给属性赋值
  // 那么在使用kvc之前必须调用super.init()
  // 调用super.init() 的目的是为了能在kvc赋值之前给属性分存储空间
  setValuesForKeys(dict)
  }
}
let p1 = Person()
print(p1.name!)


目录
相关文章
|
4月前
|
编译器 C++
【C++】详解构造函数
【C++】详解构造函数
|
6月前
|
编译器 C#
C#构造函数详解
C#构造函数详解
57 0
|
JavaScript 前端开发
构造函数。
构造函数。
32 1
|
6月前
|
编译器 C语言 C++
你想对构造函数说些什么?
你想对构造函数说些什么?
|
安全 C#
C#视频之构造函数
C#视频之构造函数
72 0
|
编译器 C++
<c++> 类的构造函数与类的析构函数
<c++> 类的构造函数与类的析构函数
93 0
|
编译器 C语言 C++
C嘎嘎~~[构造函数提升篇]
C嘎嘎~~[构造函数提升篇]
|
Java 编译器
[构造函数]构造函数是如何产生的?
[构造函数]构造函数是如何产生的?
构造函数
构造函数
59 1
|
Java C++
C++类中在构造器中调用本类的另外构造器
C++类中在构造器中调用本类的另外构造器
98 0