1.创建数组

[objc] view plaincopy
  1. // 创建一个空的数组
  2. NSArray *array = [NSArray array];
  3. // 创建有1个元素的数组
  4. array = [NSArray arrayWithObject:@"123"];
  5. // 创建有多个元素的数组
  6. array = [NSArray arrayWithObjects:@"a", @"b", @"c", nil nil];
  7. NSArray *array3 = [array arrayByAddingObjectsFromArray:[NSArray arrayWithObjects:@"4", @"5", nil nil]];
  8. NSArray *array4 = [NSArray arrayWithObjects:@"1", @"2", @"3", @"4", nil nil];
  9. NSRange range = NSMakeRange(1, 2);
  10. NSArray *array5 = [array4 subarrayWithRange:range];

2.数组的一些基本方法

[objc] view plaincopy
  1. int count = [array count];//个数
  2. // 判断是否包含了某个元素
  3. if ([array containsObject:@"a"]) {
  4. NSLog(@"包含了字符串a");
  5. }
  6. NSString *last = [array lastObject];最后一个元素
  7. NSString *str = [array objectAtIndex:1];根据索引获取数组中的元素
  8. int index = [array indexOfObject:@"c"];获取指定元素的索引
  9. // 让数组里面的所有对象都调用test方法,123为参数
  10. NSArray *array = [NSArray arrayWithObjects:stu1, stu2, stu3, nil nil];
  11. [array makeObjectsPerformSelector:@selector(test2:) withObject:@"123"];
  12. NSArray *array = [NSArray arrayWithObjects:@"1", @"2", @"3", @"4", nil nil];
  13. // 1-2-3-4
  14. // 利用分隔符-拼接所有的数组元素
  15. NSString *str = [array componentsJoinedByString:@"-"];
  16. // 将一个数组写入文件(生成的是一个xml文件)
  17. NSString *path = @"/Users/apple/Desktop/array.xml";
  18. [array writeToFile:path atomically:YES];
  19. path = @"/Users/apple/Desktop/array.txt";
  20. // 从文件中读取数组内容(文件有严格的格式要求)
  21. NSArray *array2 = [NSArray arrayWithContentsOfFile:path];

3.遍历数组

[objc] view plaincopy
  1. #pragma mark 遍历数组1
  2. void arrayFor1() {
  3. NSArray *array = [NSArray arrayWithObjects:stu1, @"1", @"2", @"3", nil nil];
  4. int count = array.count;
  5. for (int i = 0; i<count; i++) {
  6. id obj = [array objectAtIndex:i];
  7. }
  8. }
  9. #pragma mark 遍历数组2 快速遍历
  10. void arrayFor2() {
  11. Student *stu1 = [Student student];
  12. NSArray *array = [NSArray arrayWithObjects:stu1, @"1", @"2", @"3", nil nil];
  13. int i =0;
  14. for (id obj in array) {
  15. NSLog(@"%i-%@", i, obj);
  16. i++;
  17. }
  18. }
  19. #pragma mark 遍历数组3
  20. void arrayFor3() {
  21. Student *stu1 = [Student student];
  22. NSArray *array = [NSArray arrayWithObjects:stu1, @"1", @"2", @"3", nil nil];
  23. [array enumerateObjectsUsingBlock:
  24. ^(id obj, NSUInteger idx, BOOLBOOL *stop) {
  25. NSLog(@"%i-%@", idx, obj);
  26. // 如果索引为1,就停止遍历
  27. if (idx == 1) {
  28. // 利用指针修改外面BOOL变量的值
  29. *stop = YES;
  30. }
  31. }];
  32. }
  33. #pragma mark 遍历数组4
  34. void arrayFor4() {
  35. Student *stu1 = [Student student];
  36. NSArray *array = [NSArray arrayWithObjects:stu1, @"1", @"2", @"3", nil nil];
  37. // 获取数组的迭代器
  38. // NSEnumerator *enumerator = [array objectEnumerator];
  39. // 反序迭代器(从尾部开始遍历元素)
  40. NSEnumerator *enumerator = [array reverseObjectEnumerator];
  41. // allObjects是取出没有被遍历过的对象
  42. NSArray *array2 = [enumerator allObjects];
  43. NSLog(@"array2:%@", array2);
  44. // 获取下一个需要遍历的元素
  45. id obj = nil;
  46. while (obj = [enumerator nextObject]) {
  47. NSLog(@"obj=%@", obj);
  48. }
  49. }

4.数组排序

[objc] view plaincopy
  1. #pragma mark 数组排序1
  2. void arraySort1() {
  3. NSArray *array = [NSArray arrayWithObjects:@"2", @"3", @"1", @"4", nil nil];
  4. // 返回一个排好序的数组,原来数组的元素顺序不会改变
  5. // 指定元素的比较方法:compare:
  6. NSArray *array2 = [array sortedArrayUsingSelector:@selector(compare:)];
  7. NSLog(@"array2:%@", array2);
  8. }
  9. #pragma mark 数组排序2
  10. void arraySort2() {
  11. Student *stu1 = [Student studentWithFirstname:@"MingJie" lastname:@"Li"];
  12. Student *stu2 = [Student studentWithFirstname:@"LongHu" lastname:@"Huang"];
  13. Student *stu3 = [Student studentWithFirstname:@"LianJie" lastname:@"Li"];
  14. Student *stu4 = [Student studentWithFirstname:@"Jian" lastname:@"Xiao"];
  15. NSArray *array = [NSArray arrayWithObjects:stu1,stu2,stu3, stu4, nil nil];
  16. // 指定排序的比较方法
  17. NSArray *array2 = [array sortedArrayUsingSelector:@selector(compareStudent:)];
  18. NSLog(@"array2:%@", array2);
  19. }
  20. - (NSComparisonResult)compareStudent:(Student *)stu {
  21. // 先按照姓排序
  22. NSComparisonResult result = [self.lastname compare:stu.lastname];
  23. // 如果有相同的姓,就比较名字
  24. if (result == NSOrderedSame) {
  25. result = [self.firstname compare:stu.firstname];
  26. }
  27. return result;
  28. }
  29. #pragma mark 数组排序3
  30. void arraySort3() {
  31. Student *stu1 = [Student studentWithFirstname:@"MingJie" lastname:@"Li"];
  32. Student *stu2 = [Student studentWithFirstname:@"LongHu" lastname:@"Huang"];
  33. Student *stu3 = [Student studentWithFirstname:@"LianJie" lastname:@"Li"];
  34. Student *stu4 = [Student studentWithFirstname:@"Jian" lastname:@"Xiao"];
  35. NSArray *array = [NSArray arrayWithObjects:stu1,stu2,stu3, stu4, nil nil];
  36. // 利用block进行排序
  37. NSArray *array2 = [array sortedArrayUsingComparator:
  38. ^NSComparisonResult(Student *obj1, Student *obj2) {
  39. // 先按照姓排序
  40. NSComparisonResult result = [obj1.lastname compare:obj2.lastname];
  41. // 如果有相同的姓,就比较名字
  42. if (result == NSOrderedSame) {
  43. result = [obj1.firstname compare:obj2.firstname];
  44. }
  45. return result;
  46. }];
  47. NSLog(@"array2:%@", array2);
  48. }
  49. #pragma mark 数组排序4-高级排序
  50. void arraySort4() {
  51. Student *stu1 = [Student studentWithFirstname:@"MingJie" lastname:@"Li" bookName:@"book1"];
  52. Student *stu2 = [Student studentWithFirstname:@"LongHu" lastname:@"Huang" bookName:@"book2"];
  53. Student *stu3 = [Student studentWithFirstname:@"LianJie" lastname:@"Li" bookName:@"book2"];
  54. Student *stu4 = [Student studentWithFirstname:@"Jian" lastname:@"Xiao" bookName:@"book1"];
  55. NSArray *array = [NSArray arrayWithObjects:stu1,stu2,stu3, stu4, nil nil];
  56. // 1.先按照书名进行排序
  57. // 这里的key写的是@property的名称
  58. NSSortDescriptor *bookNameDesc = [NSSortDescriptor sortDescriptorWithKey:@"book.name" ascending:YES];
  59. // 2.再按照姓进行排序
  60. NSSortDescriptor *lastnameDesc = [NSSortDescriptor sortDescriptorWithKey:@"lastname" ascending:YES];
  61. // 3.再按照名进行排序
  62. NSSortDescriptor *firstnameDesc = [NSSortDescriptor sortDescriptorWithKey:@"firstname" ascending:YES];
  63. // 按顺序添加排序描述器
  64. NSArray *descs = [NSArray arrayWithObjects:bookNameDesc, lastnameDesc, firstnameDesc, nil nil];
  65. NSArray *array2 = [array sortedArrayUsingDescriptors:descs];
  66. NSLog(@"array2:%@", array2);
  67. }

转载于:https://www.cnblogs.com/Free-Thinker/p/4972341.html

ios数组基本用法和排序相关推荐

  1. ios 数组中的字典排序_利用数组和字典,实现按指定规则的排序

    大家好,今日我们继续讲解数组与字典解决方案,今日讲解第47讲:利用字典和数组,实现按指定规则的排序.随着字典讲解的深入,我们发现字典真的很神奇,在VBA代码中,给人以十分清爽的感觉,在这套数组与字典解 ...

  2. ios 数组中的字典排序_题解 | 26.删除排序数组中的重复项

    假设我们有一个传感器,会不停地向 HQ 传输已经归类好数据,数据的格式全部是数字(种类编号),且已经按照从小到大的顺序排列,大概是 [1,1,4,5,7,9] 这样的,但是我们的需求在于,希望知道有多 ...

  3. Java数组合并,完成排序,从时间复杂度,和空间复杂度考虑

    2019独角兽企业重金招聘Python工程师标准>>> 提供方法,直接调用,支持任意个数组的合并成一个数组,并且完成排序,每个数组元素个数不定.需要提供两个方法,分别做到时间复杂度最 ...

  4. Python计算两个numpy数组的交集(Intersection)实战:两个输入数组的交集并排序、获取交集元素及其索引、如果输入数组不是一维的,它们将被展平(flatten),然后计算交集

    Python计算两个numpy数组的交集(Intersection)实战:两个输入数组的交集并排序.获取交集元素及其索引.如果输入数组不是一维的,它们将被展平(flatten),然后计算交集 目录

  5. python 多维数组(array)排序

    原文:https://blog.csdn.net/daoxiaxingcai46/article/details/78391169 python 多维数组(array)排序 关于多维数组如何复合排序 ...

  6. java数组1 100偶数和_java – 数组偶数和奇数排序

    我有一个数组,我有一些数字.现在我想在单独的数组中对偶数进行排序,在单独的数组中对奇数进行排序.有没有API可以做到这一点.我试过这样的 int[] array_sort={5,12,3,21,8,7 ...

  7. boost::sort模块实现在大多数排序的数组示例上展开排序

    boost::sort模块实现在大多数排序的数组示例上展开排序 实现功能 C++实现代码 实现功能 boost::sort模块实现在大多数排序的数组示例上展开排序 C++实现代码 #include & ...

  8. php数据库根据相似度排序,php数组字段相似度排序

    摘要:今天有一个客户有这么一个需求,要求对某篇文章的相关内容的列表,在跟文章标题进行相似度排序,于是想了又想,写了一个小算法,可以根据关键字相似度对数组某个字段进行排序... 今天有一个客户有这么一个 ...

  9. Java黑皮书课后题第8章:*8.27(列排序)用下面的方法实现一个二维数组中的列排序。返回新数组,且原数组保持不变。编写一个测试程序,提示用户输入一个3*3的double型矩阵,显示一个排好的矩阵

    *8.27(列排序)用下面的方法实现一个二维数组中的列排序.返回新数组,且原数组保持不变.编写一个测试程序,提示用户输入一个3*3的double型矩阵,显示一个排好的矩阵 题目 题目描述与运行示例 破 ...

最新文章

  1. 2022-2028年中国NFT行业市场研究及前瞻分析报告
  2. QDoc状态status
  3. 前端学习(1917)vue之电商管理系统电商系统之绘制面包屑导航和卡片视图调用api获取数据
  4. 产品经理对企业的价值
  5. matlab中未定义与 ‘cell‘ 类型的输入参数相对应的运算符 ‘+‘ 的解决方案
  6. Linux中的常用命令
  7. 20160319中艺收盘总结
  8. Eolinker——前置用例返回的reponse值进行传递
  9. 联想Ideapad310s笔记本换屏线
  10. 最新抖音、快手、西瓜、小红书在线去水印,去水印API接口
  11. OCR文字识别算法与搭建流程
  12. Win11谷歌的IDM插件用不了怎么解决?如何解决win11idm插件问题
  13. Win7更换锁屏和开机画面
  14. 如何将风险应用加入白名单_vivo手机怎么把风险应用添加到白名单
  15. 【为什么我在namesilo买的域名说我没有备案 】求大佬解答
  16. 腾讯2018秋招笔试真题-小Q的歌单
  17. U盘中毒,文件夹或文件打不开的解决方法--实用
  18. [1101]flink常用参数说明
  19. 【论文汇总】2020上半年阿里、腾讯、百度入选AI顶会论文(附地址)
  20. 线性稳压器与开关稳压器的对比分析

热门文章

  1. Linux—帐号和权限管理
  2. 使用ASP.Net 3.5 的Ajax与Web服务开发实例
  3. 初学Flink,对Watermarks的一些理解和感悟(透彻2)
  4. Android上webview界面切换动画效果
  5. 一张图解释Linux的目录结构
  6. Java JPanel的使用
  7. Qt下的OpenGL 编程(3)绘制平面几何体
  8. Oracle 密码文件
  9. 《深入浅出设计模式-中文版》读书笔记-工厂模式(五)
  10. 弹性盒子 flex-direction