官术网_书友最值得收藏!

Optimizing the Sort - Making Code Professional

In this chapter, we will develop the sorting code and make it more general. We want to sort not only an array of Strings. Essentially, we will write a program that can sort anything that is sortable. That way, we will bring the coding to its full extent toward one of the major strengths of Java: abstraction.

Abstraction, however, does not come without a price tag. When you have a class that sorts strings and you accidentally mix an integer or something else, which is not a string, into the sortable data, then the compiler will complain about it: Java does not allow you to put an int into a String array. When the code is more abstract, such programming errors may slip in. We will look at how to handle such exceptional cases catching and throwing Exceptions.

To identify the bugs, we will use unit testing, applying the industry standard JUnit version 4. As JUnit heavily uses annotation, and because annotations are important, you will learn about it a bit.

After that, we will modify the code to use the generics feature of Java that was introduced into the language in version 5. Using that possibility, we will catch the coding error during compilation time, which is better than during run time. The earlier a bug is identified, the cheaper it is to fix.

For the build, we will still use Maven, but this time, we will split the code into small modules. Thus, we will have a multi-module project. We will have separate modules for the definition of a sorting module and for the different implementations. That way, we will look at how classes can extend each other and implement interfaces, and, generally, we will really start to program in the object-oriented way.

We will also discuss Test Driven Development (TDD), and at the end of the section, we will start using the brand new feature of Java 9: module support.

In this chapter, we will cover the following topics:

  • Object-oriented programming principles
  • Unit testing practices
  • Algorithmic complexity and quick sort
  • Exception handling
  • Recursive methods
  • Module support
主站蜘蛛池模板: 潞城市| 加查县| 塔河县| 揭阳市| 琼中| 曲阜市| 新乡市| 会同县| 儋州市| 工布江达县| 昌都县| 平南县| 宿迁市| 曲麻莱县| 汶川县| 浠水县| 永平县| 太康县| 晋江市| 台南市| 青神县| 论坛| 改则县| 万年县| 宿州市| 隆德县| 泽州县| 宁晋县| 吴江市| 济阳县| 镶黄旗| 县级市| 高雄县| 连山| 彩票| 海林市| 清水河县| 循化| 云龙县| 柳州市| 隆回县|