目录
3. 序列化Serializable和Parcelable的理解和区别
1. 主流网络请求框架库对比
2. SparseArray与HashMap的区别?
- SparseArray适用于key为int的场合,HashMap则使用于各种场合
- SparseArray的内存占用较HashMap少
- SparseArray性能和HashMap比并没有优势
- 当使用HashMap(K, V),如果K为整数类型时,使用SparseArray的效率更高。
-
HashMap 与 SparseArray比较:
- 当数据量在1000以上,推荐使用HashMap。
- 当数据量 在500-1000,HashMap 和SparseArray性能差不多。
- 当数据量 少于500时,使用SparseArray 要优于HashMap。
3. 序列化Serializable和Parcelable的理解和区别
转载:https://www.jianshu.com/p/a60b609ec7e7
为什么要了解序列化?—— 进行Android开发的时候,无法将对象的引用传给Activities或者Fragments,我们需要将这些对象放到一个Intent或者Bundle里面,然后再传递。
序列化,表示将一个对象转换成可存储或可传输的状态。序列化后的对象可以在网络上进行传输,也可以存储到本地。
Serializable(Java自带):
Serializable是序列化的意思,表示将一个对象转换成可存储或可传输的状态。序列化后的对象可以在网络上进行传输,也可以存储到本地。
Parcelable(android 专用):
除了Serializable之外,使用Parcelable也可以实现相同的效果,
不过不同于将对象进行序列化,Parcelable方式的实现原理是将一个完整的对象进行分解,
而分解后的每一部分都是Intent所支持的数据类型,这样也就实现传递对象的功能了。
实现Parcelable的作用
1)永久性保存对象,保存对象的字节序列到本地文件中;
2)通过序列化对象在网络中传递对象;
3)通过序列化在进程间传递对象。
选择序列化方法的原则
1)在使用内存的时候,Parcelable比Serializable性能高,所以推荐使用Parcelable。
2)Serializable在序列化的时候会产生大量的临时变量,从而引起频繁的GC。
3)Parcelable不能使用在要将数据存储在磁盘上的情况,因为Parcelable不能很好的保证数据的持续性在外界有变化的情况下。尽管Serializable效率低点,但此时还是建议使用Serializable 。
4. Synchronized和lock的区别
转载出处:https://blog.csdn.net/hefenglian/article/details/82383569
区别如下:
-
来源:
lock是一个接口,而synchronized是java的一个关键字,synchronized是内置的语言实现; -
·异常是否释放锁:
synchronized在发生异常时候会自动释放占有的锁,因此不会出现死锁;而lock发生异常时候,不会主动释放占有的锁,必须手动unlock来释放锁,可能引起死锁的发生。(所以最好将同步代码块用try catch包起来,finally中写入unlock,避免死锁的发生。) -
·是否响应中断
lock等待锁过程中可以用interrupt来中断等待,而synchronized只能等待锁的释放,不能响应中断; -
·是否知道获取锁
Lock可以通过trylock来知道有没有获取锁,而synchronized不能; -
Lock可以提高多个线程进行读操作的效率。(可以通过readwritelock实现读写分离)
-
·性能对比
-
如果竞争资源不激烈,两者的性能是差不多的,而当竞争资源非常激烈时(即有大量线程同时竞争),此时Lock的性能要远远优于synchronized。所以说,在具体使用时要根据适当情况选择。
-
synchronized使用Object对象本身的wait 、notify、notifyAll调度机制,而Lock可以使用Condition进行线程之间的调度,
-
1、synchronized和lock的用法区别
synchronized:在需要同步的对象中加入此控制,synchronized可以加在方法上,也可以加在特定代码块中,括号中表示需要锁的对象。
lock:一般使用ReentrantLock类做为锁。在加锁和解锁处需要通过lock()和unlock()显示指出。所以一般会在finally块中写unlock()以防死锁。