- 【iOS】—— 事件传递链和响应者链总结
《杯莫停》
iosmacoscocoa
事件传递链和响应者链总结1.事件传递链:事件传递链:传递流程:总结第一响应者:2.响应者链响应者链传递流程总结响应者链流程总结:之前也学习过这个内容这次在复习的时候,就想着写一下总结:初始事件传递链和响应者链1.事件传递链:事件传递链:将用户在应用程序中的进行交互的事件发送到视图层次中的适当对象。在这个事件的传递过程中,从根视图开始查找,并递归向下查找最合适的处理该事件的视图(第一响应者)。传递流
- Cocoa基本原理指南之十一 - Cocoa设计模式
iteye_20746
设计模式移动开发xcode
Cocoa设计模式Cocoa环境的很多架构和机制都有效地使用了设计模式:即为特定上下文中反复出现的问题提供解决方案的抽象设计。Cocoa中设计模式的实现有不同的形式。下面部分中描述的一些设计—比如协议和范畴—是Objective-C语言的特性;在另外一些场合中,“模式的实例”被实现为一个类或一组相关的类(比如类簇和单件类);还有一些场合下,模式表现为一个大的框架结构,比如响应者链模式。抽象工厂模式
- iOS响应者链(Responder Chain)
__life__
一定义响应者链就是由一系列的响应者对象(响应和处理事件能力的对象,一般为UIResponder实例或子类实例)构成的一个层次结构(或者链条),它的作用是能让多个控件处理同一个触摸事件。第一响应者(FirstResponder)指的是当前接受触摸的响应者对象,即表示当前该对象正在与用户交互,它是响应者链的开端。整个响应者链和事件分发的重点就是找第一响应者。
- iOS开发:浅谈响应链与事件传递
恍然如梦_b700
基本概念响应者:在iOS中,响应者为能响应事件的UIResponder子类对象,如UIButton、UIView等。响应链:响应链是由链接在一起的响应者(UIResponse子类)组成的。默认情况下,响应链是由第一响应者,到application对象以及中间所有响应者一起组成的。事件传递:获得响应链后,将事件由第一响应者往application传递的过程即为事件传递。响应链响应者链执行的过程1、寻
- iOS 响应者链
安静的电动棒
iOSiosobjective-cxcode
1.源起最近在面试,好基友池子跑过来对我说:响应者链这是个必考点,一般会这么问:响应者事件传递顺序是什么,响应者的响应顺序是什么?池子认为事件传递的过程是自上而下的,事件响应是自下而上而上的。为此和池子争论了一番。争议点在事件传递上,就此达成一致的是响应者链的顺序是自上而下的。Jeverson认为响应者链寻找最合适的(第一响应者)响应者调用HitTest的过程–事件响应,找到第一响应者发现没有相应
- 事件的传递和响应者链
小怪兽鱼小宝
当我们手指点击了屏幕上的某一点的时候,究竟会发生什么,比如点击了UIView或者UIButton。这里面就牵扯到事件的分发传递和响应链。我们先看看事件的分发吧。事件的分发和传递。1.当iOS程序中发生触摸事件后,系统会将事件加入到UIApplication管理的一个任务队列中2.UIApplication将处于任务队列最前端的事件向下分发。即UIWindow。3.UIWindow将事件向下分发,即
- iOS事件传递和响应者链
你duck不必呀
iOS中的事件触摸事件,加速事件(摇一摇),远程控制事件(耳机线控,窗口播放)以最常见的触摸事件为例,当触摸手机屏幕时操作系统会将这个事件添加到由UIApplication管理的事件队列中(FIFO)UIApplication发送事件到应用程序的主窗口(Window)Window会在图层结构中找到最合适的图层来处理事件。UIResponderUIResponder类是专门用来响应用户的操作处理各种
- iOS:事件传递,响应者链传递机制
KevinChein
如何寻找最合适的view:事件传递1.主窗口接收到应用程序传递过来的事件后,首先判断自己能否接手触摸事件。如果能,那么在判断触摸点在不在窗口自己身上2.如果触摸点也在窗口身上,那么窗口会从后往前遍历自己的子控件(遍历自己的子控件只是为了寻找出来最合适的view)3.遍历到每一个子控件后,又会重复上面的两个步骤(传递事件给子控件,1.判断子控件能否接受事件,2.点在不在子控件上)4.如此循环遍历子控
- 响应者链概述
Tmylyh
iosios
响应者链iOS事件的3大类型TouchEvents(触摸事件)MotionEvents(运动事件,比如重力感应和摇一摇等)RemoteEvents(远程事件,比如用耳机上得按键来控制手机)触摸事件处理触摸事件的两个步骤寻找事件的最佳响应者事件的响应在响应链中的传递寻找事件的最佳响应者当我们触摸屏幕的某个可响应的功能点后,最终都会由UIView或者继承UIView的控件来响应。每个UIView对象都
- iOS响应者链详解
暮云_开发
iOS程序的响应链是一个非常有意思的事情,明确了响应链的调用顺序,那么就可以在响应链中操作响应的对象,这样有助于实现一些特殊的需求,比如控件重写,自定义控件的响应顺序。这里先明确几个概念UIEvent->是事件本身,事件中包含三种状态的事件,Touch屏幕触摸事件、Motion感应事件(例如摇晃)、Remote远程事件(其他比如手表、手环之类)UIResponder->响应者,专门来响应用户的事件
- 事件响应者链
雷3雷
响应者链响应者链条概念:iOS系统检测到手指触摸(Touch)操作时会将其打包成一个UIEvent对象,并放入当前活动Application的事件队列,单例的UIApplication会从事件队列中取出触摸事件并传递给单例的UIWindow来处理,UIWindow对象首先会使用hitTest:withEvent:方法寻找此次Touch操作初始点所在的视图(View),即需要将触摸事件传递给其处理的
- iOS UIView用户事件响应(exclusiveTouch,触摸响应,手势)
搞飞机大坏蛋
UIView除了负责展示内容给用户外还负责响应用户事件。本章主要介绍UIView用户交互相关的属性和方法。1、交互相关的属性userInteractionEnabled默认是YES,如果设置为NO则不响应用户事件,并且把当前控件从事件队列中删除。也就是说设置了userInterfaceEnabled属性的视图会打断响应者链导致该view的subview都无法响应事件。multipleTouchEn
- IOS面试问题总结
海阔天空_栋
IOS开发面试ios
通过网络搜寻和自己总结经历找了一些IOS面试经常被问道的问题:1.搞清楚touch事件的传递(事件的响应链)事件的响应(responderchain)只有继承了UIResponder的类才能响应touch事件,从上图的响应者链可以看出,优先是最上层的view响应事件,如果该view有视图控制器的话会是下一个响应者,否者就是该view的父视图,这样至上而下传递事件。直到单例UIWindow对象,最后
- 40道iOS面试问题总结
weixin_34363171
1.搞清楚touch事件的传递(事件的响应链)事件的响应(responderchain)只有继承了UIResponder的类才能响应touch事件,从上图的响应者链可以看出,优先是最上层的view响应事件,如果该view有视图控制器的话会是下一个响应者,否者就是该view的父视图,这样至上而下传递事件。直到单例UIWindow对象,最后是单例UIApplication对象以终止,UIApplica
- IOS面试经常被问到的问题
hgzds
iOSiOS
1.搞清楚touch事件的传递(事件的响应链)事件的响应(responderchain)只有继承了UIResponder的类才能响应touch事件,从上图的响应者链可以看出,优先是最上层的view响应事件,如果该view有视图控制器的话会是下一个响应者,否者就是该view的父视图,这样至上而下传递事件。直到单例UIWindow对象,最后是单例UIApplication对象以终止,UIApplica
- iOS事件传递、响应者链、hitTest、pointInside
牧羊的诗人
一、什么是事件传递发生触摸事件后,系统会将该事件加入到一个由UIApplication管理的事件队列中,并将事件分发下去以便处理。通常,会先发送事件给应用程序的keyWindow,主窗口会在其视图层次结构中找到一个最合适的视图来处理触摸事件,这个找寻的过程就是事件传递。二、事件传递的过程1.事件传递的方向。window->父视图->子视图->子视图的子视图我们可以这个方向简单理解成从内到外。2.两
- 面试题 -- 基础知识
旭日猎鹰
面试题面试
文章目录1.深拷贝和浅拷贝的区别2.懒加载模式3.frame和bounds有什么不同?4.Whatispushnotification?推送实现5.什么是序列化?6.什么是安全释放7.响应者链8.简述沙盒机制1.深拷贝和浅拷贝的区别浅拷贝是指针拷贝,对一个对象进行浅拷贝,相当于对指向对象的指针进行复制,产生一个新的指向这个对象的指针,对象销毁后两个指针都应该置空;深拷贝是对一个对象进行拷贝,相当于
- iOS 通过UIView对象找到对其所在UIViewController
emily_sky
一、实现原理:通过消息响应者链找到UIView所在的UIViewControllerUIView类继承于UIResponder,通过UIResponder的next方法来获取UIViewController.如果next返回是空,则继续向上遍历superview并再次使用next方法获取。这样一直找下去,直到找到或抛出异常。二、实现代码通过扩展UIView,给其添加个viewController方
- 响应者链
傲骨天成科技
参考:http://www.javashuo.com/article/p-rigmnzyj-hm.html先执行事件链,找到合适的view,在执行响应链。一、事件链UIApplication->window->view->view……..->viewa.当iOS程序中发生触摸事件后,系统会将事件加入到UIApplication管理的一个任务队列中b.UIAplication将处于任务队列最前端的事
- iOS 响应者链
通哥
UIView响应事件满足的调节1.userInteractionEnabled=YES,该属性表示允许控件同用户交互2.hidden=NO;3.alpha>0.01;iOS接收到触摸事件,首先打包成UIEvent对象放到UIApplication中,UIApplication会从事件队列中取出触摸事件并传递给UIWindow;当用户手指触摸到屏幕莫一区域时,UIWindow查找其子控件,然后调用所
- 2020-06-16
派大星的博客
HTTP与HTTPS的区别深入理解iOSApp的启动过程从一道网易面试题浅谈OC线程安全深入理解TaggedPointerisa的本质__arm64__iOS-老生常谈内存管理(五):TaggedPointerSwiftABI稳定黑幕背后的Autorelease你所不知道的CALayer隐式动画及事务深入理解RunLoopiOS响应者链彻底掌握理解UITouch,UIEvent,UIGesture
- 2.2 谈谈你对事件的传递链和响应链的理解
哈库呐玛塔塔__
一.响应者链响应者链UIResponser包括了触摸信息的处理,比如开始、移动、停止等等。常见的UIresponser有UIView及其子类,UIViewController,AppDelegate,UIApplication等等。响应者链是由UIResponser组成的。,他是是按照哪种规则组成的呢?A:程序启动UIApplication会生成一个单例,并会关联一个APPDelegate。App
- 响应者链条
jameiShi
1.什么是事件响应链2.touch事件分发3.hit-test底层实现4.应用1.什么是事件响应链大多数事件的分发都是依赖响应链的。响应链是由一系列链接在一起的响应者(UIResponse子类)组成的。一般情况下,一条响应链开始于第一响应者,结束于application对象。如果一个响应者不能处理事件,则会将事件沿着响应链传到下一响应者。2.touch事件分发1.当用户触发某一事件(触摸事件或运动
- iOS 响应链原理与应用
风雨彩虹_123
前言iOS响应者链是支撑App界面交互的重要基础,点击、滑动、旋转、摇晃等都离不开其背后的响应者链,所以每个iOS开发人员都应该彻底掌握响应者链的响应逻辑。在iOS中不是任何对象都能处理事件,只有继承了UIResponder的对象才能接收并处理事件,我们称为响应者对象UIApplication,UIViewController,UIView都继承自UIResponder,因此他们都是响应者对象,都
- iOS-通过消息响应者链找到UIView所在的UIViewController
张国兵
消息响应者链
@interfaceUIView(FirstViewController)-(UIViewController*)firstViewController;-(id)traverseResponderChainForUIViewController;@end@implementationUIView(FirstViewController)-(UIViewController*)firstViewC
- iOS--响应者链条
刘海阳
响应者链条iOS
响应者链条是用来把事件往上抛1.把事件回传回去#import"RedView.h"@implementationRedView-(void)touchesBegan:(NSSet*)toucheswithEvent:(UIEvent*)event{NSLog(@"RedView-----touchesBegan");[supertouchesBegan:toucheswithEvent:event
- iOS- 响应者链条简介
Setoge
设计模式多线程ios响应者链条
在iOS中,事件可以分为三类:触摸事件(Multitouchevents),加速计事件(Acceleromterevents),远程控制事件(Remotecontrolevents)1.什么是响应者链条1)响应者链条就是由多个响应者对象连接起来的层次结构,响应者对象是继承自UIResponder的对象,能够处理事件.所有的view和viewController都是响应者对象.利用响应者链条我们可以
- iOS之深入解析响应者链Responder Chain
╰つ栺尖篴夢ゞ
iOS高级进阶iOS的响应链事件什么是响应者链?完整的触摸过程响应者链的事件传递过程如何监听触摸事件?
一、响应链事件iOS中的事件可分为:触摸事件(multitouchevents)、加速计事件(accelerometerevents)、远程控制事件(remotecontrolevents)。EventtypeFirstresponderToucheventsTheviewinwhichthetouchoccurredPresseventsTheobjectthathasfocusShake-mo
- iOS-响应者链条
喜欢吃布丁但是没有钱
iOS-生命周期响应者链条
背景:我建议读者们阅读该文章之前,先去看看我上一篇的文章:iOS-事件传递过程,因为事件传递过程是正向传递过程,而响应者链条是反向传递过程。什么是响应者链条?响应者链条,顾名思义,就是很多个响应者对象链接在一起,组合起来的一个链条。例如:UIApplication–>UIWindow–>白色UIView–>浅蓝色UIView响应者链条有什么用?有时候,我们想让当前视图,还有他的父视图都调用某个方法
- 【iOS】--响应者链
山河丘壑
iosobjective-c开发语言
响应者链iOS响应者链是一种事件处理机制,它描述了在iOS系统中,当一个事件(比如用户点击屏幕或者发送手势)发生时,它将从触发事件的源头开始,按照预定义的顺序传递给各个视图或控件进行处理,直到最终被处理或被丢弃。从本质上讲,苹果设备响应事件的整个过程可以分为两个步骤:步骤1:寻找目标。在iOS视图层次结构中找到触摸事件的最终接受者;步骤2:事件响应。基于iOS响应者链(ResponderChain
- JAVA基础
灵静志远
位运算加载Date字符串池覆盖
一、类的初始化顺序
1 (静态变量,静态代码块)-->(变量,初始化块)--> 构造器
同一括号里的,根据它们在程序中的顺序来决定。上面所述是同一类中。如果是继承的情况,那就在父类到子类交替初始化。
二、String
1 String a = "abc";
JAVA虚拟机首先在字符串池中查找是否已经存在了值为"abc"的对象,根
- keepalived实现redis主从高可用
bylijinnan
redis
方案说明
两台机器(称为A和B),以统一的VIP对外提供服务
1.正常情况下,A和B都启动,B会把A的数据同步过来(B is slave of A)
2.当A挂了后,VIP漂移到B;B的keepalived 通知redis 执行:slaveof no one,由B提供服务
3.当A起来后,VIP不切换,仍在B上面;而A的keepalived 通知redis 执行slaveof B,开始
- java文件操作大全
0624chenhong
java
最近在博客园看到一篇比较全面的文件操作文章,转过来留着。
http://www.cnblogs.com/zhuocheng/archive/2011/12/12/2285290.html
转自http://blog.sina.com.cn/s/blog_4a9f789a0100ik3p.html
一.获得控制台用户输入的信息
&nbs
- android学习任务
不懂事的小屁孩
工作
任务
完成情况 搞清楚带箭头的pupupwindows和不带的使用 已完成 熟练使用pupupwindows和alertdialog,并搞清楚两者的区别 已完成 熟练使用android的线程handler,并敲示例代码 进行中 了解游戏2048的流程,并完成其代码工作 进行中-差几个actionbar 研究一下android的动画效果,写一个实例 已完成 复习fragem
- zoom.js
换个号韩国红果果
oom
它的基于bootstrap 的
https://raw.github.com/twbs/bootstrap/master/js/transition.js transition.js模块引用顺序
<link rel="stylesheet" href="style/zoom.css">
<script src=&q
- 详解Oracle云操作系统Solaris 11.2
蓝儿唯美
Solaris
当Oracle发布Solaris 11时,它将自己的操作系统称为第一个面向云的操作系统。Oracle在发布Solaris 11.2时继续它以云为中心的基调。但是,这些说法没有告诉我们为什么Solaris是配得上云的。幸好,我们不需要等太久。Solaris11.2有4个重要的技术可以在一个有效的云实现中发挥重要作用:OpenStack、内核域、统一存档(UA)和弹性虚拟交换(EVS)。
- spring学习——springmvc(一)
a-john
springMVC
Spring MVC基于模型-视图-控制器(Model-View-Controller,MVC)实现,能够帮助我们构建像Spring框架那样灵活和松耦合的Web应用程序。
1,跟踪Spring MVC的请求
请求的第一站是Spring的DispatcherServlet。与大多数基于Java的Web框架一样,Spring MVC所有的请求都会通过一个前端控制器Servlet。前
- hdu4342 History repeat itself-------多校联合五
aijuans
数论
水题就不多说什么了。
#include<iostream>#include<cstdlib>#include<stdio.h>#define ll __int64using namespace std;int main(){ int t; ll n; scanf("%d",&t); while(t--)
- EJB和javabean的区别
asia007
beanejb
EJB不是一般的JavaBean,EJB是企业级JavaBean,EJB一共分为3种,实体Bean,消息Bean,会话Bean,书写EJB是需要遵循一定的规范的,具体规范你可以参考相关的资料.另外,要运行EJB,你需要相应的EJB容器,比如Weblogic,Jboss等,而JavaBean不需要,只需要安装Tomcat就可以了
1.EJB用于服务端应用开发, 而JavaBeans
- Struts的action和Result总结
百合不是茶
strutsAction配置Result配置
一:Action的配置详解:
下面是一个Struts中一个空的Struts.xml的配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
&quo
- 如何带好自已的团队
bijian1013
项目管理团队管理团队
在网上看到博客"
怎么才能让团队成员好好干活"的评论,觉得写的比较好。 原文如下: 我做团队管理有几年了吧,我和你分享一下我认为带好团队的几点:
1.诚信
对团队内成员,无论是技术研究、交流、问题探讨,要尽可能的保持一种诚信的态度,用心去做好,你的团队会感觉得到。 2.努力提
- Java代码混淆工具
sunjing
ProGuard
Open Source Obfuscators
ProGuard
http://java-source.net/open-source/obfuscators/proguardProGuard is a free Java class file shrinker and obfuscator. It can detect and remove unused classes, fields, m
- 【Redis三】基于Redis sentinel的自动failover主从复制
bit1129
redis
在第二篇中使用2.8.17搭建了主从复制,但是它存在Master单点问题,为了解决这个问题,Redis从2.6开始引入sentinel,用于监控和管理Redis的主从复制环境,进行自动failover,即Master挂了后,sentinel自动从从服务器选出一个Master使主从复制集群仍然可以工作,如果Master醒来再次加入集群,只能以从服务器的形式工作。
什么是Sentine
- 使用代理实现Hibernate Dao层自动事务
白糖_
DAOspringAOP框架Hibernate
都说spring利用AOP实现自动事务处理机制非常好,但在只有hibernate这个框架情况下,我们开启session、管理事务就往往很麻烦。
public void save(Object obj){
Session session = this.getSession();
Transaction tran = session.beginTransaction();
try
- maven3实战读书笔记
braveCS
maven3
Maven简介
是什么?
Is a software project management and comprehension tool.项目管理工具
是基于POM概念(工程对象模型)
[设计重复、编码重复、文档重复、构建重复,maven最大化消除了构建的重复]
[与XP:简单、交流与反馈;测试驱动开发、十分钟构建、持续集成、富有信息的工作区]
功能:
- 编程之美-子数组的最大乘积
bylijinnan
编程之美
public class MaxProduct {
/**
* 编程之美 子数组的最大乘积
* 题目: 给定一个长度为N的整数数组,只允许使用乘法,不能用除法,计算任意N-1个数的组合中乘积中最大的一组,并写出算法的时间复杂度。
* 以下程序对应书上两种方法,求得“乘积中最大的一组”的乘积——都是有溢出的可能的。
* 但按题目的意思,是要求得这个子数组,而不
- 读书笔记-2
chengxuyuancsdn
读书笔记
1、反射
2、oracle年-月-日 时-分-秒
3、oracle创建有参、无参函数
4、oracle行转列
5、Struts2拦截器
6、Filter过滤器(web.xml)
1、反射
(1)检查类的结构
在java.lang.reflect包里有3个类Field,Method,Constructor分别用于描述类的域、方法和构造器。
2、oracle年月日时分秒
s
- [求学与房地产]慎重选择IT培训学校
comsci
it
关于培训学校的教学和教师的问题,我们就不讨论了,我主要关心的是这个问题
培训学校的教学楼和宿舍的环境和稳定性问题
我们大家都知道,房子是一个比较昂贵的东西,特别是那种能够当教室的房子...
&nb
- RMAN配置中通道(CHANNEL)相关参数 PARALLELISM 、FILESPERSET的关系
daizj
oraclermanfilespersetPARALLELISM
RMAN配置中通道(CHANNEL)相关参数 PARALLELISM 、FILESPERSET的关系 转
PARALLELISM ---
我们还可以通过parallelism参数来指定同时"自动"创建多少个通道:
RMAN > configure device type disk parallelism 3 ;
表示启动三个通道,可以加快备份恢复的速度。
- 简单排序:冒泡排序
dieslrae
冒泡排序
public void bubbleSort(int[] array){
for(int i=1;i<array.length;i++){
for(int k=0;k<array.length-i;k++){
if(array[k] > array[k+1]){
- 初二上学期难记单词三
dcj3sjt126com
sciet
concert 音乐会
tonight 今晚
famous 有名的;著名的
song 歌曲
thousand 千
accident 事故;灾难
careless 粗心的,大意的
break 折断;断裂;破碎
heart 心(脏)
happen 偶尔发生,碰巧
tourist 旅游者;观光者
science (自然)科学
marry 结婚
subject 题目;
- I.安装Memcahce 1. 安装依赖包libevent Memcache需要安装libevent,所以安装前可能需要执行 Shell代码 收藏代码
dcj3sjt126com
redis
wget http://download.redis.io/redis-stable.tar.gz
tar xvzf redis-stable.tar.gz
cd redis-stable
make
前面3步应该没有问题,主要的问题是执行make的时候,出现了异常。
异常一:
make[2]: cc: Command not found
异常原因:没有安装g
- 并发容器
shuizhaosi888
并发容器
通过并发容器来改善同步容器的性能,同步容器将所有对容器状态的访问都串行化,来实现线程安全,这种方式严重降低并发性,当多个线程访问时,吞吐量严重降低。
并发容器ConcurrentHashMap
替代同步基于散列的Map,通过Lock控制。
&nb
- Spring Security(12)——Remember-Me功能
234390216
Spring SecurityRemember Me记住我
Remember-Me功能
目录
1.1 概述
1.2 基于简单加密token的方法
1.3 基于持久化token的方法
1.4 Remember-Me相关接口和实现
- 位运算
焦志广
位运算
一、位运算符C语言提供了六种位运算符:
& 按位与
| 按位或
^ 按位异或
~ 取反
<< 左移
>> 右移
1. 按位与运算 按位与运算符"&"是双目运算符。其功能是参与运算的两数各对应的二进位相与。只有对应的两个二进位均为1时,结果位才为1 ,否则为0。参与运算的数以补码方式出现。
例如:9&am
- nodejs 数据库连接 mongodb mysql
liguangsong
mongodbmysqlnode数据库连接
1.mysql 连接
package.json中dependencies加入
"mysql":"~2.7.0"
执行 npm install
在config 下创建文件 database.js
- java动态编译
olive6615
javaHotSpotjvm动态编译
在HotSpot虚拟机中,有两个技术是至关重要的,即动态编译(Dynamic compilation)和Profiling。
HotSpot是如何动态编译Javad的bytecode呢?Java bytecode是以解释方式被load到虚拟机的。HotSpot里有一个运行监视器,即Profile Monitor,专门监视
- Storm0.9.5的集群部署配置优化
roadrunners
优化storm.yaml
nimbus结点配置(storm.yaml)信息:
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional inf
- 101个MySQL 的调节和优化的提示
tomcat_oracle
mysql
1. 拥有足够的物理内存来把整个InnoDB文件加载到内存中——在内存中访问文件时的速度要比在硬盘中访问时快的多。 2. 不惜一切代价避免使用Swap交换分区 – 交换时是从硬盘读取的,它的速度很慢。 3. 使用电池供电的RAM(注:RAM即随机存储器)。 4. 使用高级的RAID(注:Redundant Arrays of Inexpensive Disks,即磁盘阵列
- zoj 3829 Known Notation(贪心)
阿尔萨斯
ZOJ
题目链接:zoj 3829 Known Notation
题目大意:给定一个不完整的后缀表达式,要求有2种不同操作,用尽量少的操作使得表达式完整。
解题思路:贪心,数字的个数要要保证比∗的个数多1,不够的话优先补在开头是最优的。然后遍历一遍字符串,碰到数字+1,碰到∗-1,保证数字的个数大于等1,如果不够减的话,可以和最后面的一个数字交换位置(用栈维护十分方便),因为添加和交换代价都是1