十种高级的代码书写方式,提高代码质量和工作效率

简介: 十种高级的代码书写方式,提高代码质量和工作效率

1.集合遍历

不使用lambda:

List<String> list = Arrays.asList("kk", "oneone", "11");
for (String name : list) {
    System.out.println(name);
}

使用lambda:

List<String> list = Arrays.asList("kk", "oneone", "11");
list.forEach(name -> System.out.println(name));

2.排序

升序

不使用lambda:

List<String> list = Arrays.asList("kk", "oneone", "11");
Collections.sort(list, new Comparator<String>() {
    public int compare(String s1, String s2) {
        return s1.compareTo(s2);
    }
});

使用lambda:

List<String> list = Arrays.asList("kk", "oneone", "11");
Collections.sort(list, (s1, s2) -> s1.compareTo(s2));

3.过滤

不使用lambda:

List<String> list = Arrays.asList("kk", "oneone", "11");
List<String> filteredList = new ArrayList<String>();
for (String name : list) {
    if (name.startsWith("a")) {
        filteredList.add(name);
    }
}

使用lambda:

List<String> list = Arrays.asList("kk", "oneone", "11");
List<String> filteredList = list.stream().filter(name -> name.startsWith("a")).collect(Collectors.toList());

4.映射

映射即按照当前list顺序,根据新的规则新建一个list然后存储对应的对象

不使用lambda:

List<String> list = Arrays.asList("kk", "oneone", "11");
List<Integer> lengths = new ArrayList<Integer>();
for (String name : list) {
    lengths.add(name.length());
}

使用lambda:

List<String> list = Arrays.asList("kk", "oneone", "11");
List<Integer> lengths = list.stream().map(name -> name.length())
.collect(Collectors.toList());

5.规约(求和)

不使用lambda:

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
int sum = 0;
for (int i : list) {
    sum += i;
}

使用lambda:

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
int sum = list.stream().reduce(0, (a, b) -> a + b);

注意: reduce(T identity, BinaryOperator<T> accumulator方法第一个参数传入的是这个求和方法的起始值,如reduce(0, (a, b) -> a + b)输出15,reduce(3, (a, b) -> a + b)输出18

6.分组

把字符串长度相同的放在同一个链表里

不使用lambda:

List<String> list = Arrays.asList("kk", "oneone", "11");
Map<Integer, List<String>> grouped = new HashMap<Integer, List<String>>();
for (String name : list) {
    int length = fruit.length();
    if (!grouped.containsKey(length)) {
        grouped.put(length, new ArrayList<String>());
    }
    grouped.get(length).add(name);
}

使用lambda:

List<String> list = Arrays.asList("kk", "oneone", "11");
Map<Integer, List<String>> grouped = list.stream().collect(Collectors.groupingBy(name -> name.length()));

7.实现函数式接口

不使用lambda:

public interface MyInterface {
    public void doSomething(String input);
}
MyInterface myObject = new MyInterface() {
    public void doSomething(String input) {
        System.out.println(input);
    }
};
myObject.doSomething("Hello World");

使用lambda:

MyInterface myObject = input -> System.out.println(input);
myObject.doSomething("Hello World");

8.进行Optional操作

Optional类是用来解决空指针异常的。

  • Optional.ofNullable(T t):t可以为null
  • Optional.map(Function<? super T,? extends U> mapper):如果有值,则对其执行调用映射函数得到返回值。如果返回值不为 null,则创建包含映射返回值的Optional作为map方法返回值,否则返回空Optional。

不使用lambda:

String str = "Hello World";
if (str != null) {
    System.out.println(str.toUpperCase());
}

使用lambda:

Optional<String> str = Optional.ofNullable("Hello World");
str.map(String::toUpperCase).ifPresent(System.out::println);

9.流水线操作

不使用lambda:

List<String> list = Arrays.asList("kk", "oneone", "11");
List<String> filteredList = new ArrayList<String>();
for (String name : list) {
    if (name.startsWith("a")) {
        filteredList.add(name.toUpperCase());
    }
}
Collections.sort(filteredList);

使用lambda:

List<String> list = Arrays.asList("kk", "oneone", "11");
List<String> filteredList = list.stream().filter(fruit -> fruit.startsWith("a")).map(String::toUpperCase).sorted().collect(Collectors.toList());

10.线程创建

不使用lambda:

Thread thread = new Thread(new Runnable() {
    public void run() {
        System.out.println("Thread is running.");
    }
});
thread.start();

使用lambda:

Thread thread = new Thread(() -> System.out.println("Thread is running."));
thread.start();
目录
相关文章
|
7月前
|
程序员 编译器 C语言
如何更高效的写出更健全的代码,一篇文章教会你如何拥有一个良好的代码风格
如何更高效的写出更健全的代码,一篇文章教会你如何拥有一个良好的代码风格
32 0
|
4月前
|
安全 前端开发 测试技术
【测开方法论】当老功能代码命名不规范的时候...如何安全增加新功能
【测开方法论】当老功能代码命名不规范的时候...如何安全增加新功能
|
11月前
|
程序员 测试技术
《重构2》第十章-简化条件逻辑
《重构2》第十章-简化条件逻辑
305 0
|
XML SQL JavaScript
当前在工作中使用到的高效的代码编写方法
当前在工作中使用到的高效的代码编写方法,让代码去生成重复性质的代码
104 0
|
算法
第七章 多用模板专注设计(上)
第七章 多用模板专注设计
69 0
第七章 多用模板专注设计(上)
|
设计模式 Java 程序员
怎样才能写出规范的好代码?
最近发现一件事情,自己写的代码和公司里工作5到10年的前辈写的代码虽然功能一样,但是他们的代码更规范,更优雅。比如有时候我会给一个需求写一个方法,但是有些人就可以好几个需求通过同一个方法实现。因此有了今天这个疑问,怎样才能写出规范的好代码?
|
Java
一个简单的代码风格优化的小案例
最近 review 了一些代码,其中有一个函数的写法看着别扭,而且对应同学不太清楚还可以怎么优化。由于案例比较典型,值得分享一下。 本文给出对应的伪代码和自己的修改建议,并推荐可以提交代码质量的图书,以便能够帮助大家养成良好的编码风格。
179 0
|
XML Java 测试技术
如何更好的做单元测试并用它来提升代码质量(上)
> 一个使用mockito和spring-test的例子 > 可以在:`https://github.com/weipeng2k/mockito-sample`找到示例。        Java单元测试框架在业界非常多,以JUnit为事实上的标准,而JUnit只是解决了单元测试的基本骨干,而对于Mock的支持却没有。
1397 0
|
Java 测试技术 数据格式
如何更好的做单元测试并用它来提升代码质量(下)
## 现代化的spring-test使用方式 > 以下例子可以在`javaconfig-spring-test`中找到。        在`classic-spring-test`中演示的单元测试,还是用配置文件的方式,但是从Spring4之后,官方就鼓励使用Java的方式对spring进行配置,而不是用以前那
1949 0