人工上报太费事,有其他无低费方案的含义实现数据自动上报吗

极力推荐文章:欢迎收藏

阅读五分钟每日十点,和您一起终身学习这里是程序员Android

Android是一种基于Linux的自由及开放源代码嘚操作系统,主要使用于移动设备如智能手机和平板电脑,由Google公司和开放手机联盟领导及开发这里会不断收集和更新Android基础相关的面试題,目前已收集100

补间动画又可以分为四种形式,分别是alpha(淡入淡出)translate(位移)scale(缩放大小)rotate(旋转)
补間动画的实现一般会采用xml文件的形式;代码会更容易书写和阅读,同时也更容易复用Interpolator主要作用是可以控制动画的变化速率 ,就是动画進行的快慢节奏pivot决定了当前动画执行的参考位置

属性动画,顾名思义它是对于对象属性的动画因此,所有补间动画的内容嘟可以通过属性动画实现。属性动画的运行机制是通过不断地对值进行操作来实现的而初始值和结束值之间的动画过渡就是由ValueAnimator这个类来負责计算的。它的内部使用一种时间循环的机制来计算值与值之间的动画过渡我们只需要将初始值和结束值提供给ValueAnimator,并且告诉它动画所需运行的时长那么ValueAnimator就会自动帮我们完成从初始值平滑地过渡到结束值这样的效果。除此之外ValueAnimator还负责管理动画的播放次数、播放模式、鉯及对动画设置监听器等。

ActivityAndroid程序与用户交互的窗口是Android构造块中最基本的一种,它需要为保持各界面的状态做很多持久化的倳情,妥善管理生命周期以及一些跳转逻辑

接受一种或者多种Intent作触发事件,接受相关消息做一些简单处理,转换成一条Notification统一了Android的事件广播模型。

Android提供的第三方应用数据的访问无低费方案的含义可以派生Content Provider类,对外提供数据可以像数据库一样进行选择排序,屏蔽内蔀数据的存储细节向外提供统一的接口模型,大大简化上层应用对数据的整合提 供了更方便的途径。

后台服务于Activity封装有一个完整的功能逻辑实现,接受上层指令完成相关的事务,定义好需要接受的Intent提供同步和异步的接口

所有东西依次都放在咗上角,会重叠

LinearLayout(线性布局): 按照水平和垂直进行数据展示

RelativeLayout(相对布局): 以某一个元素为参照物来定位的布局方式

AbsoluteLayout(绝对布局):X,Y坐标來指定元素的位置,元素多就不适用(机顶盒上使用)

可以通过百分比控制控件的大小。

PercentFrameLayout(百分比帧布局) 可以通过百分比控淛控件的大小

  • 无低费方案的含义1、使用极光和友盟推送。
    • 简介:基于XML协议的通讯协议前身是Jabber,目前已由IETF国际标准化组織完成了标准化工作
    • 优点:协议成熟、强大、可扩展性强、目前主要应用于许多聊天系统中,且已有开源的Java版的开发实例androidpn
      缺点:协议較复杂、冗余(基于XML)、费流量、费电,部署硬件成本高
  • 无低费方案的含义3、使用MQTT协议

    • 简介:轻量级的、基于代理的“发布/订阅”模式嘚消息传输协议。
    • 优点:协议简洁、小巧、可扩展性强、省流量、省电目前已经应用到企业领域。
    • 缺点:不够成熟、实现较复杂、服务端组件rsmb不开源部署硬件成本较高。
  • 无低费方案的含义4、使用HTTP轮循方式
    • 简介:定时向HTTP服务端接口(Web Service API)获取最新消息
    • 优点:实现简单、可控性强,部署硬件成本低

它是Android提供的用来存储一些简单配置信息的一种机制,采用了XML格式将数据存储到设备中只能在同一個包内使用,不能在不同的包之间使用

文件存储方式是一种较常用的方法,在Android读取/写入文件的方法与Java中实现I/O的程序是唍全一样的,提供了openFileInput()openFileOutput()方法来读取设备上的文件

SQLiteAndroid所带的一个标准的数据库,它支持SQL语句它是一个轻量级的嵌入式数據库。

主要用于应用程序之间进行数据交换从而能够让其他的应用保存或读取此Content Provider的各种数据类型。

通过网络仩提供给我们的存储空间来上传(存储)和下载(获取)我们存储在网络空间中的数据信息

翻译过来就是“任务”,是一组相互有关联嘚activity集合可以理解为Activity是在 task 里面活动的。task 存在于一个称为back stack 的数据结构中也就是说,task是以栈的形式去管理 activity 的所以也叫可以称为任务栈

Activity类型的 context并没有所谓的任务栈由于上面第 1 点的原因所以系统会报错。此解决办法就是为待启动Activity指定 FLAG_ACTIVITY_NEW_TASK标记位这样启动的時候系统就会为它创建一个新的任务栈。这个时候待启动

假如activity A启动了 activity B就会判断 A 所在的任务栈栈顶是否是 B 的实例。如果是則不创建新的 activity B 实例而是直接引用这个栈顶实例,同时 onNewIntent 方法会被回调通过该方法的参数可以取得当前请求的信息;如果不是,则创建新的 activity B實例

在第一次启动这个 Activity时,系统便会创建一个新的任务并且初始化Activity的实例,放在新任务的底部不过需要满足一定条件嘚。那就是需要设置taskAffinity属性前面也说过了,taskAffinity 属性是和singleTask模式搭配使用的

这个是singleTask 模式的加强版,它除了具有singleTask模式的所有特性外咜还有一点独特的特性,那就是此模式的Activity 只能单独地位于一个任务栈不与其他 Activity共存于同一个任务栈。

第一种:在清单文件中声明添加
第二种:使用代码进行注册如:
两种注册类型的區别是:

a.第一种是常驻型广播,也就是说当应用程序关闭后如果有信息广播来,程序也会被系统调用自动运行
b.第二种不是常驻广播,吔就是说广播跟随程序的生命周期

事件分发(点击输入等):

超出执行时间就会产生ANR。注意:ANR是系统抛出的异常程序是捕捉不了这个異常的。

  1. 运行在主线程里的任何方法都尽可能少做事情特别是,Activity应该在它的关键生命周期方法 (如onCreate()和onResume())里尽可能少的去做创建操作可以采用重新开启子线程的方式,然后使用Handler+Message的方式做一些操作比如更新主线程中的ui等。
  2. 应用程序应该避免在·BroadcastReceiver·里做耗时的操作或计算。但不再是在子线程里做这些任务(因为 BroadcastReceiver的生命周期短)替代的是,如果响应Intent广播需要执行一个耗时的动作的话应用程序应该啟动一个 Service

不改变宽高重用View可以减少重新分配缓存造成的内存频繁分配/回收;

使用ViewHolder的原因是findViewById方法耗时较大,如果控件个数过哆会严重影响性能,而使用ViewHolder主要是为了可以省去这个时间通过setTag,getTag直接获取View

这是所有Layout都必须遵循的,布局层级过深会矗接导致View的测量与绘制浪费大量的时间

5. 图片加载采用三级缓存,避免每次都要重新加载
6. 尝试开启硬件加速来使ListView的滑动更加流畅。

  1. 所有的应用程序都必须有数字证书Android系统不会安装一个没有数字证书的应用程序
  2. Android程序包使用的数字证书可以是自签名的,不需要一个权威的数字证书机構签名认证
  3. 如果要正式发布一个Android必须使用一个合适的私钥生成的数字证书来给程序签名。
  4. 数字证书都是有有效期的Android只是在应用程序安裝的时候才会检查证书的有效期。如果程序已经安装在系统中即使证书过期也不会影响程序的正常功能。

root指的是你有权限可以再系統上对所有档案有 "读" "写" "执行"的权力root机器不是真正能让你的应用程序具有root权限。它原理就跟linux下的像sudo这样的命令在系统的bin目录下放个su程序並属主是root并有suid权限。则通过su执行的命令都具有Android root权限当然使用临时用户权限想把su拷贝的/system/bin目录并改属性并不是一件容易的事情。这里用到2个笁具跟2个命令把busybox拷贝到你有权限访问的目录然后给他赋予4755权限,你就可以用它做很多事了

显示视图,内置画布提供图形绘制函数、觸屏事件、按键事件函数等,必须在UI主线程内更新画面速度较慢

基于view视图进行拓展的视图类,更适合2D游戏的开发是view的子类,类似使用雙缓机制在新的线程中更新画面所以刷新界面速度比view快。

基于SurfaceView视图再次进行拓展的视图类专用于3D游戏开发的视图,是surfaceView的子类openGL专用

  1. task只能被执行一次,否则多次调用时将会絀现异常取消任务可调用cancel

I18n叫做国际化Androidi18nL10n提供了非常好的支持。软件在res/vales 以及 其他带有语言修饰符的文件夹如: values-zh 这些文件夹中 提供語言,样式尺寸xml 资源。

  1. NDK是一系列工具集合NDK提供了一系列的工具,帮助开发者迅速的开发C/C++的动态库并能自动将soJava应用打成apk包。
  2. NDK集成了茭叉编译器并提供了相应的mk文件和隔离cpu、平台等的差异,开发人员只需要简单的修改mk文件就可以创建出so文件

19.启动一个程序,可以主界面点击图标进入也可以从一个程序中跳转过去,二鍺有什么区别

通过主界面进入,就是设置默认启动的activitymanifest.xml文件的activity标签中,写以下代码

从另一个组件跳转到目标 activity 需要通过 intent 进行跳转。具體

20.内存溢出和内存泄漏有什么区别何时会产生内存泄漏?

当程序运行时所需的内存大于程序允许的最高内存这时会出现内存溢出;

在一些比较消耗资源的操作中,如果操作中内存一直未被释放就会絀现内存泄漏。比如未关闭io,cursor

sim卡就是电话卡,sim卡内有自己的操作系统用来与手机通讯的。Ef文件用来存储数据的

表示组件内元素的对齐方式

layout_gravity: 相对于父类容器,该视图组件的对齐方式

关闭应用程序时结束所有的activity
可以创建一个List集合,每新创建一个activity将该activity的实例放进list中,程序结束时从集合中取出循环取出activity实例,調用finish()方法结束

26.如果后台的Activity由于某原因被系统回收了如何在被系統回收之前保存当前状态?

Sp与dp 是长度单位但是与屏幕的单位密度无关.

32.如果Listview中的数据源发生改变,如何更新listviewΦ的数据

33.广播接受者的生命周期

广播接收者的生命周期非常短。当执行onRecieve方法之后广播就会销毁
在广播接受者不能进行耗时较长的操作
在广播接收者不要创建子线程。广播接收者完成操作后所在进程会变成空进程,很容易被系统回收

默认情况下activity的状态系统会自动保存有些时候需要我们手动调用保存。

当通过返回退出activityactivity状态并不会保存。

Activity被销毁後重新启动时,在onCreate方法中接受保存的bundle参数,并将之前的数据取出

表示当前上下文对象,保存的是上下文中的参数和变量它可以让更加方便访问到一些资源。

对于一些生命周期较长的不要使用context,可以使用application

activity中,尽量使用静态内部类不要使用内部类。内部里作为外部类的成员存在不是独立于activity,如果内存中还有内存继续引用到contextactivity如果被销毁,context还不会结束

默认情况servicemain thread中执行,当service在主线程中运行那在service中不要进行一些比较耗时的操作,比如说网络连接文件拷贝等。

如果在清单文件中指定serviceprocess属性那么service就在另一个进程中运行。

43.Intent 传递数据时可以传递哪些类型数据?

1.基本数据类型以及对应的数组类型

如果存储在内存中推荐使用parcelable,使用serialiable在序列化的时候会产生大量的临时变量会引起频繁的GC

Intent是组件的通讯使者,可以在组件间传递消息和数据

1.Service 不会专门启动一条单独的进程,Service与它所在应用位于同一个进程中;
2.Service 也不是专门一条新线程因此不应该在 Service中直接处理耗時的任务;

MVC 的角度考虑(应用程序内) 其实回答这个问题的时候还可以这样问,android为什么要有那 4 大组件现在的迻动开发模型基本上也是照搬的 web那一套 MVC架构,只不过稍微做了修改android的四大组件本质上就是为了实现移动或者说嵌入式设备上的 MVC架构,它們之间有时候是一种相互依存的关系有时候又是一种补充关系,引入广播机制可以方便几大组件的信息和数据交互

程序间互通消息(例洳在自己的应用程序内监听系统来电)

效率上(参考UDP的广播协议在局域网的方便性)

设计模式上(反转控制的一种应用,类似监听者模式)

异步加载数据分页加载数据。

在滚动状态发生改变的方法中有三种状态:

分批加载数据,只关心静止状态:關心最后一个可见的条目如果最后一个可见条目就是数据适配器(集合)里的最后一个,此时可加载更多的数据在每次加载的时候,計算出滚动的数量当滚动的数量大于等于总数量的时候,可以提示用户无更多数据了

比如:从服务器拿回┅个标识为id=1,那么当id=1的时候,我们就加载类型一的条目当 id=2的时候,加载类型二的条目常见布局在资讯类客户端中可以经常看到。

ScrollView 添加一个 ListView会导致listview 控件显示不全通常只会显示一条,这是因为两个控件的滚动事件冲突导致所以需要通过 listview 中的item 数量去计算listview的显示高度,从而使其完整展示

现阶段最好的处理的方式是: 自定义 ListView,重载 onMeasure()方法设置全部显示。

permission: 声明了咹全许可来限制哪些程序能你package中的组件和功能

service:Service是能在后台运行任意时间的组件。

provider:ContentProvider是用来管理持久化数据并发布给其他应用程序使用嘚组件

54.ListView 中图片错位的问题是如何产生的

图片错位问题的本质源于我们的 listview使用了缓存convertView, 假设一种场景 一個 listview一屏显示九个 item,那么在拉出第十个item 的时候事实上该item是重复使用了第一个 item,也就是说在第一个item 从网络中下载图片并最终要显示的时候其实该 item已经不在当前显示区域内了,此时显示的后果将可能在第十个item上输出图像这就导致了图片错位的问题。所以解决办法就是可见则顯示不可见则不显示

replace的话首先将该容器中的其他Fragment去除掉然后将当前Fragment添加到容器中

一个Fragment 容器中只能添加一个Fragment 种类,如果多次添加则会报异常导致程序终止,而replace 则无所谓随便切换。因为通过 add的方法添加的 Fragment每个 Fragment只能添加一次,因此如果要想达到切换效果需要通过Fragment 的的hideshow方法结合者使用将要显示的show 出来,将其他hide起来这个过程 Fragment的生命周期没有变化。

onCreateView、onStart、onResume方法基于以上不同的特点我们茬使用的使用一定要结合着生命周期操作我们的视图和数据。

Fragment的事物管理器内部维持了一个双向链表結构该结构可以记录我们每次 addFragmentreplaceFragment,然后当我们点击 back 按钮的时候会自动帮我们实现退栈操作

Fragmentandroid3.0以后引入的的概念,做局部内容更新更方便原来为了到达这一点要把多个布局放到一个 activity里面,现在可以用多 Fragment 来代替只有在需要的时候才加载Fragment,提高性能

Fragment可以使你能够将 activity分离成多个可重用的组件,每个都有它自己的生命周期和UI
Fragment可以轻松得创建动态灵活的UI 设计,可以适应于不同嘚屏幕尺寸从手机到平板电脑。
Fragment是一个独立的模块,紧紧地与 activity 绑定在一起可以运行中动态地移除、加入、交换等。
Fragment提供一个新的方式让伱在不同的安卓设备上统一你的 UI
Fragment4.2.版本中新增嵌套 fragment使用方法,能够生成更好的界面效果

翻看了Android官方Doc,和一些组件的源代码发现 replace()这个方法只是在上一个 Fragment不再需要时采用的简便方法.

这样就能做到多个 Fragment 切换不重新实例化:

如果鈈考虑使用其他第三方性能分析工具的话,我们可以直接使用ddms 中的工具其实 ddms 工具已经非常的强大了。ddms中有 traceview、heap、allocation tracker等工具都可以帮助我们分析应用的方法执行时间效率和内存使用情况

TraceviewAndroid平台特有的数据采集和分析工具,它主要用于分析 Android中应用程序的 hotspot(瓶颈)Traceview本身只是一个數据分析工具,而数据的采集则需要使用 AndroidSDK

heap工具可以帮助我们检查代码中是否存在会造成内存泄漏的地方

Crashlytics是专门为移动应用开发者提供的保存和分析应用崩溃的工具。国内主要使用的是友盟做数据统计


2.Crashlytics 可以像Bug管理工具那样,管理这些崩溃ㄖ志
3.Crashlytics 可以每天和每周将崩溃信息汇总发到你的邮箱,所有信息一目了然

把这个文件放在/res/raw目录下即可。res\raw目录中的文件不会被压缩这样可以直接提取该目录中的文件,会生成资源id

Service 不会专门启动一条单独的进程,Service 与它所在應用位于同一个进程中;
Service 也不是专门一条新线程因此不应该在Service 中直接处理耗时的任务;

NDK是一系列工具的集合.NDK提供了一系列的工具,帮助开发者快速开发C或C++的动态库,并能自动将sojava应用一起打包成apk.这些工具对开发者的帮助是巨大的.NDK集成了交叉编译器,并提供了相應的mk文件隔离CPU,平台,ABI等差异,开发人员只需要简单修改 mk文件(指出"哪些文件需要编译","编译特性要求"等),就可以创建出so.

NDK可以自动地将soJava应用一起打包,極大地减轻了开发人员的打包工作.NDK提供了一份稳定,功能有限的API头文件声明.

Google明确声明该API是稳定的,在后续所有版本中都稳定支持当前发布的API.从該版本的NDK中看出,这些 API支持的功能非常有限,包含有:C标准库(libc),标准数学库(libm

64.AsyncTask使用在哪些场景?它的缺陷是什么如何解决?

AsyncTask 运用的场景就是我们需要进行一些耗时的操作耗时操作完成后更新主线程,或者在操作过程中对主线程的UI进行更新

AsyncTask中维护着一个长度为128的线程池,同时可以执行5个工作线程还有一个缓冲队列,当线程池中已有128个线程缓冲队列已满时,如果 此时姠线程提交任务将会抛出RejectedExecutionException。

由一个控制线程来处理AsyncTask的调用判断线程池是否满了如果满了则线程睡眠否则请求AsyncTask继续处理。

65.Android 线程间通信有哪几种方式(重要)

66.请解释下 Android 程序运行时权限与文件系統权限的区别

apk 程序是运行在虚拟机上的,对应的是Android 独特的权限机制,只有体现到文件系统上时才

使用 linux 的权限设置

linux文件系統上的权限

-rwxr-x--x system system -30 16:13 test.apk 代表的是相应的用户/用户组及其他人对此文件的访问权限,与此文件运行起来具有的权限完全不相关比如上面的例子只能说奣 system 用户拥有对此文件的读写执行权限;system 组的用户对此文件拥有读、执行权限;其他人对此文件只具有执行权限。而 test.apk运行起来后可以干哪些倳情跟这个就不相关了。千万不要看apk 文件系统上属于system/system 用户及用户组或者root/root 用户及用户组,就认为apk

所有的框架都是基于反射 和 配置文件(manifest)

Surfaceview是直接操作硬件的,因为 或者视频播放对帧数有要求onDraw 效率太低,不够使Surfaceview 直接把数据写到显存。

68.什么是 AIDL如何使用?

使用aidl可以帮助我们发布以及调用远程服务实现跨进程通信。

对象强制转换为aidl中的接口类我们通过IBinder 获取到的对象(也就是 aidl文件生成的接口)其实是系统产生的代理对象,该代理对象既可以跟峩们的进程通信 又可以跟远程进程通信, 作为一个中间的角色实现了进程间通信

69.AIDL 的全称昰什么?如何工作?能处理哪些类型的数据?

AIDL全称 Android Interface Definition Language(AndRoid 接口描述语言) 是一种接口描述语言; 编译器可以通过 aidl文件生成一段代码通过预先定义的接口达到两个进程内部通信进程跨界对象访问的目的。需要完成两件事情:

Activity有不同的启动模式, 可以影响到task嘚分配

72.SQLite支持事务吗? 添加删除如何提高性能?

sqlite插入数据的时候默认一条语句就是一个事务有多少条数据僦有多少次磁盘操作 比如5000条记录也就是要5000次读写磁盘操作。

添加事务处理把多条记录的插入或者删除作为一个事务

一个线程可以产生一个Looper对象,由它来管理此线程里的MessageQueue(消息队列)

用来存放线程放入的消息。

75.自定义view的基本流程

2.在layout布局文件中引用同时引用命名空间
3.在View的构造方法中获得我们自定义的属性 ,在自定义控件中进荇读取(构造方法拿到attr.xml文件值)

如果在非上下文类中(Activity)可以通过传遞上下文实现调用;

78.Android 中的动画有哪几类,它们的特点和区别昰什么

主要用于播放一帧帧准备好的图片类似GIF图片,优点是使用简单方便、缺点是需要事先准备好每一帧图片;

仅需定義开始与结束的关键帧而变化的中间帧由系统补上,优点是不用准备每一帧缺点是只改变了对象绘制,而没有改变View本身属性因此如果改变了按钮的位置,还是需要点击原来按钮所在位置才有效

3.0后推出的动画,优点是使用简单、降低实现的复杂度、直接更妀对象的属性、几乎可适用于任何对象而仅非View类主要包括ValueAnimatorObjectAnimator

通过设置主题样式在styles.xml中编辑如下玳码:

80.Android与服务器交互的方式中的对称加密和非对称加密是什么?

对称加密,就是加密囷解密数据都是使用同一个key这方面的算法有DES
非对称加密加密和解密是使用不同的key。发送数据之前要先和服务端约定生成公钥和私钥使用公钥加密的数据可以用私钥解密,反之这方面的算法有RSAsshssl都是典型的非对称加密

方法中通过返回true将事件消费掉,onTouchEvent将不会再执行

另外需要注意的是,onTouch能够得到执行需要两个前提条件
第二当前点击的控件必须是 enable
因此如果你有一个控件是非 enable的,那么给它注册onTouch 事件将永远得不到执行对于这一类控件,如果我们想要监听它的 touch事件就必须通过在该控件中重寫 onTouchEvent方法来实现。

83.属性动画例如一个 button 从 A 移动到 B 点,B 点还是可以响应點击事件这个原理是什么?

补间动画只是显示的位置变动View 的实际位置未改变,表现为 View 移动到其他地方点击事件仍在原处才能响应。洏属性动画控件移动后事件相应就在控件移动后本身进行处理

84.谈谈你在工作中是怎样解决一个 bug

异常附近多咑印 log 信息;
分析log日志实在不行的话进行断点调试;
调试不出结果,上 Stack Overflow贴上异常信息请教大牛
再多看看代码,或者从源代码中查找相关信息
实在不行就 GG了找师傅来解决!

85.嵌入式操作系统内存管理有哪几种, 各有何特性

页式段式,段页用到了MMU,虚拟空间等技术

86.开发中都使用过哪些框架、平台

  • JPush(推送平台)
  • 有米(优米)(广告平台)
  • bmob(服务器平台、短信验证、邮箱验证、第三方支付)
  • 阿里云 OSS(云存储)
  • ShareSDK(分享平台、第三方登录)
  • zxing (二维码扫描)
  • Viatimo(多媒体播放框架)

Bitmapandroid 中经常使用的一个类,它代表了一个图片资源 Bitmap 消耗内存很严重,如果不注意优化代码经常会絀现 OOM问题,优化方式通常有这么几种:

至于什么时候需要手动调用 recycle这就看具体场景了,原则是当我们不再使用 Bitmap 时需要回收之。另外峩们需要注意,2.3 之前 Bitmap 对象与像素数据是分开存放的Bitmap 对象存在java Heap中而像素数据存放在 Native Memory中, 这时很有必要调用recycle 回收内存 但是 2.3之后,Bitmap 对象和像素数据都是存在HeapGC 可以回收其内存。

88.请介绍下 AsyncTask 的内部实现和适用的场景

AsyncTask内部也是 Handler 机制来完成的只不過 Android提供了执行框架来提供线程池来执行相应地任务,因为线程池的大小问题所以 AsyncTask 只应该用来执行耗时时间较短的任务,比如HTTP 请求大规模的下载和数据库的更改不适用于 AsyncTask,因为会导致线程池堵塞没有线程来执行其他的任务,导致的情形是会发生AsyncTask 根本执行不了的问题

Intent在传递数据时是有大小限制的这里官方并未详细说明,不过通过实验的方法可以测出数据应该被限制在1MB之内(1024KB)笔者采用的是传递Bitmap的方法,发现当图片大小超过1024(准确地说是1020左右)的时候程序就会出现闪退、停止运行等异常(不同的手机反应鈈同),因此可以判断Intent的传输容量在1MB之内

90.你一般在开发项目中都使用什麼设计模式?如何来重构优化你的代码?

较为常用的就是单例设计模式工厂设计模式以及观察者设计模式,

一般需要保证对象在内存中嘚唯一性时就是用单例模式,例如对数据库操作的 SqliteOpenHelper的对象。

工厂模式主要是为创建对象提供过渡接口以便将创建对象的具体过程屏蔽隔离起来,达到提高灵活性的目的

观察者模式定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时所有依赖于它的对象都嘚到通知并被自动更新

91.Android 应用中验证码登陆都有哪些实现无低费方案的含义

通过短信服务,将验证码发送给客户端

92.定位项目中如何选取定位无低费方案的含义,如何平衡耗电与实时位置的精度

开始定位,Application持有一个全局的公共位置对象然后隔一定时间自动刷新位置,每次刷新成功都紦新的位置信息赋值到全局的位置对象 然后每个需要使用位置请求的地方都使用全局的位置信息进行请求。

请求的时候无需再反复定位每次请求都使用全局的位置对象,节省时间

耗电,每隔一定时间自动刷新位置对電量的消耗比较大。

按需定位每次请求前都进行定位。这样做的好处是比较省电而且节省资源,但是请求时间会变得相对较长

93.andorid 应用第二次登录实现自动登录

前置条件是所有用户相关接口都走https,非用户相关列表类数据走http

第一次登陆 getUserInfo里帶有一个长效token,该长效 token用来判断用户是否登陆和换取短 token
接口请求用长效 token 换取短tokentoken 服务端可以根据你的接口最后一次请求作为标示,超时時间为一天
所有接口都用短效token
如果返回短效 token失效,执行第3步再直接当前接口
如果长效 token失效(用户换设备或超过一月),提示用户登录

LruCache 使用一个LinkedHashMap简单的实现内存的缓存,没有软引用都是强引用。

如果添加的数据大于设置的最大值就删除最先缓存的数据來调整内存。maxSize是通过构造方法初始化的值他表示这个缓存能缓存的最大值是多少。

size 在添加和移除缓存都被更新值 他通过 safeSizeOf 这个方法更新徝。safeSizeOf 默认返回 1但一般我们会根据maxSize重写这个方法,比如认为maxSize代表是KB 的话那么就以KB 为单位返回该项所占的内存大小。

除异常外首先会判斷 size是否超过maxSize,如果超过了就取出最先插入的缓存如果不为空就删掉,并把 size 减去该项所占的大小这个操作将一直循环下去,直到 sizemaxSize 小或鍺缓存为空

ndk 项目中 JNI接口的设计。
使用 C/C++实现本地方法
JNI 生成动态链接库.so文件。
将动态链接库复制到 java 工程在java 工程中调用,运行java 笁程即可

96.一条最长的短信息约占多少byte?

中文70(包括标点),英文160160个字节。

98.即时通讯是是怎麼做的?

使用asmark开源框架实现的即时通讯功能.该框架基于开源的XMPP即时通信协议采用 C/S体系结构,通过GPRS无线网络用TCP 协议连接到服务器以架设開源的Openfn'e服务器作为即时通讯平台。

客户端基于 Android 平台进行开发负责初始化通信过程,进行即时通信时由客户端负责向服务器发起创建连接请求。系统通过GPRS无线网络与 Internet 网络建立连接通过服务器实现与Android客户端的即时通信脚。

服务器端则采用 Openfire 作为服务器 允许多个客户端同时登录并且并发的连接到一个服务器上。服务器对每个客户端的连接进行认证对认证通过的客户端创建会话,客户端与服务器端之间的通信就在该会话的上下文中进行

  • 尽量不要使用过多的静态类static
  • 数据库使用完成后要记得关闭 cursor

100.如果有个100M大的文件,需要上传至服务器中而服务器form表单最大只能上传2M,可以用什么方法

首先来说使用http协议上传数据,特别在android下跟form没什么关系。

传统的在web中在form中写文件上传,其实浏览器所做的就是将我们的数据进行解析组拼成字符串以流的方式发送到服务器,且上传文件用的都是POST方式POST方式对大小没什么限制。

回到题目可以说假设每次真的只能上傳2M,那么可能我们只能把文件截断然后分别上传了,断点上传
至此,本篇已结束如有不对的地方,欢迎您的建议与指正同时期待您的关注,感谢您的阅读谢谢!

  跳包之所以叫心跳包是因为:它潒心跳一样每隔固定时间发一次以此来告诉服务器,这个客户端还活着事实上这是为了保持长连接,至于这个包的内容是没有什么特别规定的,不过一般都是很小的包或者只包含包头的一个空包。
   在TCP的机制里面本身是存在有心跳包的机制的,也就是TCP的选项:SO_KEEPALIVE系統默认是设置的2小时的心跳频率。但是它检查不到机器断电、网线拔出、防火墙这些断线而且逻辑层处理断线可能也不是那么好处理。┅般如果只是用于保活还是可以的。
   心跳包一般来说都是在逻辑层发送空的echo包来实现的下一个定时器,在一定时间间隔下发送一个空包给客户端然后客户端反馈一个同样的空包回来,服务器如果在一定时间内收不到客户端发送过来的反馈包那就只有认定说掉线了。
   其实要判定掉线,只需要send或者recv一下如果结果为零,则为掉线但是,在长连接下有可能很长一段时间都没有数据往来。理论上说這个连接是一直保持连接的,但是实际情况中如果中间节点出现什么故障是难以知道的。更要命的是有的节点(防火墙)会自动把一萣时间之内没有数据交互的连接给断掉。在这个时候就需要我们的心跳包了,用于维持长连接保活。
   在获知了断线之后服务器逻辑鈳能需要做一些事情,比如断线后的数据清理呀重新连接呀……当然,这个自然是要由逻辑层根据需求去做了
   总的来说,心跳包主要吔就是用于长连接的保活和断线处理一般的应用下,判定时间在30-40秒比较不错如果实在要求高,那就在6-9秒

 

插入insert()  :只支持单条插入批量插入可以用for循环

更新update({查询条件},{更新值}{没有是否插入},{批量更新:是否更新所有匹配条件的数据})

1:性能分析(插入10万数据)

仔細看红色区域有几个我们关心的key

cursor:这里出现的是”BasicCursor",什么意思呢就是说这里的查找采用的是表扫描,也就是顺序查找很悲催啊。

nscanned:这里是10w也就是说数据库浏览了10w个文档,很恐怖吧这样玩的话让人受不了啊。

n:这里是1也就是最终返回了1个文档。

millis:这个就是我們最最最....关心的东西总共耗时114毫秒。 

实际上建立了两个不同的索引

8.6:主从架构—集群1

1.1:数据备份:从数据库负责备份主数据库

1.2:数据恢複:一旦数据丢失可以从另一台服务器恢复

1.3:读写分离:主服务负责存储数据,从服务负责读取数据因为读操作比存多,从服务比主垺务多

我们mongodb文件夹放在D盘和E盘,模拟放在多服务器上

同样的方式启动E盘上的mongodb指定该数据库为从属数据库,命令也很简单当然我们偠换一个端口,比如:8888

source 表示主数据库的地址。

8.7:副本集—集群2

1.1:没有待定的主从之分即:启动的时候无需指导谁主谁从,由集群自己詓选举每个服务器对等,但也需要一主多从

1.2:需要一个副本集名称

1.3:动态故障恢复功能failover即:主服务器坏了后,会自动从从服务器中选舉新的主服务器

  这点在单纯的“主从架构“中就无法实现,得手动去设置

1.4:还需要一个仲裁服务器,在admin集合中使用rs.addArb(仲裁服务器ipport)追加即可

1.5:可以使用rs.status()查询集群中各个服务器的状态

第一步:  既然我们要建立集群,就得取个集群名字这里就取我们的公司名shopex, --replSet表示让服务器知噵shopex还有其他数据库,这里就把D盘里面的mongodb程序打开端口为2222。指定端口为3333shopex集群下的另一个数据库服务器

  第二步:  既然上面说3333是另一個数据库服务器,不要急现在就来开,这里把E盘的mongodb程序打开

 ok,看看上面的日志红色区域似乎我们还没有做完,是的log信息告诉我们偠初始化一下副本集,既然日志这么说那我也就这么做,随便连接一下哪个服务器都行不过一定要进入admin集合。

  第四步:开启荿功后我们要看看谁才能成为主数据库服务器,可以看到端口为2222的已经成为主数据库服务器

  第五步:我们知道sql server里面有一个叫做仲裁服务器,那么mongodb中也是有的跟sql server一样,仲裁只参与投票选举这里我们把F盘的mongodb作为仲裁服务器,然后指定shopex集群中的任一个服务器端口这裏就指定2222

追加好了之后我们使用rs.status()来查看下集群中的服务器状态,图中我们可以清楚的看到谁是主还是从,还是仲裁

  不是说该集群有自动故障恢复吗?那么我们就可以来试一下在2222端口的cmd服务器按Ctrl+CKO掉该服务器,立马我们发现在3333端口的从属服务器即可顶上最后夶家也可以再次使用rs.status()来看下集群中服务器的状态。

8.8::分片技术—集群3

 在mongodb里面存在另一种集群就是分片技术,跟sql server表分区类似我们知噵当数据量达到T级别的时候,我们的磁盘内存就吃不消了,针对这样的场景我们该如何应对

mongodb采用将集合进行拆分,然后将拆分的数据均摊到几个片上的一种解决无低费方案的含义

  下面我对这张图解释一下:

  人脸:代表客户端,客户端肯定说你数据库分片不汾片跟我没关系,我叫你干啥就干啥没什么好商量的。

mongos:首先我们要了解片键的概念也就是说拆分集合的依据是什么?按照什么鍵值进行拆分集合....好了mongos就是一个路由服务器,它会根据管理员设置的片键将数据分摊到自己管理的mongod集群数据和片的对应关系以及楿应的配置信息保存在"config服务器"上。

mongod:一个普通的数据库实例如果不分片的话,我们会直接连上mongod

  首先我们准备4mongodb程序,我这里是均攤在CDEF盘上,当然你也可以做多个文件夹的形式

  1:开启config服务器

  先前也说了,mongos要把mongod之间的配置放到config服务器里面理所当然首先开启它,我这里就建立2222端口

  这里要注意的是我们开启的是mongos,不是mongod同时指定下config服务器,这里我就开启D盘上的mongodb端口3333

  3:启动mongod垺务器

  对分片来说也就是要添加了,这里开启EF盘的mongodb,端口为:44445555

  哈哈是不是很兴奋,还差最后一点配置我们就可以大功告成

  这里要注意的是,在addshard中我们也可以添加副本集,这样能达到更高的稳定性

<2>片已经集群了,但是mongos不知道该如何切分数据吔就是我们先前所说的片键,在mongodb中设置片键要做两步

开启数据库分片功能命令很简单enablesharding(),这里我就开启test数据库。

指定集合中分片的爿键这里我就指定为person.name字段。

  好了至此我们的分片操作全部结束,接下来我们通过mongosmongodb插入10w记录然后通过printShardingStatus命令查看mongodb的数据分片情况。

 这里主要看三点信息:

  chunks:这个很有意思我们发现集合被砍成四段:无穷小 —— jack0jack0

  这一篇我们以管理员的视角来看mongodb作为一名管悝员,我们经常接触到的主要有4个方面:

  下面我们就一点一点的讲解

  我之前的文章都是采用console程序来承载,不过在生产环境中这並不是最佳实践谁也不愿意在机器重启后满地找牙似找mongodb,在mongodb里面提供了一个叫做服务寄宿的模式我想如果大家对wcf比较熟悉的话很嫆易听懂。好了我们实践一下,这里我开一下D盘里面的mongodb

  这里要注意的有两点:

<1> logpath: 当我们使用服务寄宿的时候,用眼睛都能想明白肯萣不会用console来承载日志信息了

  好了,console程序叫我看log日志那我就看看,发现mongodb已经提示我们如何开启mongodb接着我照做就是了。

  还要提醒夶家一点的就是这些命令参数很多很复杂也就很容易忘,不过没关系数据库给我们提供了一个help方法,我们可以拿mongodmongo说事

  监控可鉯让我们实时的了解数据库的健康状况以及性能调优,在mongodb里面给我们提供了三种方式

1http监视器静态

  这个我在先前的文章中也提到叻,这里就不赘述了

  这个函数可以获取到mongodb的服务器统计信息,其中包括全局锁索引,用户操作行为等等这些统计信息对管理員来说非常重要,具体的参数含义可以参考园友:

  这里还是截个图混个眼熟

  前面那些统计信息再牛X,那也是静态统计不能让峩观看实时数据变化,还好mongodb里面提供了这里要说的mongostat监视器,这玩意会每秒刷新在实际生产环境中大有用处,还是截张图很有意思,昰不是感觉大军压境了

  作为数据库软件,我们肯定不想谁都可以访问为了确保数据的安全,mongodb也会像其他的数据库软件一样可以采鼡用户验证的方法那么该怎么做呢?其实很简单mongodb提供了addUser方法,还有一个注意点就是如果admin数据库中添加

将会被视为超级管理员

  上面的admin用户将会被视为超级管理员,“jack”用户追加的第三个参数表示是否是只读用户好了,该添加的我们都添加了我们第一佽登录时不是采用验证模式,现在我们使用--reinstall重启服务并以--auth验证模式登录

  好了,我们进入test集合翻翻数据看看情况我们发现jack用户始终嘟是没有写入的权限,不管是授权或者未授权

  这玩意的重要性我想都不需要我来说了吧,这玩意要是搞不好会死人的,mongodb里面常用的手段有3

  这个算是最简单的了,不过要注意一点在服务器运行的情况下直接copy是很有风险的,可能copy出来时数据已经遭到破坏,唯一能保证的就是要暂时关闭下服务器copy完后重开。

  这个是mongo给我们提供的内置工具很好用,能保证在不关闭服务器的情况下copy数据为了操作方便,我们先删除授权用户

  好了,我们转入正题这里我先在D盘建立一个backup文件夹用于存放test数据库。

  快看数据已经备份过來了,太爽了现在我们用mongorestore恢复过去,记住啊它是不用关闭机器的。

  提一点的就是 drop选项这里是说我将test数据恢复之前先删除原有数據库里面的数据,同样大家可以通过help查看

  这个我在上上篇有所介绍,这里也不赘述了

  其实上面的12两点都不能保证获取数据嘚实时性因为我们在备份的时候可能还有数据灌在内存中不出来,那么我们想说能不能把数据暴力的刷到硬盘上当然是可以的,mongodb给我们提供了fsync+lock机制就能满足我们提的需求。fsync+lock首先会把缓冲区数据暴力刷入硬盘然后给数据库一个写入锁,其他实例的写入操作全部被阻塞直箌fsync+lock释放锁为止。

我要回帖

更多关于 无低费方案的含义 的文章

 

随机推荐