Object-c学习之路八(NSArray(数组)遍历和排序)
今天学习了NSArray的遍历和排序,现在在这里做一下总结:
遍历现在实现了四中方法:
排序大概有三中方法:(代码中都有注释)
关于对象的排序还是以Student和Book为例 每个Student持有一个Book.
主函数:
//
// main.m
// NSArray
//
// Created by WildCat on 13-7-25.
// Copyright (c) 2013年 wildcat. All rights reserved.
// #import <Foundation/Foundation.h>
#import "Student.h"
#pragma mark 创建一个集合
void arrayTest(){
//创建一个数组
NSArray *array=[NSArray array]; array=[NSArray arrayWithObjects:@"123",@"sf",@"dsg", nil];
NSLog(@"array is:%@",array); NSLog(@"tength is: %zi",array.count);
} #pragma mark 给数组里的元素发送消息
void arrayMessage(){
Student *stu1=[Student student];
Student *stu2=[Student student];
Student *stu3=[Student student];
NSArray *array=[NSArray arrayWithObjects:stu1,stu2,stu3, nil];
//让数组里的元素调用addMessage方法
[array makeObjectsPerformSelector:@selector(addMessage:) withObject:@"你好。"]; } #pragma mark 数组遍历(四种方法) void arrayLoop(){ Student *stu1=[Student student];
NSArray *array=[NSArray arrayWithObjects:stu1,@"1",@"2",@"3", nil];
//方法一 for循环
for (int i=0; i<array.count; i++) {
NSLog(@"%i->%@",i,[array objectAtIndex:i]);
} //方法二
int i=0;
for (id obj in array) {
NSLog(@"%i->%@",i,obj);
i++;
}
//方法三 通过Block遍历:官方建议使用block
[array enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
NSLog(@"%zi->%@",idx,obj);
//当执行到第3个时停止
if (idx==2){
*stop=YES;
}
}]; //方法四 通过迭代器遍历 //获得一个迭代器
NSEnumerator *enumerator=[array objectEnumerator];
id next=nil;
while (next=[enumerator nextObject]) {
NSLog(@"next->%@",next);
} //反向遍历
NSEnumerator *rvenumerator=[array reverseObjectEnumerator];
id rvnext=nil;
while (rvnext=[rvenumerator nextObject]) {
NSLog(@"rvnext->%@",rvnext);
} } #pragma mark 数组排序
void arraySort(){ NSArray *array=[NSArray arrayWithObjects:@"4",@"1",@"2",@"3", nil];
//排完后产生一个新的数组
//指定元素的排序方法 compare:
NSArray *array2=[array sortedArrayUsingSelector:@selector(compare:)];
NSLog(@"排序后:%@",array2);
}
#pragma mark 对数组中的Student对象进行排序:
//先按照性进行排序,后按照名进行排序(两种方法)
void studentSort(){ Student *stu1=[Student initWithFirstName:@"lianjie" LastName:@"Li"];
Student *stu2=[Student initWithFirstName:@"dehua" LastName:@"Liu"];
Student *stu3=[Student initWithFirstName:@"xingle" LastName:@"Li"];
Student *stu4=[Student initWithFirstName:@"long" LastName:@"Cheng"];
NSArray *array=[NSArray arrayWithObjects:stu1,stu2,stu3,stu4, nil]; //第一种方法
NSArray *array2=[array sortedArrayUsingSelector:@selector(compareStudent:)];
NSLog(@"排序后:%@",array2);
//第二种方法 通过Block排序
NSArray *array3=[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(@"通过Block排序后:%@",array3); } #pragma mark 对数组中的Student对象进行排序: //对数组中的Student对象进行排序:先按照性进行排序,后按照名进行排序(另一种方法)
void studentSort2(){ Student *stu1=[Student initWithFirstName:@"lianjie" LastName:@"Li" bookName:@"book1"];
Student *stu2=[Student initWithFirstName:@"dehua" LastName:@"Liu" bookName:@"book2"];
Student *stu3=[Student initWithFirstName:@"xingle" LastName:@"Li" bookName:@"book2"];
Student *stu4=[Student initWithFirstName:@"long" LastName:@"Cheng" bookName:@"book1"];
NSArray *array=[NSArray arrayWithObjects:stu1,stu2,stu3,stu4, nil];
//先按照书名进行排序 NSSortDescriptor *bookNameDesc=[NSSortDescriptor sortDescriptorWithKey:@"book.name" ascending:YES];
NSSortDescriptor *lastnameDesc=[NSSortDescriptor sortDescriptorWithKey:@"lastname" ascending:YES];
NSSortDescriptor *firstnameDesc=[NSSortDescriptor sortDescriptorWithKey:@"firstname" ascending:YES]; NSArray *decarray=[NSArray arrayWithObjects:bookNameDesc,lastnameDesc,firstnameDesc, nil]; NSArray *array2=[array sortedArrayUsingDescriptors:decarray];
NSLog(@"排序后:%@",array2); } int main(int argc, const char * argv[])
{ @autoreleasepool {
// arrayTest();
// arrayMessage();
//arrayLoop();
// arraySort();
// studentSort();
//先根据book名,后根据性 ,再根据名 进行排序
studentSort2();
}
return 0;
}
Student函数:
头文件:
// Student.h
// NSArray
//
// Created by WildCat on 13-7-25.
// Copyright (c) 2013年 wildcat. All rights reserved.
// #import <Foundation/Foundation.h>
@class Book;
@interface Student : NSObject{
NSString *_firstname;
NSString *_lastname; }
@property (nonatomic,retain) NSString * firstname;
@property (nonatomic,retain) NSString * lastname;
//每个学生拥有一本书
@property (nonatomic,retain)Book *book;
+(id)initWithFirstName:(NSString *)firstname LastName:(NSString *)lastname;
+(id)initWithFirstName:(NSString *)firstname LastName:(NSString *)lastname bookName:(NSString *)bookName;
+(id)student;
-(void) addMessage:(NSString *)str;
-(NSComparisonResult)compareStudent:(Student *)stu;
@end
.m文件:
//
// Student.m
// NSArray
//
// Created by WildCat on 13-7-25.
// Copyright (c) 2013年 wildcat. All rights reserved.
// #import "Student.h"
#import "Book.h"
@implementation Student
@synthesize firstname=_firstname;
@synthesize lastname=_lastname;
+(id)initWithFirstName:(NSString *)firstname LastName:(NSString *)lastname{
Student *stu=[[[Student alloc] init] autorelease]; stu.firstname=firstname;
stu.lastname=lastname;
return stu;
}
+(id)initWithFirstName:(NSString *)firstname LastName:(NSString *)lastname bookName:(NSString *)bookName{
Student *stu=[Student initWithFirstName:firstname LastName:lastname];
Book *book=[Book initBookWithName:bookName];
stu.book=book;
return stu;
} +(id)student{ return [[[Student alloc] init] autorelease]; }
-(void) addMessage:(NSString *)str{ NSLog(@"%@->addMessage->%@",self,str);
}
-(void)dealloc{
[_lastname release];
[_firstname release]; NSLog(@"%@ 被销毁",self);
[super dealloc];
}
//定义一个排序方法
-(NSComparisonResult)compareStudent:(Student *)stu{ //先按照性进行排序
NSComparisonResult result=[self.lastname compare:stu.lastname];
//再按照名进行排序
if (result==NSOrderedSame) {
result=[self.firstname compare:stu.firstname];
}
return result;
}
//重定义description 方法
-(NSString *)description{ return [NSString stringWithFormat:@"%@ %@->%@",self.lastname,self.firstname,self.book.name]; } @end
Book类:
.h文件:
// Book.h
// NSArray
//
// Created by WildCat on 13-7-25.
// Copyright (c) 2013年 wildcat. All rights reserved.
// #import <Foundation/Foundation.h> @interface Book : NSObject
@property (nonatomic ,retain) NSString *name;
+(id)initBookWithName:(NSString *)name; @end
.m文件:
#import "Book.h"
@implementation Book
+(id)initBookWithName:(NSString *)name{
Book *book=[[[Book alloc] init] autorelease];
book.name=name;
return book;
}
-(void)dealloc{
[_name release];
[super dealloc];
}
@end
Object-c学习之路八(NSArray(数组)遍历和排序)的更多相关文章
- Android开发学习之路-RecyclerView滑动删除和拖动排序
Android开发学习之路-RecyclerView使用初探 Android开发学习之路-RecyclerView的Item自定义动画及DefaultItemAnimator源码分析 Android开 ...
- Java学习之路(八):Set
Set集合概述以及特点: set 是一个不包含重复元素的collection set只是一个接口,一般使用它的子类HashSet,LinkedHashSet,TreeSet HashSet 此类是Se ...
- zigbee学习之路(八):定时器1(中断)
一.前言 通过上次的实验,我们已经学会了定时器3的中断方式,这次,我们来看看定时器1通过中断怎么控制. 二.原理分析 定时器1的初始化跟前面提到的一样,也是要配置寄存器T1CTL,还要进行开中断的操作 ...
- 嵌入式Linux驱动学习之路(八)创建最小的根文件系统
busybox 在配置busybox,在是否选择要静态链接库时,在静态下,busybox中的工具不需要动态链接库,能够直接运行.而用户自己编写的程序如果需要动态链接库,还是依然需要有. 如果是动态链接 ...
- IOS7学习之路八(iOS 禁止屏幕旋转的方法)
- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)toInterfaceOrientation { retu ...
- IOS学习之路八(GCD与多线程)
GCD,全称Grand Central Dispath,是苹果开发的一种支持并行操作的机制.它的主要部件是一个FIFO队列和一个线程池,前者用来添加任务,后者用来执行任务. GCD中的FIFO队列称为 ...
- python学习之路 八 :面向对象编程基础
本节重点 了解面向对象.面向过程的区别 掌握什么是类,什么是对象 掌握如何定义及使用类和对象 了解类与对象间的关系 掌握类属性和实例属性 掌握绑定方法 一.编程范式 编程即写程序or写代码 ...
- Go数组遍历与排序
遍历数组 Go遍历数组有两种方式 1.按照数组下标进行遍历 2.用range遍历 package main import ( "fmt" ) func main() { // 声明 ...
- Go语言学习笔记八: 数组
Go语言学习笔记八: 数组 数组地球人都知道.所以只说说Go语言的特殊(奇葩)写法. 我一直在想一个人参与了两种语言的设计,但是最后两种语言的语法差异这么大.这是自己否定自己么,为什么不与之前统一一下 ...
随机推荐
- 大话设计模式C++达到-文章16章-国家模式
一.UML画画 二.概念 状态模式(State):当一个对象的内在状态改变时同意改变其行为.这个对象看起来像是改变了其类. 三.说明 以下是来自书本和网络的对状态模式的定义和分析: (1)状态模式同意 ...
- CSharp设计模式读书笔记(21):状态模式(学习难度:★★★☆☆,使用频率:★★★☆☆)
模式角色与结构: 示例代码:(本示例在具体状态类中实现状态切换,也可以在环境类中实现状态切换.状态模式一定程度上违背开闭原则) using System; using System.Collectio ...
- LeetCode: Best Time to Buy and Sell Stock II [122]
[题目] Say you have an array for which the ith element is the price of a given stock on day i. Design ...
- Codeforces 484B Maximum Value(高效+二分)
题目链接:Codeforces 484B Maximum Value 题目大意:给定一个序列,找到连个数ai和aj,ai%aj尽量大,而且ai≥aj 解题思路:类似于素数筛选法的方式,每次枚举aj,然 ...
- 谢绝艳照门 - 手把手教你把当今很hit的家庭监控IP Camera变得网络安全起来
IP Camerars现在已经越来越便宜了,很多人都可以买得起,并且大家也乐意去购买,因为它们的确是用来监控你在高房价的中国购买的爱巢的非常便利的设备.当然,配套的监控应用也层出不穷,从通用的家庭安全 ...
- ASP.NET MVC企业级项目框架
ASP.NET MVC企业级项目框架 MVC项目搭建笔记---- 项目框架采用ASP.NET MVC+Entity Framwork+Spring.Net等技术搭建,搭建过程内容比较多,结合了抽象工厂 ...
- 【剑指offer】员工年龄排序
典型的以空间换时间问题,思路非常重要! /* 员工年龄排序 员工可能有几万名,要求时间复杂度为O(n) 思路:员工的年龄必定在一个范围内,比方0-99,那么我们建立一个大小为100的辅助数组,然后遍历 ...
- Java 之复合赋值运算符
1.引入问题 切入正题,看下面代码,结果应该是怎么样的 public class App{ public static void main( String[] args ){ byte a=1 ; i ...
- Your build host version of Xamarin.IOS (release NO.)is too recent to work with the IOS designer
Encounted such error in VS after I update the xamarin at Mac side.Here is the solution for u to refe ...
- 经历:asp.net oracle 部署问题以及解决方法
原文:[原创]经历:asp.net oracle 部署问题以及解决方法 精简的美丽...... 一.环境 开发环境 win7 64bit Vs2010 ...