[转] ios数组基本用法和排序
http://blog.csdn.net/daiyelang/article/details/18726947
1.创建数组
- // 创建一个空的数组
- NSArray *array = [NSArray array];
- // 创建有1个元素的数组
- array = [NSArray arrayWithObject:@"123"];
- // 创建有多个元素的数组
- array = [NSArray arrayWithObjects:@"a", @"b", @"c", nil nil];
- NSArray *array3 = [array arrayByAddingObjectsFromArray:[NSArray arrayWithObjects:@"4", @"5", nil nil]];
- NSArray *array4 = [NSArray arrayWithObjects:@"1", @"2", @"3", @"4", nil nil];
- NSRange range = NSMakeRange(1, 2);
- NSArray *array5 = [array4 subarrayWithRange:range];
2.数组的一些基本方法
- int count = [array count];//个数
- // 判断是否包含了某个元素
- if ([array containsObject:@"a"]) {
- NSLog(@"包含了字符串a");
- }
- NSString *last = [array lastObject];最后一个元素
- NSString *str = [array objectAtIndex:1];根据索引获取数组中的元素
- int index = [array indexOfObject:@"c"];获取指定元素的索引
- // 让数组里面的所有对象都调用test方法,123为参数
- NSArray *array = [NSArray arrayWithObjects:stu1, stu2, stu3, nil nil];
- [array makeObjectsPerformSelector:@selector(test2:) withObject:@"123"];
- NSArray *array = [NSArray arrayWithObjects:@"1", @"2", @"3", @"4", nil nil];
- // 1-2-3-4
- // 利用分隔符-拼接所有的数组元素
- NSString *str = [array componentsJoinedByString:@"-"];
- // 将一个数组写入文件(生成的是一个xml文件)
- NSString *path = @"/Users/apple/Desktop/array.xml";
- [array writeToFile:path atomically:YES];
- path = @"/Users/apple/Desktop/array.txt";
- // 从文件中读取数组内容(文件有严格的格式要求)
- NSArray *array2 = [NSArray arrayWithContentsOfFile:path];
3.遍历数组
- #pragma mark 遍历数组1
- void arrayFor1() {
- NSArray *array = [NSArray arrayWithObjects:stu1, @"1", @"2", @"3", nil nil];
- int count = array.count;
- for (int i = 0; i<count; i++) {
- id obj = [array objectAtIndex:i];
- }
- }
- #pragma mark 遍历数组2 快速遍历
- void arrayFor2() {
- Student *stu1 = [Student student];
- NSArray *array = [NSArray arrayWithObjects:stu1, @"1", @"2", @"3", nil nil];
- int i =0;
- for (id obj in array) {
- NSLog(@"%i-%@", i, obj);
- i++;
- }
- }
- #pragma mark 遍历数组3
- void arrayFor3() {
- Student *stu1 = [Student student];
- NSArray *array = [NSArray arrayWithObjects:stu1, @"1", @"2", @"3", nil nil];
- [array enumerateObjectsUsingBlock:
- ^(id obj, NSUInteger idx, BOOLBOOL *stop) {
- NSLog(@"%i-%@", idx, obj);
- // 如果索引为1,就停止遍历
- if (idx == 1) {
- // 利用指针修改外面BOOL变量的值
- *stop = YES;
- }
- }];
- }
- #pragma mark 遍历数组4
- void arrayFor4() {
- Student *stu1 = [Student student];
- NSArray *array = [NSArray arrayWithObjects:stu1, @"1", @"2", @"3", nil nil];
- // 获取数组的迭代器
- // NSEnumerator *enumerator = [array objectEnumerator];
- // 反序迭代器(从尾部开始遍历元素)
- NSEnumerator *enumerator = [array reverseObjectEnumerator];
- // allObjects是取出没有被遍历过的对象
- NSArray *array2 = [enumerator allObjects];
- NSLog(@"array2:%@", array2);
- // 获取下一个需要遍历的元素
- id obj = nil;
- while (obj = [enumerator nextObject]) {
- NSLog(@"obj=%@", obj);
- }
- }
4.数组排序
- #pragma mark 数组排序1
- void arraySort1() {
- NSArray *array = [NSArray arrayWithObjects:@"2", @"3", @"1", @"4", nil nil];
- // 返回一个排好序的数组,原来数组的元素顺序不会改变
- // 指定元素的比较方法:compare:
- NSArray *array2 = [array sortedArrayUsingSelector:@selector(compare:)];
- NSLog(@"array2:%@", array2);
- }
- #pragma mark 数组排序2
- void arraySort2() {
- Student *stu1 = [Student studentWithFirstname:@"MingJie" lastname:@"Li"];
- Student *stu2 = [Student studentWithFirstname:@"LongHu" lastname:@"Huang"];
- Student *stu3 = [Student studentWithFirstname:@"LianJie" lastname:@"Li"];
- Student *stu4 = [Student studentWithFirstname:@"Jian" lastname:@"Xiao"];
- NSArray *array = [NSArray arrayWithObjects:stu1,stu2,stu3, stu4, nil nil];
- // 指定排序的比较方法
- NSArray *array2 = [array sortedArrayUsingSelector:@selector(compareStudent:)];
- NSLog(@"array2:%@", array2);
- }
- - (NSComparisonResult)compareStudent:(Student *)stu {
- // 先按照姓排序
- NSComparisonResult result = [self.lastname compare:stu.lastname];
- // 如果有相同的姓,就比较名字
- if (result == NSOrderedSame) {
- result = [self.firstname compare:stu.firstname];
- }
- return result;
- }
- #pragma mark 数组排序3
- void arraySort3() {
- Student *stu1 = [Student studentWithFirstname:@"MingJie" lastname:@"Li"];
- Student *stu2 = [Student studentWithFirstname:@"LongHu" lastname:@"Huang"];
- Student *stu3 = [Student studentWithFirstname:@"LianJie" lastname:@"Li"];
- Student *stu4 = [Student studentWithFirstname:@"Jian" lastname:@"Xiao"];
- NSArray *array = [NSArray arrayWithObjects:stu1,stu2,stu3, stu4, nil nil];
- // 利用block进行排序
- NSArray *array2 = [array sortedArrayUsingComparator:
- ^NSComparisonResult(Student *obj1, Student *obj2) {
- // 先按照姓排序
- NSComparisonResult result = [obj1.lastname compare:obj2.lastname];
- // 如果有相同的姓,就比较名字
- if (result == NSOrderedSame) {
- result = [obj1.firstname compare:obj2.firstname];
- }
- return result;
- }];
- NSLog(@"array2:%@", array2);
- }
- #pragma mark 数组排序4-高级排序
- void arraySort4() {
- Student *stu1 = [Student studentWithFirstname:@"MingJie" lastname:@"Li" bookName:@"book1"];
- Student *stu2 = [Student studentWithFirstname:@"LongHu" lastname:@"Huang" bookName:@"book2"];
- Student *stu3 = [Student studentWithFirstname:@"LianJie" lastname:@"Li" bookName:@"book2"];
- Student *stu4 = [Student studentWithFirstname:@"Jian" lastname:@"Xiao" bookName:@"book1"];
- NSArray *array = [NSArray arrayWithObjects:stu1,stu2,stu3, stu4, nil nil];
- // 1.先按照书名进行排序
- // 这里的key写的是@property的名称
- NSSortDescriptor *bookNameDesc = [NSSortDescriptor sortDescriptorWithKey:@"book.name" ascending:YES];
- // 2.再按照姓进行排序
- NSSortDescriptor *lastnameDesc = [NSSortDescriptor sortDescriptorWithKey:@"lastname" ascending:YES];
- // 3.再按照名进行排序
- NSSortDescriptor *firstnameDesc = [NSSortDescriptor sortDescriptorWithKey:@"firstname" ascending:YES];
- // 按顺序添加排序描述器
- NSArray *descs = [NSArray arrayWithObjects:bookNameDesc, lastnameDesc, firstnameDesc, nil nil];
- NSArray *array2 = [array sortedArrayUsingDescriptors:descs];
- NSLog(@"array2:%@", array2);
- }
[转] ios数组基本用法和排序的更多相关文章
- ios数组基本用法和排序
1.创建数组 // 创建一个空的数组 NSArray *array = [NSArray array]; // 创建有1个元素的数组 array = [NSArray arrayWithObject: ...
- ios数组基本用法和排序大全
1.创建数组 // 创建一个空的数组 NSArray *array = [NSArray array]; // 创建有1个元素的数组 array = [NSArray arrayWithObject: ...
- iOS 数组内中英文混合排序
NSInteger sortObjects(id obj1, id obj2,void *context) { NSMutableString * str1 = [[NSMutableString a ...
- iOS数组使用
相关链接: ios数组基本用法和排序 NSArray 排序汇总 iOS 数组排序方法 IOS-筛选数组内的元素 关于EnumerateObjectsUsingBlock和for-in之间的较量 [iO ...
- iOS - 数组字典模型根据模型属性key排序
方法一: NSArray *sortArray = [arrayM sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2) { ...
- PHP 二维数组根据某个字段排序
二维数组根据某个字段排序有两种办法,一种是通过sort自己写代码,一种是直接用array_multisort排序函数 一. 手写arraysort PHP的一维数组排序函数: sort 对数组的值按 ...
- [BS-02] iOS数组、字典、NSNumber 新写法—— @[]、@{}
IOS数组.字典.NSNumber 新写法—— @[].@{} //标准写法 NSNumber * number = [NSNumber numberWithInt:]; NSArray * ar ...
- PHP 按二维数组的键值排序
/** * 按二维数组的键值排序 * @param unknown $array 二维数组 * @param unknown $key 二维数组的键值 * @param string $order 升 ...
- javascript 常见数组操作( 1、数组整体元素修改 2、 数组筛选 3、jquery 元素转数组 4、获取两个数组中相同部分或者不同部分 5、数组去重并倒序排序 6、数组排序 7、数组截取slice 8、数组插入、删除splice(需明确位置) 9、数组遍历 10、jQuery根据元素值删除数组元素的方)
主要内容: 1.数组整体元素修改 2. 数组筛选 3.jquery 元素转数组 4.获取两个数组中相同部分或者不同部分 5.数组去重并倒序排序 6.数组排序 7.数组截取slice 8.数组插入.删除 ...
随机推荐
- callback机制之内核通知链表【转】
本文转载自:http://bbs.chinaunix.net/thread-2011776-1-1.html 1.通知链表简介 大多数内核子系统都是相互独立的,因此某个子系统可能对其它子系统产生 ...
- python中的编码转换
今天遇到了一个问题,将字符串“\uxxxx\uxxxx”转换成汉字.网上查了很多资料都不行. 后来看到,发现一个函数就OK了. str = str.decode('unicode_escape') 等 ...
- java入门的语法学习
用java语言写了一个求两个数最大公约数的程序: import java.io.*; import java.util.*; import java.math.*; public class Main ...
- deepin网络加速
0.进入控制中心里的“更新设置”,选择速度最快的镜像源(我的是阿里云)1.安装dnsmasq(命令:sudo aptitude install dnsmasq)2.以管理员权限打开gedit(命令:s ...
- Java微信公众平台开发_05_微信网页授权
GitHub源码:https://github.com/shirayner/weixin_gz 一.本节要点 1.网页授权回调域名 登录微信公众平台后台, 开发 - 接口权限 - 网页服务 - 网页帐 ...
- PG替换字段中的回车与换行
REPLACE(filed, CHR(10), '') //替换换行符 REPLACE(filed, CHR(13), '') //替换回车符
- 【Lintcode】033.N-Queens
题目: The n-queens puzzle is the problem of placing n queens on an n×n chessboard such that no two que ...
- Java 核心读书笔记 第11章
1. 异常 用户希望在出现错误时,程序能够采用一些理智的行为. 如果由于出现错误而使得某些操作无法完成,程序应该: 返回到一种安全状态,并能够进行一些其他的命令: 或者:允许用于保存所有操作的结果, ...
- Linux命令总结_touch创建文件
1.touch命令,用来创建文件或者修改文件时间戳 格式:touch [选项]... 文件... 选项 : -a 或--time=atime或--time=access或--time=use 只 ...
- Teams Formation
题意: 给定一长度为 n 的整数序列 $a$,将其复制m次,并接成一条链,每相邻K个相同的整数会消除,然后其他的整数继续结成一条链,直到不能消除为止,求问最终剩余多少个整数. 解法: 首先将长度为n的 ...