[转] 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.数组插入.删除 ...
随机推荐
- 9.2 NOIP提高组试题精解(2)
9-18 fruit.c #include <stdio.h> #define MAXN 10000 int Queue1[MAXN], Queue2[MAXN]; void Insert ...
- CSS3实现水位充满文字特效
CSS3实现水位充满文字特效是一款既是Loading特效也是文字特效,Loading动画开始时,文字中的水位渐渐上升,为了模拟水位上升的真实效果,水面还会波浪浮动,当Loading动画结束时,文字中的 ...
- Eclipse中导入github上的项目
Eclipse中导入github上的项目 转载至: http://blog.csdn.net/hil2000/article/details/8566456 1.首先在github.com上申请一个账 ...
- Scrapy,终端startproject,显示错误TimeoutError: [WinError 10060] 由于连接方在一段时间后没有正确答复或连接的主机没有反应,连接尝试失败。
F:\python_project\test>scrapy startproject spz Traceback (most recent call last): File "d:\p ...
- Educational Codeforces Round 17 颓废记
又被虐了... (记一次惨痛的Codeforces) 好不容易登上去了Codeforces,22:35准时开打 第一题,一看:这不SB题嘛?直接枚举因数上啊.9min才过掉了pretest 第二题.. ...
- 【Lintcode】033.N-Queens II
题目: Follow up for N-Queens problem. Now, instead outputting board configurations, return the total n ...
- Thrift简析
Thrift源于大名鼎鼎的facebook之手,在2007年facebook提交Apache基金会将Thrift作为一个开源项目,对于当时的facebook来说创造thrift是为了解决faceboo ...
- bzoj 1731 [Usaco2005 dec]Layout 排队布局——差分约束
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1731 对差分约束理解更深.还发现美妙博客:http://www.cppblog.com/me ...
- poj 3415 Common Substrings —— 后缀数组+单调栈
题目:http://poj.org/problem?id=3415 先用后缀数组处理出 ht[i]: 用单调栈维护当前位置 ht[i] 对之前的 ht[j] 取 min 的结果,也就是当前的后缀与之前 ...
- WaitHandle.WaitAll 方法在WPF工程中的应用
因为WaiAll需要多线程支持, 而WPF是STA模式, 可以通过以下方式实现WaitAll ManualResetEvent[] events: foreach (ManualResetEvent ...