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

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
主站蜘蛛池模板: 上饶市| 墨竹工卡县| 利津县| 清河县| 吉安市| 辉县市| 洞口县| 襄樊市| 竹山县| 舞阳县| 荔浦县| 吴川市| 丹江口市| 北流市| 黎川县| 海城市| 阳高县| 宝鸡市| 团风县| 徐汇区| 景泰县| 四川省| 北票市| 贵州省| 海阳市| 临邑县| 商都县| 永寿县| 安义县| 宜川县| 金华市| 沅江市| 金堂县| 湘西| 东辽县| 北海市| 景泰县| 阿拉善右旗| 利川市| 广南县| 南漳县|