Block,多态,数组排序

本文介绍了C语言中的五大内存区域:栈区、堆区、全局静态区、常量区和代码区,并通过实例展示了Objective-C中数组的排序方法,包括字符串排序和对象属性排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.回忆C语言中5大区的地址
(1)栈区
int a=10;
NSLog(@”%p”,&a);
2015-07-28 19:06:00.999 OC10_Block[3922:303] 0x7fff5fbff85c
(2)堆区
int *p=malloc(40);
NSLog(@”%p”,p);
2015-07-28 19:06:01.001 OC10_Block[3922:303] 0x100200500
(3)全局静态区
static int b=10;
NSLog(@”%p”,&b);
2015-07-28 19:06:01.001 OC10_Block[3922:303] 0x1000023f0
(4)常量区
// 常量字符串:保存常量字符串首字母地址
char *str=”iPhone”;
NSLog(@”%p”,str);
2015-07-28 19:56:14.311 OC10_Block[4272:303] 0x100001f75
(5)代码区
main.m

import

import

import

import “BaseModel.h”

@implementation BaseModel

-(id)initWithName:(NSString *)name
sex:(NSString *)sex{
self=[super init];
if (self) {
self.name=name;
self.sex=sex;
}
return self;
}

+(id)baseWithName:(NSString *)name
sex:(NSString *)sex{
// 多态的方式完成对象的创建
id obj=[[[self class] alloc] initWithName:name sex:sex];
return obj;
}
@end
// 创建BaseModel 的子类 Person
6.多态
Person *per=[Person baseWithName:@”张三” sex:@”男”];
NSLog(@”%@”,per.sex);
2015-07-28 20:25:41.672 OC10_Block[4581:303] 男
7.数组排序
(1)数组对字符串的排序
[1]不可变数组
NSArray *arr=@[@”zhangsan”,@”lisi”,@”wangermazi”,@”zhaoliu”,@”wangwu”];
// SEL是方法选择器,它是方法选择器的类型
NSArray *arrNew=[arr sortedArrayUsingSelector:@selector(compare:)];
NSLog(@”%@”,arrNew);
NSLog(@”%@”,arr);
2015-07-28 20:27:08.687 OC10_Block[4613:303] (
lisi,
wangermazi,
wangwu,
zhangsan,
zhaoliu
)
2015-07-28 20:27:08.689 OC10_Block[4613:303] (
zhangsan,
lisi,
wangermazi,
zhaoliu,
wangwu
)
[2]可变数组
NSMutableArray *arr=[NSMutableArray arrayWithObjects:@”zhangsan”,@”lisi”,@”wangermazi”,@”zhaoliu”,@”wangwu”, nil];
[arr sortUsingSelector:@selector(compare:)];
NSLog(@”%@”,arr);
2015-07-28 20:27:59.836 OC10_Block[4624:303] (
lisi,
wangermazi,
wangwu,
zhangsan,
zhaoliu
)
(2)对对象进行排序
// 新建四个人的对象
Person *per1=[Person baseWithName:@”张三” sex:@”男”];
Person *per2=[Person baseWithName:@”李四” sex:@”男”];
Person *per3=[Person baseWithName:@”王五” sex:@”女”];
Person *per4=[Person baseWithName:@”赵六” sex:@”女”];
[1]不可变数组
// 以学生的姓名作为排序的依据
// 加个”-“号 降序,否则为升序
NSArray *arr=@[per1,per2,per3,per4];
NSArray newArr=[arr sortedArrayUsingComparator:^NSComparisonResult(Person obj1, Person * obj2) {
return -[obj1.name compare:obj2.name];
}];
for (Person *per in newArr) {
NSLog(@”%@”,per.name);
}
2015-07-28 20:30:15.080 OC10_Block[4651:303] 赵六
2015-07-28 20:30:15.098 OC10_Block[4651:303] 王五
2015-07-28 20:30:15.099 OC10_Block[4651:303] 李四
2015-07-28 20:30:15.099 OC10_Block[4651:303] 张三
[2]可变数组
// id不改,下面就得转换
NSMutableArray *arr=[NSMutableArray arrayWithObjects:per1,per2,per3,per4, nil];
[arr sortUsingComparator:^NSComparisonResult(id obj1, id obj2) {
Person per11=(Person )obj1;
Person per22=(Person )obj2;
return [per11.name compare:per22.name];
}];
for (Person *per in arr) {
NSLog(@”%@”,per.name);
}
2015-07-28 20:31:52.934 OC10_Block[4684:303] 张三
2015-07-28 20:31:52.936 OC10_Block[4684:303] 李四
2015-07-28 20:31:52.936 OC10_Block[4684:303] 王五
2015-07-28 20:31:52.937 OC10_Block[4684:303] 赵六

资源下载链接为: https://pan.quark.cn/s/d9ef5828b597 在本文中,我们将探讨如何通过 Vue.js 实现一个带有动画效果的“回到顶部”功能。Vue.js 是一款用于构建用户界面的流行 JavaScript 框架,其组件化和响应式设计让实现这种交互功能变得十分便捷。 首先,我们来分析 HTML 代码。在这个示例中,存在一个 ID 为 back-to-top 的 div 元素,其中包含两个 span 标签,分别显示“回到”和“顶部”文字。该 div 元素绑定了 Vue.js 的 @click 事件处理器 backToTop,用于处理点击事件,同时还绑定了 v-show 指令来控制按钮的显示与隐藏。v-cloak 指令的作用是在 Vue 实例渲染完成之前隐藏该元素,避免出现闪烁现象。 CSS 部分(backTop.css)主要负责样式设计。它首先清除了一些默认的边距和填充,对 html 和 body 进行了全屏布局,并设置了相对定位。.back-to-top 类则定义了“回到顶部”按钮的样式,包括其位置、圆角、阴影、填充以及悬停时背景颜色的变化。此外,与 v-cloak 相关的 CSS 确保在 Vue 实例加载过程中隐藏该元素。每个 .page 类代表一个页面,每个页面的高度设置为 400px,用于模拟多页面的滚动效果。 接下来是 JavaScript 部分(backTop.js)。在这里,我们创建了一个 Vue 实例。实例的 el 属性指定 Vue 将挂载到的 DOM 元素(#back-to-top)。data 对象中包含三个属性:backTopShow 用于控制按钮的显示状态;backTopAllow 用于防止用户快速连续点击;backSeconds 定义了回到顶部所需的时间;showPx 则规定了滚动多少像素后显示“回到顶部”按钮。 在 V
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值