---恢复内容开始---
2017混混沌沌就过去了,感觉2017上半年工作量很辛苦,下半年我感觉我在混日子啊,学习技术进步不大,在考勤方面也是烦人的,天天闲着不想去上班。感觉换了一个项目没激情没进步的烦躁原因。
在6月份的时候和粉项目交接给北京,后续想跳槽没跳成,6月份有点难找工作,所以还是留在现在的公司继续学习,现在就在做云流量开发,用的技术还是老技术老系统。。这一年的下半年过得不是很充实呐,一年就这么混混沌沌的过去了,总的来说感觉没做过有意义的事,怎么办呐,我要努力啊,自己赚点钱养好自己呢其他事先不说,有钱才安全,我的计划是想2018年想换公司,想找一份比现在高点的工资,然后报个培训班个人兴趣的培训班,学钢琴或者跳舞班都行,不能没有方向了,接下来,准备过一个年,想找好方向努力一把。
说起6月份有出去找过工作碰到的面试,现在想起就来瞎整一下:
1. 如何实现单利模式?(笔试可能会有)
public class Singleton { private Singleton(){ } private class SingletonHoledr(){ private static Singleton instance = new Singleton(); } private static Singleton getInstance(){ return SingletonHoledr.instance; } }
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
2. :
List
-
- :元素有序,可重复。
- ArrayList:数组。特点:有索引(脚标),所以查找快,增删后每个元素的索引都发生改变,所以增删慢,而且数组越长增删越慢
- LinkedList:链表。特点:无索引,每个元素都包含下一元素地址,查找需要逐一进行,所以查找慢,但是增删快只需要改变元素后面的地址。
- Vector:线程同步数组 基本抛弃使用。
- :元素有序,可重复。
Set
- :元素无序,不重复,无索引。
- HashSet:哈希表。特点:线程非同步,保证元素唯一性原理:判断hashCode是个屁相同,洗过相同在判断equals方法是否为true。
- TreeSet:二叉树。特点:可对用两种方法对集合中元素排序,1.实现comparable接口,覆盖compareTo方法。2.集合建立时规定,并自定义比较类。
Map:双列集合,用于存放键值对。键值是唯一的,不可重复。
array:数组,可以存储对象和基本数据类型,长度固定。
Collection:集合(单列),用于存储对象、不能存储基本数据类型(int,char等),但可以存储基本数据类型包装类(int-Integer,char-Character等),长度可变
-
- 那么,为什么会出现这么多集合呢,我们可以把集合比如成容器。每个不同容器中对数据的存储方式不同,这种存储方式称为数据结构。
- 找到一张图的对比可以参考:
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
3. sql 语句 注意分页,和优化,我面试好像都有被问到
分页需求:
客户端通过传递start(页码),limit(每页显示的条数)两个参数去分页查询数据库表中的数据,那我们知道MySql数据库提供了分页的函数limit m,n,但是该函数的用法和我们的需求不一样,所以就需要我们根据实际情况去改写适合我们自己的分页语句,具体的分析如下:
比如:
查询第1条到第10条的数据的sql是:select * from table limit 0,10; ->对应我们的需求就是查询第一页的数据:select * from table limit (1-1)*10,10;
查询第10条到第20条的数据的sql是:select * from table limit 10,20; ->对应我们的需求就是查询第二页的数据:select * from table limit (2-1)*10,10;
查询第20条到第30条的数据的sql是:select * from table limit 20,30; ->对应我们的需求就是查询第三页的数据:select * from table limit (3-1)*10,10;
通过上面的分析,可以得出符合我们自己需求的分页sql格式是:select * from table limit (start-1)*limit,limit; 其中start是页码,limit是每页显示的条数。
优化知道一点点:
连接是outer join,非常不好。因为outer join意味着必须对左表或右表查询所有行。
如果表很大而没有相应的where语句,那么outer join很容易导致table scan或index scan。
要尽量使用inner join避免scan(扫描)整个表。
要尽量减少返回的结果行,包括行数和字段列数。返回的结果越大,意味着相应的SQL语句的logical reads 就越大,对服务器的性能影响就越甚。
一个很不好的设计就是返回表的所有数据:
Select * from tablename 即使表很小也会导致并发问题。更坏的情况是,如果表有上百万行的话,那后果将是灾难性的。DISTINCT去重
---------------------------------------------------------------------------------------------------------------------------------------------------------------
4. 定时任务?怎么实现?用的是什么定时任务?
定一个执行任务execute(),在配置applicationContext-fbms.xml文件里bean属性配置调用的类和调用的方法以及执行的时间值。
插进去一个项目实践的小曲
Spring boot 个人还在学习中,虽然做的项目没有用到,但是贵在学习坚持下,不能太落后了。
---恢复内容结束---