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

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
主站蜘蛛池模板: 余姚市| 丹凤县| 青浦区| 万山特区| 德惠市| 福鼎市| 云梦县| 吉隆县| 灵寿县| 梨树县| 巨鹿县| 黄浦区| 辽中县| 淮安市| 顺平县| 青冈县| 荃湾区| 崇阳县| 绵阳市| 靖江市| 霍林郭勒市| 揭东县| 横峰县| 林甸县| 石柱| 利辛县| 渭源县| 临武县| 淄博市| 田阳县| 仪征市| 咸丰县| 乌鲁木齐县| 舞阳县| 秦安县| 永吉县| 花垣县| 临高县| 张家口市| 江安县| 贺兰县|