Swift 数组,字典,结构体,枚举

   2023-02-09 学习力0
核心提示:1.数组let types = ["none","warning","error"]//省略类型的数组声明var menbers = [String]()//声明空数组menbers.append("six")//添加元素menbers += ["seven"]//添加元素menbers.insert("one", at: 0)//指定位置添加元素menbers[0] = "m

1.数组

let types = ["none","warning","error"]//省略类型的数组声明
        var menbers = [String]()//声明空数组
        menbers.append("six")//添加元素
        menbers += ["seven"]//添加元素
        menbers.insert("one", at: 0)//指定位置添加元素
        menbers[0] = "message"//通过下标修改元素
        menbers[0...2] = ["message","banana","orange"]//通过区间修改元素
        print(types)
        print(menbers)
        print(menbers.count)//数组个数
        print(menbers.isEmpty)//数组是否为空
        menbers.swapAt(1, 2)//元素之间交换
        //menbers.remove(at: 2)//删除某一个元素
        //menbers.removeLast()//删除最后一个元素
        let addStringArr = types + menbers
        //数组遍历
        for value in addStringArr {
            print("\(value)")
        }
        //元祖遍历
        for (index,value) in menbers.enumerated() {
            print("索引:\(index) 数据:\(value)")
        }
        
        //过滤数组元素
        let newTypes = types.filter { (item) -> Bool in
            return item.count < 6
        }
        print(newTypes)
        
        //创建包含100个元素的数组
        let items = Array(0..<100).map{ "条目\($0)"}
        print(items)

 

//2.0 字典
        //var emptyDict = [String : Int]()//空字典
        //声明一个字典
        var myDict = ["name":"hangge","url":"hangge.com"]
        myDict["address"] = "china" //添加/修改字典
        myDict.removeValue(forKey: "name")//删除某一个key
        myDict["name"] = nil //删除某一个key值
        //字典的key,value
        print(myDict.keys,myDict.values)
        //遍历字典
        for (key,value) in myDict {
            print("\(key):\(value)")
        }
        //顾虑字典元素
        let dict2 = myDict.filter { (item) -> Bool in
            return item.value.count < 7
        }
        print(dict2)
        
        //通过元祖创建字典
        let duplicatesArray = [("Monday",30),("Tuesday",25),("Wednesday",27),("Sunday",29)]
        let dic = Dictionary(duplicatesArray, uniquingKeysWith: min)
        print(dic)
        
        //合并字典
        var dict1 = ["one":10,"two":20]
        //merge 合并
        let tuples = [("one",5),("three",30)]
        dict1.merge(tuples, uniquingKeysWith: min)
        print("dict:\(dict1)")
        //merging 合并
        let dict3 = dict1.merging(tuples, uniquingKeysWith: min)
        print("dict2:\(dict3)")
        
        //字典不存在时,指定默认值
        let dict4 = ["apple":1,"banana":2]
        var orange : Int
        if let value = dict4["orange"] {
            orange = value
        }else {
            orange = 0
        }
        let longan = dict4["longan",default:0]
        
        print(orange)
        print(longan)
//创建一个结构体
        struct BookInfo {
            var id : Int = 0
            var name : String = "default"
            var authord : String = "default"
        }
        var book1 : BookInfo //默认构造器创建结构体
        var book2 : BookInfo = BookInfo.init(id: 0021, name: "航哥", authord: "hanggge")
        book1 = book2
        book2.id = 1234
        print(book1,book2)
        
        //枚举
        enum Compasspoint {
            case north
            case south
            case east
            case west
        }
        let directionTohead = Compasspoint.east
        print(directionTohead)
        
        enum Planet : Int {
            case mercury = 1
            case venus = 2
            case earth = 3
        }
        let earthsorder = Planet.earth
        print(earthsorder)
        
        enum Direction {
            case up
            case down
            func description() -> String {
                switch self {
                case .up:
                    return "向上"
                case .down:
                    return "向下"
                }
            }
        }
        print(Direction.up.description())

 

//默认构造器
class Student{
    var name : String = ""
    var number : Int = 0
}
//自定义构造函数
class Person{
    //雷属性
    var name:String
    var age:Int
    //类构造函数
    init(newName:String,newAge:Int) {
        self.name = newName
        self.age = newAge
    }
    //实例函数
    func say() -> String {
        return "我叫MT\(name)"
    }
}
class People {
    //普通属性
    var firstName:String = ""
    var lastName:String = ""
    var nickName:String = ""
    
    //计算属性
    var fullName:String {
        get {
            return nickName + " " + firstName + " " + lastName
        }
    }
    //带属性监视器普通属性
    var age:Int = 0 {
        //属性变化前
        willSet{
            print("will set an new value\(age) to age")
        }
        didSet{
            print("age file change form \(oldValue) to \(age)")
            if age < 10 {
                nickName = "Little"
            }else{
                nickName = "Big"
            }
        }
    }
    func toString() ->String{
        return "Full name \(fullName) +_ age\(age)"
    }
}
/*结构体运用*/
struct Account {
    var amount:Double = 0.0
    var owner:String = ""
    //修饰静态方法
    static var interestRate:Double = 0.668
    static func interestBy(amount:Double) ->Double{
        return interestRate * amount
    }
}
class Account_class {
    var amount:Double = 0.0
    var owner:String = ""
    
    class var staticProp: Double {
        return 0.668
    }
    class func interestBy(amount:Double) ->Double{
        return staticProp * amount
    }
}

 

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • swift 命令行工具初探
    亲爱的同学们好,今天我们要介绍这么一个东西。相信有过解释型语言(PHP,Ruby,等)使用经验的同学会更加熟悉,就是 Swift 也为我们提供了命令行运行工具,俗称 REPL。好了,我们进入正题,在安装好 Swift 开发环境的机器上,打开命令行,输入 swift 命令,就进
    03-16
  • [Swift]冒泡排序 | Bubble sort
    [Swift]冒泡排序 | Bubble sort
    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs.com/strengthen/)➤GitHub地址:https://github.com/strengthen/LeetCode➤原文
    03-08
  • [Swift] 自定义在 SwiftUI 中实现的可搜索的外观
    [Swift] 自定义在 SwiftUI 中实现的可搜索的外
    首先我找遍了,似乎找不到任何信息......(我遇到了许多根本不起作用的事情......)终于在详细的英文文献中找到了,我会保留下来,希望以后有机会。关于 SwiftUI 中的可搜索searchable是iOS15新增的易于实现的搜索字段。关于这种情况有一个参数placement,您
    03-08
  • [Swift] 检测 SwiftUI ScrollView 中的偏移量
    [Swift] 检测 SwiftUI ScrollView 中的偏移量
    首先你可以用ScrollViewReader做一些可以从iOS14使用的事情。但是,我不能做我想做的事情,所以我想我还能做些什么。再次,可重复使用我尝试过了。执行我将首先发布实现的图像。 (Swift Playgrounds 演示)您可以像这样根据滚动获取坐标。让我们看看实现。1.
    03-08
  • Swift3.0 UICollectionView 删除,拖动
    Swift3.0 UICollectionView 删除,拖动
    UICollectionView实现了一下常见的新闻分类.  附有效果图 近期一直在深入学习swift,实现了CollectionView item的头东与删除,用的都是系统的一些函数方法,看起来比较直观. 第一步:class HotViewController: UIViewController,UICollectionViewDelegate,UICo
    02-09
  • swift -懒加载创建view
     // 只有外界访问到headerView的时候才会去执行闭包, 然后将闭包的返回值赋值给headerView    // 注意: 一定要记住闭包后面需要写上(), 代表执行闭包    //懒加载创建UIView    lazy var headerView: UIView = {        let view = UIView()
    02-09
  • Swift--非常好用的适合局部的代码约束
    // 哪个控件的哪个属性等于(大于、小于)另外一个控件的哪个属性乘以多少再加上多少 eg:let widthContraint = NSLayoutConstraint(item: messageLabel, attribute: NSLayoutAttribute.Width, relatedBy: NSLayoutRelation.Equal, toItem: nil, attribute: NSLa
    02-09
  • iOS打包framework - Swift完整项目打包Framework,嵌入OC项目使用
    iOS打包framework - Swift完整项目打包Framewor
    场景说明:-之前做的App,使用Swift框架语言,混合编程,内含少部分OC代码。-需要App整体功能打包成静态库,完整移植到另一个App使用,该App使用OC。-所以涉及到一个语言互转的处理,以及一些AppDelegate的代码减除变化。 --------------------------------
    02-09
  • Swift -- 官方文档Swift-Guides的学习笔记
    在经历的一段时间的郁闷之后,我发现感情都是虚伪的,只有代码是真实的(呸)因为看了swift语法之后依然不会用swift,然后我非常作死的跑去看官方文档,就是xcode里自带的help》documentation and API reference其中的swift里的guide这里主要总结一下里面每一
    02-09
  • Swift - 进度条(UIProgressView)的用法
     1,创建进度条1234var progressView=UIProgressView(progressViewStyle:UIProgressViewStyle.Default)progressView.center=self.view.centerprogressView.progress=0.5 //默认进度50%self.view.addSubview(progressView); 2,设置进度,同时有动画效果1p
    02-09
点击排行