最后
看完上述知识点如果你深感Java基础不够扎实,或者刷题刷的不够、知识不全面
小编专门为你量身定制了一套<Java一线大厂高岗面试题解析合集:JAVA基础-中级-高级面试+SSM框架+分布式+性能调优+微服务+并发编程+网络+设计模式+数据结构与算法>
针对知识面不够,也莫慌!还有一整套的<Java核心进阶手册>,可以瞬间查漏补缺
全都是一丢一丢的收集整理纯手打出来的
更有纯手绘的各大知识体系大纲,可供梳理:Java筑基、MySQL、Redis、并发编程、Spring、分布式高性能架构知识、微服务架构知识、开源框架知识点等等的xmind手绘图~
b)一次添加多个资源,多个资源先打成zip包
@Test
public void deploy_2() {
// 找到zip文件
InputStream in = this.getClass().getClassLoader().getResourceAsStream(“helloworld/helloworld.zip”);
ZipInputStream zipInputStream = new ZipInputStream(in);
// 部署
String deploymentId = processEngine.getRepositoryService()//
.createDeployment()//
.addResourcesFromZipInputStream(zipInputStream)//
.deploy();
System.out.println("deploymentId = " + deploymentId);
}
c)说明
1, addResourceFromClasspath(resource); 可以调用多次以添加多个文件。文件重复添加也不会报错。
2, addResourceFromInputStream(resourceName, inputStream)添加一个文件(使用InputStream)
3, addResourcesFromZipInputStream(zipInputStream)添加多个文件,里面也可以有文件夹。
4, 以上方法可以在一起调用。
2.查询所有流程定义
a) 查询所有流程定义
@Test
public void findAll() {
// 查询
List list = processEngine.getRepositoryService()//
.createProcessDefinitionQuery()//
.orderAsc(ProcessDefinitionQuery.PROPERTY_KEY)//排序条件
//.count()查询出总数量
//.page(0, 100)分页,取出前100条记录
.list();
// 显示
for (ProcessDefinition pd : list) {
System.out.println(“id=” + pd.getId()// 格式为:{key}-{version}
-
“, name=” + pd.getName()// 流程定义文件(.jpdl.xml)中根元素的name属性的值
-
“, key=” + pd.getKey()// 流程定义文件(.jpdl.xml)中根元素的key属性的值,可以不写,不写就是name属性的值
-
“, version=” + pd.getVersion()// 流程定义文件(.jpdl.xml)中根元素的version属性的值,可以不写,不写就会自增(key相同时,版本加1)
-
“, deploymentId=” + pd.getDeploymentId()); // 本流程定义对应的 .jpdl.xml 文件所属的Deployment对象的id
}
}
b) 查询所有最新版本的流程定义
@Test
public void findAllLatestVersions() {
// 1,查询所有流程定义,按Version升序排列,这样所有最大的版本就都排到最后了
List allList = processEngine.getRepositoryService()//
.createProcessDefinitionQuery()//
.orderAsc(ProcessDefinitionQuery.PROPERTY_VERSION)//
// .processDefinitionName(“test”)//
// .orderAsc(ProcessDefinitionQuery.PROPERTY_KEY)//
// .orderDesc(ProcessDefinitionQuery.PROPERTY_KEY)//
// .uniqueResult()
// .count()
// .page(firstResult, maxResults)
.list();
// 2,过滤出所需的最新版本的流程定义
Map<String, ProcessDefinition> map = new HashMap<String, ProcessDefinition>();
for (ProcessDefinition pd : allList) {
map.put(pd.getKey(), pd);//不同的key会保存最新的版本(上面已经按版本升序排列)
}
// 显示
for (ProcessDefinition pd : map.values()) {
System.out.println(“id=” + pd.getId()// 格式为:{key}-{version}
-
“, name=” + pd.getName()// 流程定义文件(.jpdl.xml)中根元素的name属性的值
-
“, key=” + pd.getKey()// 流程定义文件(.jpdl.xml)中根元素的key属性的值,可以不写,不写就是name属性的值
-
“, version=” + pd.getVersion()// 流程定义文件(.jpdl.xml)中根元素的version属性的值,可以不写,不写就会自增(key相同时,版本加1)
-
“, deploymentId=” + pd.getDeploymentId()); // 本流程定义对应的 .jpdl.xml 文件所属的Deployment对象的id
}
}
3.删除流程定义(其实是删除Deployment)
a) 删除某个Deployment
@Test
public void deleteById() {
String deploymentId = “1”;
// // 删除某Deployment,如果有关联的执行信息,就抛异常
// processEngine.getRepositoryService().deleteDeployment(deploymentId);
// 删除某Deployment,如果有关联的执行信息,就级联删除
processEngine.getRepositoryService().deleteDeploymentCascade(deploymentId);
}
b) 删除指定key的所有版本的流程定义
@Test
public void deleteByKey() {
// 1,查询出指定key的所有版本的流程定义
List list = processEngine.getRepositoryService()//
.createProcessDefinitionQuery()//
总结
虽然面试套路众多,但对于技术面试来说,主要还是考察一个人的技术能力和沟通能力。不同类型的面试官根据自身的理解问的问题也不尽相同,没有规律可循。
上面提到的关于这些JAVA基础、三大框架、项目经验、并发编程、JVM及调优、网络、设计模式、spring+mybatis源码解读、Mysql调优、分布式监控、消息队列、分布式存储等等面试题笔记及资料
有些面试官喜欢问自己擅长的问题,比如在实际编程中遇到的或者他自己一直在琢磨的这方面的问题,还有些面试官,尤其是大厂的比如 BAT 的面试官喜欢问面试者认为自己擅长的,然后通过提问的方式深挖细节,刨根到底。
厂的比如 BAT 的面试官喜欢问面试者认为自己擅长的,然后通过提问的方式深挖细节,刨根到底。