[转] 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.数组插入.删除 ...
随机推荐
- HDU - 1495 非常可乐 【BFS】
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=1495 思路 首先 如果可乐的体积 是奇数 那么是无解的 然后 如果能够得到两杯 都是一般容量的可乐 那 ...
- Java基础知识整理之static修饰属性
static 关键字,我们在开发用的还是比较多的.在<Java编程思想>有下面一段话 static 方法就是没有 this 的方法.在 static 方法内部不能调用非静态方法,反过来是可 ...
- mini2440 u-boot禁止蜂鸣器
mini2440的u-boot版本启动之后马上就会开启蜂鸣器,在办公环境下有可能会影响同事的工作,所以我考虑将其禁止掉. 我使用的mini2440使用的光盘是2013年10月的版本,我在该光盘下的u- ...
- 服务器中判断客户端socket断开连接的方法【转】
本文转载自:http://www.cnblogs.com/jacklikedogs/p/3976208.html 1, 如果服务端的Socket比客户端的Socket先关闭,会导致客户端出现TIME_ ...
- POJ3294 Life Forms —— 后缀数组 最长公共子串
题目链接:https://vjudge.net/problem/POJ-3294 Life Forms Time Limit: 5000MS Memory Limit: 65536K Total ...
- Python成长之路第一篇(2)__初识列表和元组
可以将列表和元组当成普通的“数组”,他能保存任意数量任意类型的Python对象,和数组一样都是通过数字0索引访问元素,列表和元组可以存储不同类型的对象,列表和元组有几处重要区别.列表元素用([])包括 ...
- freemaker开发
推荐书籍 百度云盘 密码: c3m9 1. 前言 本书为<FreeMarker 2.3.19 中文版手册>,包含了freemarker开发得方方面面,可以作为开发freemarker的字典 ...
- tkinter之对话框
对话框的一个例子: from tkinter.dialog import * from tkinter import * def investigation(): d=Dialog(None,titl ...
- EOF的使用
1.我疑惑了 char a[20]; while(scanf("%s",a)!=EOF){ cout<<"hello"<<endl; } ...
- 岭回归与Lasso回归
线性回归的一般形式 过拟合问题及其解决方法 问题:以下面一张图片展示过拟合问题 解决方法:(1):丢弃一些对我们最终预测结果影响不大的特征,具体哪些特征需要丢弃可以通过PCA算法来实现:(2):使用正 ...