oc_转_类的数组的实现和操作
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_转_类的数组的实现和操作的更多相关文章
- 方法引用_通过this引用本类的成员方法和方法引用_类的构造器(构造方法)引用和数组的构造器引用
package com.yang.Test.ThisMethodReference; /** * 通过this引用本类的成员方法 */ public class Husband { //定义一个买房子 ...
- C++_进阶之函数模板_类模板
C++_进阶之函数模板_类模板 第一部分 前言 c++提供了函数模板(function template.)所谓函数模板,实际上是建立一个通用函数,其函数类型和形参类型不具体制定,用一个虚拟的类型来 ...
- Unit02-OOP-对象和类,数组(下)
Unit02-OOP-对象和类,数组(下) 1.方法的签名: 方法名+参数列表 2.方法的重载(Overload): 1)发生在一个类中,方法名称相同,参数列表不同 2)编译器在编译时自动根据签名 ...
- 转:C/C++中,空数组、空类、类中空数组的解析及其作用
转自:http://blog.sina.com.cn/s/blog_93b45b0f01015s95.html 我们经常会遇到这些问题: (1)C++中定义一个空类,他们它的大小(sizeof) 为多 ...
- Java:IO流其他类(字节数组流、字符数组流、数据流、打印流、Properities、对象流、管道流、随机访问、序列流、字符串读写流)
一.字节数组流: 类 ByteArrayInputStream:在构造函数的时候,需要接受数据源,而且数据源是一个字节数组. 包含一个内部缓冲区,该缓冲区包含从流中读取的字节.内部计数器跟踪 read ...
- 定义Java类的数组的问题
定义了一个类: class Student{ private int Id; public int getId() { return Id; } public void setId(int id) { ...
- BZOJ_5055_膜法师_树状数组+离散化
BZOJ_5055_膜法师_树状数组+离散化 Description 在经历过1e9次大型战争后的宇宙中现在还剩下n个完美维度, 现在来自多元宇宙的膜法师,想偷取其中的三个维度为伟大的长者续秒, 显然 ...
- BZOJ_3653_谈笑风生_树状数组
BZOJ_3653_谈笑风生_树状数组 Description 设T 为一棵有根树,我们做如下的定义: ? 设a和b为T 中的两个不同节点.如果a是b的祖先,那么称“a比b不知道 高明到哪里去了”. ...
- BZOJ_3196_Tyvj 1730 二逼平衡树_树状数组套主席树
BZOJ_3196_Tyvj 1730 二逼平衡树_树状数组套主席树 Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 1.查询k在区间内的排 ...
随机推荐
- Java学习笔记之:Java数据类型的转换
一.介绍 数据类型的转换,分为自动转换和强制转换.自动转换是程序在执行过程中“悄然”进行的转换,不需要用户提前声明,一般是从位数低的类型向位数高的类型转换:强制类型转换则必须在代码中声明,转换顺序不受 ...
- 利用纯真ip地址库 查询 ip所属地
1. 首先下周数据源,选择是纯真数据库:http://www.cz88.net/ 2. 安装后,打开软件,将数据导出为txt格式. 3. 处理数据,参照网上的文章(http://www.jb51.ne ...
- class卸载、热替换和Tomcat的热部署的分析
一 class的热替换 ClassLoader中重要的方法 loadClassClassLoader.loadClass(...) 是ClassLoader的入口点.当一个类没有指明用什么加载器加载的 ...
- underscore.js 一个强大的js函数库
Underscore提供的100多个函数,主要涉及对Collection.Object.Array.Function的操作: Collections(集合) each, map, reduce, re ...
- 【转载】Morris遍历二叉树 & BST(二叉搜索树) Traverse & 空间O(1) 时间O(n)
因为做一道Leetcode的题目(前面博客有:link),需要用Space O(1)空间复杂度来中序遍历树, 看了Discuss,也上网搜了一下,发现空间O(1)可以用 Morris遍历的方法.方法介 ...
- combination-sum-ii(熟悉下Java排序)
代码还是这一块代码,但是还是写的很慢.. 其中用到了Java对 List的排序.查了很久,发现使用 Collections.sort 很方便. 另外对结果的去重,使用了 Java的HashSet. h ...
- 如何过滤 adb logcat 输出
对原作者表示感谢,转自博客:http://www.otechu.me/zh/2011/12/filtering-adb-logcat-output/ 本文介绍如何在 shell 命令行中过滤 adb ...
- UVa 12716 (GCD == XOR) GCD XOR
题意: 问整数n以内,有多少对整数a.b满足(1≤b≤a)且gcd(a, b) = xor(a, b) 分析: gcd和xor看起来风马牛不相及的运算,居然有一个比较"神奇"的结论 ...
- UVa 10791 (唯一分解) Minimum Sum LCM
题意: 输入n,求至少两个正整数,使得这些数的最小公倍数为n且和最小. 分析: 设n的分解式为,很显然单独作为一项,和最小. 这里有两个小技巧: 从2开始不断的除n,直到不能整除为止.这样就省去了素数 ...
- 【linux】命令
pwd 显示路径 whereis jupyterhub find / -name base.py reboot 重启 grep