ios数组基本用法和排序
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);
- }
转载于:https://www.cnblogs.com/Free-Thinker/p/4972341.html
ios数组基本用法和排序相关推荐
- ios 数组中的字典排序_利用数组和字典,实现按指定规则的排序
大家好,今日我们继续讲解数组与字典解决方案,今日讲解第47讲:利用字典和数组,实现按指定规则的排序.随着字典讲解的深入,我们发现字典真的很神奇,在VBA代码中,给人以十分清爽的感觉,在这套数组与字典解 ...
- ios 数组中的字典排序_题解 | 26.删除排序数组中的重复项
假设我们有一个传感器,会不停地向 HQ 传输已经归类好数据,数据的格式全部是数字(种类编号),且已经按照从小到大的顺序排列,大概是 [1,1,4,5,7,9] 这样的,但是我们的需求在于,希望知道有多 ...
- Java数组合并,完成排序,从时间复杂度,和空间复杂度考虑
2019独角兽企业重金招聘Python工程师标准>>> 提供方法,直接调用,支持任意个数组的合并成一个数组,并且完成排序,每个数组元素个数不定.需要提供两个方法,分别做到时间复杂度最 ...
- Python计算两个numpy数组的交集(Intersection)实战:两个输入数组的交集并排序、获取交集元素及其索引、如果输入数组不是一维的,它们将被展平(flatten),然后计算交集
Python计算两个numpy数组的交集(Intersection)实战:两个输入数组的交集并排序.获取交集元素及其索引.如果输入数组不是一维的,它们将被展平(flatten),然后计算交集 目录
- python 多维数组(array)排序
原文:https://blog.csdn.net/daoxiaxingcai46/article/details/78391169 python 多维数组(array)排序 关于多维数组如何复合排序 ...
- java数组1 100偶数和_java – 数组偶数和奇数排序
我有一个数组,我有一些数字.现在我想在单独的数组中对偶数进行排序,在单独的数组中对奇数进行排序.有没有API可以做到这一点.我试过这样的 int[] array_sort={5,12,3,21,8,7 ...
- boost::sort模块实现在大多数排序的数组示例上展开排序
boost::sort模块实现在大多数排序的数组示例上展开排序 实现功能 C++实现代码 实现功能 boost::sort模块实现在大多数排序的数组示例上展开排序 C++实现代码 #include & ...
- php数据库根据相似度排序,php数组字段相似度排序
摘要:今天有一个客户有这么一个需求,要求对某篇文章的相关内容的列表,在跟文章标题进行相似度排序,于是想了又想,写了一个小算法,可以根据关键字相似度对数组某个字段进行排序... 今天有一个客户有这么一个 ...
- Java黑皮书课后题第8章:*8.27(列排序)用下面的方法实现一个二维数组中的列排序。返回新数组,且原数组保持不变。编写一个测试程序,提示用户输入一个3*3的double型矩阵,显示一个排好的矩阵
*8.27(列排序)用下面的方法实现一个二维数组中的列排序.返回新数组,且原数组保持不变.编写一个测试程序,提示用户输入一个3*3的double型矩阵,显示一个排好的矩阵 题目 题目描述与运行示例 破 ...
最新文章
- 2022-2028年中国NFT行业市场研究及前瞻分析报告
- QDoc状态status
- 前端学习(1917)vue之电商管理系统电商系统之绘制面包屑导航和卡片视图调用api获取数据
- 产品经理对企业的价值
- matlab中未定义与 ‘cell‘ 类型的输入参数相对应的运算符 ‘+‘ 的解决方案
- Linux中的常用命令
- 20160319中艺收盘总结
- Eolinker——前置用例返回的reponse值进行传递
- 联想Ideapad310s笔记本换屏线
- 最新抖音、快手、西瓜、小红书在线去水印,去水印API接口
- OCR文字识别算法与搭建流程
- Win11谷歌的IDM插件用不了怎么解决?如何解决win11idm插件问题
- Win7更换锁屏和开机画面
- 如何将风险应用加入白名单_vivo手机怎么把风险应用添加到白名单
- 【为什么我在namesilo买的域名说我没有备案 】求大佬解答
- 腾讯2018秋招笔试真题-小Q的歌单
- U盘中毒,文件夹或文件打不开的解决方法--实用
- [1101]flink常用参数说明
- 【论文汇总】2020上半年阿里、腾讯、百度入选AI顶会论文(附地址)
- 线性稳压器与开关稳压器的对比分析