03-Foundation中NSMutableArray遍历、复制和排序
目录:
SDK、API、Foundation、Cocoa是什么?
SDK Software Development Kit开发工具包,目标文件.o实现库,非开源。
API Application Program Interface是应用程序接口,是.h文件的声明库。
Cocoa( Foundation框架【API、SDK】、UIKIT框架【API、SDK】 )
一、NSString补充
1 截取字符串
* 从指定下标开始,包含开始位置,截取字符串
SubStringFromIndex从中间到最后
* 从0开始,到指定位置,不包含指定位置
SubStringToIndex 从开始到中间
* 指定范围截取字符串
SubStringWithRange
2 字符串大小写转换
* 将所有的字符串内容变为大写
uppercaseString 会创建一个新的字符串
* 将所有的字符串内容变为小写
lowercaseString
* 将单词的首字母大写
capitalizedString
3 得到字符串的前缀和后缀
TRStudent.h
如果一个字符串是文件名,可以得到这个字符串的前缀和后缀。
* 判断一个文件是否有某个前缀,返回布尔类型
BOOL b = [str hasPrefix:@"TR"]
* 判断一个文件是否有某个后缀,返回布尔类型
BOOL b = [str hasSuffix:@".h"]
二、NSMutableArray可变数组
//1 初始化方法
//NSMutableArray* array = [NSMutableArray array];
NSMutableArray* array2 = [NSMutableArray arrayWithObjects:@"one",@"two", nil];
//2 向数组中添加一个元素
[array2 addObject:@"three"];
//3 在指定位置添加一个元素
[array2 insertObject:@"four" atIndex:];
//4 删除指定下标的元素
[array2 removeObjectAtIndex:];
//5 删除指定对象(删除对象的地址)
[array2 removeObject:@"three"];
//6 替换指定下标的元素
[array2 replaceObjectAtIndex: withObject:@""];
//7 删除数组中所有元素
[array2 removeAllObjects];
NSLog(@"%@",array2);
三、遍历(三种遍历方式)
1 for循环
2 快速枚举
//2 forin
//NSString* str 保存数组元素的变量
//array 要遍历的数组
for (NSString* str in array) {
NSLog(@"arrar:%@",str);
}
练习:National类(名称China)拥有多个地区,地区Area(名称、人口)。创建三个地区
(beijing3000,guangzhou2000,shanghai1000)
显示所有城市及人口
只显示北京的人口
3 迭代器遍历
//* 每个数组和集合都有自己的迭代器
NSEnumerator* enumer = [array objectEnumerator];
//* 每次迭代时要发送消息
//[enumer nextObject]
//返回当前指向数组中的对象,并且自动向下移动一位,
//如果没有对象时,则返回nil,且终止迭代
//向数组中取对象
id obj;
while (obj = [enumer nextObject]) {//自动取值,然后向下移动一下
NSString* str = obj;
NSLog(@"str:%@",str);
}//运行此循环的时候先取出一个值,然后向下移动
四、NSArray支持的新语法
1 ios6.0及osx10.8之后,编译器LLVM编译支持
2 初始化数据
OC:[NSArray arrayWithObjects:@"a",@"b",nil]
OC新语法:NSArray* array = @[@"a",@"b"];
3 根据下标得到数组中的元素的值
OC:[array objictAtIndex:0];
OC新语法:array[0];
五、数组复制
1 分深拷贝(内容复制)、浅拷贝(引用复制)
2 复制对象:指针复制(浅拷贝)、内容复制(深拷贝)
3 数组中的元素,对象的引用
4 浅拷贝:新数组和原有数组共享内存中的对象
NSArray* array2 = [[NSArray alloc] initWithArray:array copyItems:NO];
5 深拷贝:新数组和原有数组都有独享的对象
NSArray* array3 = [[NSArray alloc] initWithArray:array copyItems:YES];
注:深拷贝数组的对象必须遵守NSCopying协议,并且实现copyWithZone方法,如果不但想复制对象,还要复制对象的值,要添加有参的copyWithZone方法
六、数组的排序
1 可以让数组中的对象按照一定规则进行排序
2 类必须实现compare方法(排序的规则)
3 规则原理:0相等 -1升序 1降序
4 发送排序消息
NSArray* array2 = [array sortedArrayUsingSelector:@selector(compare:)];
练习:创建5个学生对象,按姓名排序
作业:1.按年龄排序升序、降序。
2.先年龄升序再按姓名升序(年龄相等的人,再按姓名排序)
作业:
联系人信息:TelphoneInfo 1
name:ysy 2 谁的联系人信息
userInfos: 2 所有好友信息
-addUserInfo 3 添加好友
-removeUser 7 删除好友
-lookupUserInfoByName 6查找好友信息
-list 4 查看所有好友信息
-sort 5 查看所有好友信息排序
个人信息:UserInfo 1
name:2 好友的姓名
email:2
telphone:2
-showInfo;3 查看好友的详细信息
03-Foundation中NSMutableArray遍历、复制和排序的更多相关文章
- PAT 甲级 1064 Complete Binary Search Tree (30 分)(不会做,重点复习,模拟中序遍历)
1064 Complete Binary Search Tree (30 分) A Binary Search Tree (BST) is recursively defined as a bin ...
- 二叉树 排序二叉树-可以通过中序遍历得到排序的数据 二叉排序树时间复杂度O(logn),
二叉树是一种非常重要的数据结构,它同时具有数组和链表各自的特点:它可以像数组一样快速查找,也可以像链表一样快速添加.但是他也有自己的缺点:删除操作复杂. 虽然二叉排序树的最坏效率是O(n),但它支持动 ...
- Java中常用的6种排序算法详细分解
排序算法很多地方都会用到,近期又重新看了一遍算法,并自己简单地实现了一遍,特此记录下来,为以后复习留点材料. 废话不多说,下面逐一看看经典的排序算法: 1. 选择排序 选择排序的基本思想是遍历数组的过 ...
- Team Foundation 中的错误和事件消息
Visual Studio Team System Team Foundation 中的错误和事件消息 Team Foundation 通过显示错误消息和事件消息来通知您操作成功以及操作失败.一部分错 ...
- 剑指 Offer 03. 数组中重复的数字
剑指 Offer 03. 数组中重复的数字 找出数组中重复的数字. 在一个长度为 n 的数组 nums 里的所有数字都在 0-n-1 的范围内.数组中某些数字是重复的,但不知道有几个数字重复了,也不知 ...
- SQL把表中的数据复制到另一个数据库中
1 删除整张表的数据,并还原自增长值TRUNCATE TABLE TbWeixinActivity 2 3张表左连接select a.ID,c.Name,b.nickname,a.CreateDate ...
- iOS中的深复制与浅复制
很多语言中都有深复制浅复制的概念,如C++,ObjC等.简单来说,浅复制就是两个变量指向了同一块内存区域,深复制就是两个变量指向了不同的内存区域,但是两个内存区域里面的内容是一样的. 浅复制示意图: ...
- 线索化二叉树的构建与先序,中序遍历(C++版)
贴出学习C++数据结构线索化二叉树的过程, 方便和我一样的新手进行测试和学习 同时欢迎各位大神纠正. 不同与普通二叉树的地方会用背景色填充 //BinTreeNode_Thr.h enum Point ...
- Freemarker中如何遍历List
Freemarker中如何遍历List(附源码) 关键词(Keyword):Freemarker,Freemarker遍历list 在Freemarker应用中经常会遍历List获取需要的数据, ...
随机推荐
- 前端笔试面试中的常用知识点总结(CSS)
1.CSS选择器的优先级!important > 内联 > id选择器 > 类选择器 > 标签选择器多个类选择器叠加(256)之后的优先级大于一个id选择器!importan ...
- 关于left join 和 inner join
今天遇到一个逻辑很复杂的SQL,虽然写出来了,但是并没有完全体会,找了找资料,算是摸清楚了left join和inner join 的实际意义. 感谢PCJIM的文章,写的非常明白,原文地址:http ...
- BZOJ 1634: [Usaco2007 Jan]Protecting the Flowers 护花( 贪心 )
考虑相邻的两头奶牛 a , b , 我们发现它们顺序交换并不会影响到其他的 , 所以我们可以直接按照这个进行排序 ------------------------------------------- ...
- tomcat手动发布
有些时候不能通过eclipse中的server服务发布工程,这时候就只能通过手动配置进行发布了 如下: 配置发布路径:D:\Program Files\apache-tomcat-6.0.10\con ...
- shell实例浅谈之六文件特定行打印的多种方法
一.问题 Sed和AWK在处理文件方面有很强的优势,还有head和tail等文件处理工具的使用,grep也可实现文本的搜索.上述命令都可以在后面直接加文件名,不需要在前面使用cat添加管道,cat会影 ...
- Square(hdu 1511)
题目描述: Problem Description Given a set of sticks of various lengths, is it possible to join them end- ...
- window下nodejs安装指南
相信对于很多关注javascript发展的同学来说,nodejs已经不是一个陌生的词眼.有关nodejs的相关资料网上已经铺天盖地.由于它的高并发特性,造就了其特殊的应用地位. 国内目前关注最高,维护 ...
- android 上传文件
android对于上传文件,还是非常easy的,和java里面的上传都是一样的,基本上都是熟悉操作输出流和输入流!另一个特别重要的就是须要一些content-type这些參数的配置! 假设这些都弄好 ...
- 为joomla加入�下拉菜单的方法
用 Joomla! 建站的大多数站长都须要在站点前台使用下拉菜单(dropdown menu),或者叫弹出菜单(slide menu),由于这样能够在有限的页面空间上公布很多其它的导航菜单,而且能够进 ...
- UILabel可以显示html文本
NSString * htmlString = @"<html><body> Some html string \n <font size=\"13\ ...