主要内容:字典、集合、数组排序

一、字典

演示样例:

name : @" 张三 " 。sex:@" 男 " ; age :@" 21 " ;

思考:怎么用字典保存?

字典:用于保存具有映射关系(key - value对)数据的集合,对于张三来说,key就是name,男来说。sex就是key

一个key - value对觉得是一个条目,字典是存储key - value对的容器

与数组不同,字典靠key存取元素,key不能反复,value必须是对象(value能够反复),键值对在字典中的存储是无序的

字典相同分为可变字典(NSMutableDictionary)、不可变字典(NSDictionary)

不可变字典(NSDictionary):

不可变字典一旦创建,键值对就不可更改、不可加入、不可删除,仅仅能读取key或者value

创建字典对象(三种方法):

便利构造器:NSDictionary  *dict1 = [ [ NSDictionary  dictionaryWithObjects : @[@"af", @"afaf", @"adada"]  forkeys : @[ @"first", @"second" , @"three"] ] ;

初始化方法:NSDictionary  *dict2 = [ [ NSDictionary  alloc] initWithObjectsAndKeys : @"first" , @"afdaf" ,

@"second" , @"afadx" ] ;

字面量:NSDictionary  *dict3 = @{@"first" : @"aex",

@"second" : @"af", } ;

经常用法:

1、获取全部的key值

[ dict1 allKeys ] ;

2、获取全部的value值

[ dict1  allValues ] ;

3、通过key值查询value

[ dict1  ObjectForKey : @"first" ] ;

可变字典(NSMutableDictionary):

不可变字典(NSDictionary)的子类

能够进行增删改查的操作

经常用法:

1、加入键值对

[ dict2  addEntriesFromDictionary : @{@"other" : @"afa" } ] ; / / 作用是将一个字典中的键值对放入还有一个字典中

[ dict2  setObject : @"other"  forKey : @"axea" ] ;

2、改动key相应的值

[ dict2  setObject : @"afas"  forKey : @"first" ] ;

3、删除键值对

[ dict2 removeObjectForKey : @"first" ] ;

[ dict2  removeAllObject ] ; / / 删除所有键值对

4、通过for循环遍历全部的键值对

for ( NSDictionary  *obj  int  dict3 ) {   / / 高速遍历方法

NSLog ( @" %@ " , obj) ; / / 高速遍历对字典来说,默认打印key值

}

二、集合

与数学中的集合一样,集合中的元素 “ 唯一 ”

元素是无序的,而且元素必须是对象,相同分为NSSet(不可变集合)、NSMutableSet(可变集合)

假设想从集合中取出元素,仅仅能随机取出一个

NSSet(不可变集合):

创建集合:NSSet  *sets = [ NSSet  setWithObjects : @"b" , @"c" , @"a", @"d", nil ] ;

经常用法:

1、获取元素个数    count

[ sets  count ] ;

2、获取集合中的一个元素       anyObject

[ sets  anyObject ] ;

3、推断集合中是否包括某个元素       containObject

[ sets  containsObject ] ;

三、集合类型的高速枚举

for ( <#type  *object#> in <#collection#>){

}

object是遍历得到的元素对象

collection是集合类型的对象:数组、字典、集合

特点:

数组枚举得到数组中的元素对象、

字典枚举得到字典中的key值、

集合枚举得到集合中的元素对象

四、数组排序

原来学的冒泡排序

演示样例:

int  array[10] = { 2, 5, 4, 7, 6, 3} ;

for (int i = 0; i < 6 - 1 ; i++){

for(int j = 0; j < 6 - 1 - i ; j++){

int temp = array[ j ] ;

array[ j ] = array[ j + 1 ] ;

array[ j + 1 ] = temp ;

}

}

for(int i = 0 ; i < 6 ; i++){

printf("%d" , a[ i ]) ;

}

数组排序:

for (int i = 0; i < 6 - 1 ; i++){

for( 推断条件 ){

[array  exchangeObjectAtIndex : j WithObjectAtIndex : j + 1 ] ;

}

}

                    数组排序取决与推断条件,推断条件决定了排序方式(升序、降序)

OC第五课的更多相关文章

  1. NeHe OpenGL教程 第四十五课:顶点缓存

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  2. kali linux 渗透测试视频教程 第五课 社会工程学工具集

    第五课 社会工程学工具集 文/玄魂 教程地址:http://edu.51cto.com/course/course_id-1887.html   目录 第五课社会工程学工具集 SET SET的社会工程 ...

  3. Adafruit的树莓派教程第五课:使用控制电缆

    Adafruit的树莓派教程第五课:使用控制电缆 时间 2014-05-09 01:11:20 极客范 原文 http://www.geekfan.net/9095/ 主题 Raspberry PiM ...

  4. NeHe OpenGL教程 第三十五课:播放AVI

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  5. NeHe OpenGL教程 第二十五课:变形

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  6. NeHe OpenGL教程 第十五课:纹理图形字

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  7. NeHe OpenGL教程 第五课:3D空间

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  8. 斯坦福IOS开发第五课(第一部分)

    转载请注明出处 http://blog.csdn.net/pony_maggie/article/details/27706991 作者:小马 因为第五课的内容比較多.分两部分来写. 一 屏幕旋转基本 ...

  9. 【Linux探索之旅】第一部分第五课:Unity桌面,人生若只如初见

    内容简介 1.第一部分第五课:Unity桌面,人生若只如初见 2.第一部分第六课预告:Linux如何安装在虚拟机中 Unity桌面,人生若只如初见 不容易啊,经过了前几课的学习,我们认识了Linux是 ...

随机推荐

  1. DiskGenius

    DiskGenius是一款集磁盘分区管理与数据恢复功能于一身的工具软件.它即是一款功能强大.灵活易用的分区软件,同时也是一款技术高超.功能全面的数据恢复软件.它不仅具备与分区管理有关的几乎全部功能,支 ...

  2. html状态码

    100——客户必须继续发出请求101——客户要求服务器根据请求转换HTTP协议版本 200——交易成功201——提示知道新文件的URL202——接受和处理.但处理未完成203——返回信息不确定或不完整 ...

  3. 乌班图 root权限获取

    点击左侧终端标 2 出现命令提示符 3 首先输入:sudo passwd root(设置root密码) 4 输入当前系统的账户密码(账户:admin-pc的密码) 5 输入新的root密码,确认新密码 ...

  4. poj2728 最小比率生成树——01分数规划

    题目大意: 有n个村庄,村庄在不同坐标和海拔,现在要对所有村庄供水, 只要两个村庄之间有一条路即可,建造水管距离为坐标之间的欧几里德距离,费用为海拔之差, 现在要求方案使得费用与距离的比值最小,很显然 ...

  5. sql 查找死锁对象的存储过程

    USE [master] GO /****** Object: StoredProcedure [dbo].[sp_who_lock] Script Date: 05/12/2016 14:13:46 ...

  6. 行为型设计模式之命令模式(Command)

    结构 意图 将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化:对请求排队或记录请求日志,以及支持可撤消的操作. 适用性 抽象出待执行的动作以参数化某对象,你可用过程语言中的回调(c a ...

  7. 推送通知iOS客户端编写实现及推送服务器端编写

    http://blog.csdn.net/tonny_guan/article/details/8963262 1.iOS客户端编程 推送通知技术在Mac OS X和iOS系统上都可以运行,我们本章主 ...

  8. openGL深度缓冲区问题

    http://zhidao.baidu.com/question/368299839.html&__bd_tkn__=6aa9196c746cd3357f1eec74aeb127b395029 ...

  9. Java设计模式_创建型模式_单例模式

    单例模式的实现: 定义一个类,在类中定义该类的静态变量,再定一个一个获取该类的静态变量的方法. UML图:

  10. AC日记——Little Elephant and Problem codeforces 221c

    221C 思路: 水题: 代码: #include <cstdio> #include <cstring> #include <iostream> #include ...