OC的数组对象的基本方法的使用:因为OC的数组中存储的为对象类型,所以我们可以新建一个Person类,通过Person生成对象进行操作。

其中Person.h中的代码为:

 
01.#import<Foundation/Foundation.h>
02.@interfacePerson: NSObject{
03.  NSString * _name;//姓名
04.  NSString * _sex;//性别
05.  NSInteger _age;//年龄
06.}
07.-(NSInteger) age;
08.-(id) initWithName: (NSString*)name sex: (NSString*)sex age: (NSInteger)age;
09.-(void) sayHi;
10.-(NSComparisonResult) compareByAge: (Person*) per;
11.//当%@打印时,内部就自动调用该对象的description方法。
12.//重写父类的description方法
13.-(NSString*) description;
14.@end

Person.m中实现:

01.#import"Person.h"
02.@implementation Person
03.-(id) initWithName: (NSString*)name sex: (NSString*)sex age: (NSInteger)age{
04.  self = [super init];
05.  if (nil != self){
06.    _name = name;
07.    _sex = sex;
08.    _age = age;
09.  }
10.  return self;
11.}
12.-(NSInteger) age{
13.  return _age;
14.}
15.-(void) sayHi{
16.  NSLog(@"name:%@,sex:%@,age:%ld", _name, _sex, _age);
17.}
18.-(NSComparisonResult) compareByAge: (Person*) per{
19.//self拿到当前对象,per拿到另外一个对象
20.//两个对象比较年龄
21.  if ([self age] < [per age]) {
22.    return NSOrderedAscending; //-1
23.  }else if ([self age] == [per age]){
24.    return NSOrderedSame; //0
25.  }else{
26.    return NSOrderedDescending; //1
27.  }
28.}
29.//当%@打印时,内部就自动调用该对象的description方法。
30.//重写父类的description方法
31.-(NSString*) description{
32.  return [NSString stringWithFormat: @"%@,%@,%ld", _name, _sex, _age];
33.}
34.@end

main.m中的完整代码为:

001.#import<Foundation/Foundation.h>
002.#import"Person.h"
003.int main (int argc, const char * argv[])
004.{
005.  @autoreleasepool{
006.//先创建三个Person对象
007.    Person * per1 = [[Person alloc] initWithName: @"zhangsan" sex: @"man" age: 23];
008.    Person * per2 = [[Person alloc] initWithName: @"lisi" sex: @"woman" age: 18];
009.    Person * per3 = [[Person alloc] initWithName: @"wangwu" sex: @"man" age: 18];
010.    Person * per4;
011.//创建数组对象,用来存储三个Person对象。
012.//对于OC中的数组,用来存储多个对象,并且对象的类型可以任意的。
013.//1.initWithObjects:用来初始化数组的时候一次性存储多个对象,冒号之后填写数组中要存放的对象,也就是数组元素,对象与对象之间通过逗号分隔,最后以nil作为数组元素初始化的结束,也就是说在nil之前有几个对象,数组中就存入几个对象,在nil之后的对象都不会存放到数组中。
014.//数组是一个有序的结合,也就是先放入数组的对象会在数组的最前端,后放入的会在后面,有先后顺序。
015.//并且数组和C语言中的数组非常相似,也具有下标的概念,每个元素都有对应的下标,下标的范围也是从0开始,到数组元素个数-1,并且,数组的下标不能越界。
016.    NSArray * per = [[NSArray alloc] initWithObjects: per1, per2, per3, per2, nil];
017. 
018.//2.如何求得数组元素的个数
019.    NSUInteger count = [per count];
020.    NSLog(@"count=%lu", count);
021. 
022.//3.根据索引值获取对象
023.//objectAtIndex:根据给定的下标,获取该下标在数组中对应的元素
024.//Person * person = [per objectAtIndex: 0];
025.//用来获取数组中的第一个元素
026.    Person * person1 = [per firstObject];
027.//[person sayHi];
028.    [person1 sayHi];
029.//获取最后一个元素
030.    Person * person2 = [per lastObject];
031.    [person2 sayHi];
032. 
033.    Person * person3 = [per objectAtIndex: [percount]-1];
034.    [person3 sayHi];
035. 
036.//4.获取对象对应的索引值
037.//根据指定对象获取的永远是该对象对应的第一个下标。
038.//如果指定对象不在该数组中,则返回一个无穷大的数LONG_MAX
039.    NSUInteger index = [per indexOfObject: per4];
040.    NSLog(@"index = %lu", index);
041.//5.判断两个数组是否相同。
042.    NSArray * newArr = [NSArray arrayWithObjects: per1, per2, per3, nil];
043.//判断newArr和per是否相同
044. 
045.//isEqualToArray:判断两个数组中的内容是否相等(也就是数组内的元素是否对应相等)
046.    BOOL isEqual = [per isEqualToArray: newArr];
047.    NSLog(@"%d", isEqual);
048. 
049.//(1).数组是一个有序的集合,先添加的元素会在数组的前部。
050.//(2).数组中的元素可以重复。
051.    NSLog(@"count = %ld", [per count]);
052. 
053.//用来判断两个对象是否相等(也就是两个是否是同一个对象)
054.//对于集合,如果使用isEqual:或者isEqualTo:方法,则内部实现也是比较集合内的元素是否对应相等。
055.    BOOL isEqual1 = [per isEqualTo: newArr];
056.    NSLog(@"isEqual = %d", isEqual1);
057. 
058.    NSSet * set1 = [NSSet setWithArray: per];
059.    NSSet * set2 = [NSSet setWithArray: newArr];
060.    BOOL is = [set1 isEqualTo: set2];
061.    NSLog(@"is ---> %d", is);
062. 
063.//6.数组排序,升序排列
064.    NSArray * strArr = [NSArray arrayWithObjects: @"bb", @"cc", @"aa", @"dd", @"ff", @"bb", nil];
065.    NSLog(@"%@", strArr);
066.//selector方法选择器
067.//假设数组中的每一个对象都是字符串对象,我们使用字符串自带的比较方法compare:
068.//
069.    NSArray * sortArray = [strArr sortedArrayUsingSelector: @selector(compare:)];
070.    NSLog(@"%@", sortArray);
071. 
072.//创建一个新的数组,里面有四个Person类型的对象,然后对数组按Person的年龄来进行升序排列
073.    Person * pers1 = [[Person alloc] initWithName: @"zhangsan" sex: @"man" age: 23];
074.    Person * pers2 = [[Person alloc] initWithName: @"lisi" sex:@ "woman" age: 18];
075.    Person * pers3 = [[Person alloc] initWithName: @"wangwu" sex: @"man" age: 18];
076.    Person * pers4 = [[Person alloc] initWithName: @"zhangsan" sex: @"man" age: 25];
077.    Person * pers5 = [[Person alloc] initWithName: @"lisi" sex: @"woman" age: 17];
078.    Person * pers6 = [[Person alloc] initWithName: @"wangwu" sex: @"man" age: 19];
079. 
080.    NSArray * perArr = [NSArray arrayWithObjects: pers1, pers2, pers3, pers4, pers5, pers6, nil];
081.    NSArray * sortArr = [perArr sortedArrayUsingSelector: @selector(compareByAge:)];
082.    NSLog(@"%@", sortArr);
083. 
084.//7.对数组遍历
085.    for (int i = 0 ; i < [perArr count] ; i++){
086.//根据下标获取数组元素
087.      Person * per = [perArr objectAtIndex: i];
088. 
089.//输出per的信息
090.//     NSLog(@"%@", [per description]);
091.      [per sayHi];
092.    }
093. 
094.//快速遍历数组
095.//从集合中依次将其中的元素一一取出
096.    for (Person * pinperArr){
097.      [per sayHi];
098.    }
099. 
100.  }
101.  return 0;
102. 
103.}

oc_转_类的数组的实现和操作的更多相关文章

  1. 方法引用_通过this引用本类的成员方法和方法引用_类的构造器(构造方法)引用和数组的构造器引用

    package com.yang.Test.ThisMethodReference; /** * 通过this引用本类的成员方法 */ public class Husband { //定义一个买房子 ...

  2. C++_进阶之函数模板_类模板

     C++_进阶之函数模板_类模板 第一部分 前言 c++提供了函数模板(function template.)所谓函数模板,实际上是建立一个通用函数,其函数类型和形参类型不具体制定,用一个虚拟的类型来 ...

  3. Unit02-OOP-对象和类,数组(下)

    Unit02-OOP-对象和类,数组(下) 1.方法的签名: 方法名+参数列表 2.方法的重载(Overload):  1)发生在一个类中,方法名称相同,参数列表不同  2)编译器在编译时自动根据签名 ...

  4. 转:C/C++中,空数组、空类、类中空数组的解析及其作用

    转自:http://blog.sina.com.cn/s/blog_93b45b0f01015s95.html 我们经常会遇到这些问题: (1)C++中定义一个空类,他们它的大小(sizeof) 为多 ...

  5. Java:IO流其他类(字节数组流、字符数组流、数据流、打印流、Properities、对象流、管道流、随机访问、序列流、字符串读写流)

    一.字节数组流: 类 ByteArrayInputStream:在构造函数的时候,需要接受数据源,而且数据源是一个字节数组. 包含一个内部缓冲区,该缓冲区包含从流中读取的字节.内部计数器跟踪 read ...

  6. 定义Java类的数组的问题

    定义了一个类: class Student{ private int Id; public int getId() { return Id; } public void setId(int id) { ...

  7. BZOJ_5055_膜法师_树状数组+离散化

    BZOJ_5055_膜法师_树状数组+离散化 Description 在经历过1e9次大型战争后的宇宙中现在还剩下n个完美维度, 现在来自多元宇宙的膜法师,想偷取其中的三个维度为伟大的长者续秒, 显然 ...

  8. BZOJ_3653_谈笑风生_树状数组

    BZOJ_3653_谈笑风生_树状数组 Description 设T 为一棵有根树,我们做如下的定义: ? 设a和b为T 中的两个不同节点.如果a是b的祖先,那么称“a比b不知道 高明到哪里去了”. ...

  9. BZOJ_3196_Tyvj 1730 二逼平衡树_树状数组套主席树

    BZOJ_3196_Tyvj 1730 二逼平衡树_树状数组套主席树 Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排 ...

随机推荐

  1. Java学习笔记之:Java数据类型的转换

    一.介绍 数据类型的转换,分为自动转换和强制转换.自动转换是程序在执行过程中“悄然”进行的转换,不需要用户提前声明,一般是从位数低的类型向位数高的类型转换:强制类型转换则必须在代码中声明,转换顺序不受 ...

  2. 利用纯真ip地址库 查询 ip所属地

    1. 首先下周数据源,选择是纯真数据库:http://www.cz88.net/ 2. 安装后,打开软件,将数据导出为txt格式. 3. 处理数据,参照网上的文章(http://www.jb51.ne ...

  3. class卸载、热替换和Tomcat的热部署的分析

    一 class的热替换 ClassLoader中重要的方法 loadClassClassLoader.loadClass(...) 是ClassLoader的入口点.当一个类没有指明用什么加载器加载的 ...

  4. underscore.js 一个强大的js函数库

    Underscore提供的100多个函数,主要涉及对Collection.Object.Array.Function的操作: Collections(集合) each, map, reduce, re ...

  5. 【转载】Morris遍历二叉树 & BST(二叉搜索树) Traverse & 空间O(1) 时间O(n)

    因为做一道Leetcode的题目(前面博客有:link),需要用Space O(1)空间复杂度来中序遍历树, 看了Discuss,也上网搜了一下,发现空间O(1)可以用 Morris遍历的方法.方法介 ...

  6. combination-sum-ii(熟悉下Java排序)

    代码还是这一块代码,但是还是写的很慢.. 其中用到了Java对 List的排序.查了很久,发现使用 Collections.sort 很方便. 另外对结果的去重,使用了 Java的HashSet. h ...

  7. 如何过滤 adb logcat 输出

    对原作者表示感谢,转自博客:http://www.otechu.me/zh/2011/12/filtering-adb-logcat-output/ 本文介绍如何在 shell 命令行中过滤 adb ...

  8. UVa 12716 (GCD == XOR) GCD XOR

    题意: 问整数n以内,有多少对整数a.b满足(1≤b≤a)且gcd(a, b) = xor(a, b) 分析: gcd和xor看起来风马牛不相及的运算,居然有一个比较"神奇"的结论 ...

  9. UVa 10791 (唯一分解) Minimum Sum LCM

    题意: 输入n,求至少两个正整数,使得这些数的最小公倍数为n且和最小. 分析: 设n的分解式为,很显然单独作为一项,和最小. 这里有两个小技巧: 从2开始不断的除n,直到不能整除为止.这样就省去了素数 ...

  10. 【linux】命令

    pwd 显示路径 whereis jupyterhub find / -name base.py reboot 重启 grep