zoukankan      html  css  js  c++  java
  • 《从零开始学Swift》学习笔记(Day 30)——选择类还是结构体呢?

    原创文章,欢迎转载。转载请注明:关东升的博客

    类和结构体非常相似,很多情况下没有区别。如果你是设计人员在进行系统设计时候,是将某种类型设计成为类还是结构体? 

    类和结构体异同:

    类和结构体都有如下功能:

    •    定义存储属性
    •    定义方法
    •    定义下标
    •    定义构造函数
    •    定义扩展
    •    实现协议 

    只有类才有的功能:

    •    能够继承另外一个类
    •    能够核对运行期对象的类型
    •    析构对象释放资源
    •    引用计数允许一个实例有多个引用 

    选择的原则:

    结构体是值类型,每一个实例没有独一无二的标识,下面两个数组实例本质上没有区别,他们可以互相替换。

    var studentList1: [String]  = ["张三","李四","王五"]
    
    var studentList2: [String]  = ["张三","李四","王五"]

    但是我们提到类时候,它是引用类型,每个实例都有独一无二的标识。我们看看下面员工Employee类代码:

    class Employee {
    
        var no   = 0      
    
        var name = "" 
    
        var job = ""  
    
        var salary = 0.0
    
    } 
    
    var emp1  =  Employee()
    
    emp1.no = 100
    
    emp1.name = "Tom"
    
    emp1.job = "SALES"
    
    emp1.salary = 9000 
    
    var emp2  =  Employee()
    
    emp2.no = 100
    
    emp2.name = "Tom"
    
    emp2.job = "SALES"
    
    emp2.salary = 9000

    emp1和emp2两个员工实例即便内容完全相同,但是这不能说明他们就是同一个员工,只是相似而已。每一个员工实例的背后都有独一无二的标识。

    我们再来看看部门Department结构体。

    struct Department {
    
        var no: Int = 0
    
        var name: String = ""
    
    } 
    
    var dept1 = Department()
    
    dept1.no = 20
    
    dept1.name = "Research" 
    
    var dept2 = Department()
    
    dept2.no = 20
    
    dept2.name = "Research"

    Department为什么被设计成为结构体而不是类呢,那要看我们对于两个不同部门的理解是什么,如果具有相同的部门编号(no)和部门名称(name),我们就认为他们是两个相同的部门,那么就可以把Department定义为结构体,这一点与员工Employee不同。

    欢迎关注关东升新浪微博@tony_关东升。
    关注智捷课堂微信公共平台,了解最新技术文章、图书、教程信息
                              ​
    更多精品iOS、Cocos、移动设计课程请关注智捷课堂官方网站:http://www.zhijieketang.com
    智捷课堂论坛网站:http://51work6.com/forum.php

  • 相关阅读:
    oracle 查询判断语句
    C#后台调用oracle存储过程,参数传入的是clob字段,怎样处理
    devexpress chart 弧度曲线图
    回车键提交与不提交表单的解决方法
    ajax请求在ie下返回undefined
    [PhpStorm]找回Excluded后的目录
    javasript之toString怪异的情况
    强制页面不缓存
    [争论]localhost与127.0.0.1的区别
    Windows下创建空名文件夹
  • 原文地址:https://www.cnblogs.com/iOS-Blog/p/4930032.html
Copyright © 2011-2022 走看看