The practice of programming


Chapter 4 Interfaces

A good programmer should always be good at designing. The essence of design is to balance competing goals and constraints. When we do programming, we need to design a friendly, portable and flexible interface.

Among the issues to be worked out in a design are:

  interfaces,  information hiding,  resource management,  error handling

These factors are not separated, but combined.

So, how to do a good designer? On the other word, how to handle the issues above perfectly?

The first step is to construct a general frame, leaving out the details. Then we need to test it by thinking of every possible situation, and improve it. By the way, it is essential for our frame to work in changeable environments. In this circumstance, we need specifications to constraint our work. Generally speaking, specifications had better be worked out in advance.

To prosper an interface must be well suited for its task-simple, general, regular,predictable, robust-and it must adapt gracefully as its users and its implementation change.

  • Hide implementation details
  • Avoid global variables
  • Don't reach behind the user's back
  • Do the same thing the same way everywhere

About Resource Management:

  • Initializationma
  • Maintaining state
  • Sharing and copying
  • Cleaning up (Free a resource in the same layer that allocated it)

To avoid problems, it is necessary to write code that is reentrant,  which means that it works regardless of the number of simultaneous executions.

The text of error messages, prompts, and dialog boxes should state the form of valid input.

Charpter 5 Debugging

  • Good Clues
  1. Look for familiar patterns
  2. Examine the most recent change
  3. Don't make the same mistake twice
  4. Debug it now, not later
  5. Get a stack trace
  6. Read before typing
  7. Explain your code to someone else
  • No Clues

  1. Make the bug reproducible
  2. Divide and conquer
  3. Study the numerology of failures
  4. Display output to localize your search
  5. Write self-checking code
  6. Write a logfile
  7. Draw a picture
  8. Use tools
  9. Keep records
  • Last Resorts

    This may be  the time to use a good debugger to step through the program.

  • Non-reproducible Bugs

  1. Check whether all variables have been initialized
  2. If the bug changes behavior or even disappears when debugging code is added, it may be a memory allocation error

Chapter 6 Testing

  • Test as You Write the Code

  1. Test code at its boundaries
  2. Test pre- and post-conditions
  3. Use assertions
  4. Program defensively
  5. Check error returns
  • Systematic Testing
  1. Test incrementally
  2. Test simple parts first
  3. Know what output to expect
  4. Verify conservation properties
  5. Compare independent implementations
  6. Measure test coverage
  • Test Automation

  1. Automate regression testing
  2. Create self-contained tests
  • Test Scaffolds

  • Stress Tests

  • Tips for Testing

  1. Programs should check array bounds (if the language doesn't do it for them), but the checking code might not be tested if the array sizes are large compared to typical input.
  2. Make the hash function return a constant, so every elemen1 gets installed in the same hash bucket.
  3. Write a version of your storage allocator that intentionally fails early, to test your code for recovering from out-of-memory errors.
  4. Before you ship your code. disable testing limitations that will affect performance.
  5. Initialize arrays and variables with some distinctive value, rather than the usual default of zero; then if you access out of bounds or pick up an uninitialized variable, you are more likely to notice it.
  6. Vary your test cases
  7. Provide ways to make the amount and type of output controllable when a program is run; extra output can help during testing.
  8. Test on multiple machines, compilers, and operating systems.

Chapter 7 Performance

Before changing a program to make it  faster, be certain that it really is too slow, and use timing tools and profilers to discover where the time is going.

In any case, times have changed, and both main memory and secondary storage are amazingly cheap. Thus the first approach to optimizing space should be the same as to improving speed: don't  bother.

When you're trying to improve the speed or space consumption of a program, it's a good idea to make up some benchmark tests and problems so you can estimate and keep track of performance for yourself.

Chapter 8 Portability

Our message is this: try to write software that works within the intersection of the various standards, interfaces and environments it must accommodate. Don't fix every portability problem by adding special code; instead, adapt the software to work within the new constraints. Use abstraction and encapsulation to restrict and control unavoidable non-portable code. By staying within the intersection of constraints and by localizing system dependencies, your code will become cleaner and more general as it is ported.

  • Language

  1. Stick to the standard
  2. Program in the mainstream
  3. Be ware of language trouble spots......
  • Headers and Libraries

  1. Use standard libraries
  • Program Organization

  1. Use only features available everywhere
  2. Avoid conditional compilation
  • Isolation

  1. Localize system dependencies in separate files
  2. Hide system dependencies behind interfaces
  • Data Exchange

  1. Use text for data exch
  • Byte Order

  1. Use a fmed byte order for data exchange
  • Portability and Upgrade

  1. Change the name ifyou change the specification
  2. Maintain compatibility with existing programs and data
  • Internationalization

Chapter 9 Notation

  • Regular Expressions

   The best-known regular expression tool is the program grep.

   Unfortunately, not every system comes with grep  or an equivalent. Some systems include a regular expression    library, usually called regex  or regexp,  that you can use to write a version of grep.  If neither option is available,    it's easy to implement a modest subset of the full regular expression language.

  • Programs that Write Programs
  • Using Macros to Generate Code

  • Compiling on the Fly


Summary

The book generally introduces how to program practically, including the following topics:

  • Style
  • Algorithms and Data Structures
  • Design and Implementation
  • Interfaces
  • Debugging
  • Testing
  • Performance
  • Portability
  • Notation

It emphasizes the practical problems we may meet in the programming. I think the most important thing is also practice, and learn by doing. Before we do, we need a general structure, a plan, a standard to help us better maintain, transmit a program. When we do, we need a good style, algorithms, and interfaces. When we finished, or half-finished, we need test, debug to improve it.

Some details need more studying because of my narrow knowledge. I'll look back this book from time to time.

That's all.

Book Review of “The practice of programming” (Ⅳ)的更多相关文章

  1. Book Review of “The practice of programming” (Ⅲ)

    The practice of programming Chapter 3 Design and Implementation In this section, we focus on one kin ...

  2. Book Review of “The practice of programming” (Ⅱ)

    The practice of programming Chapter 2 Algorithms and Data Structures Searching sequential search (li ...

  3. Book Review of "The Practice of Programming" (Ⅰ)

    The Practice of Programming In the preface, the author illustrates four basic principles of programm ...

  4. 2015年第2本(英文第1本):《The Practice of Programming》

    2015年计划透析10本英文原著,最开始选定的第一本英文书是<Who Moved my Cheese>,可是这本书实在是太短.太简单了,总体的意思就是要顺应变化,要跳出自己的舒适区,全文不 ...

  5. net programming guid

    Beej's Guide to Network Programming Using Internet Sockets Brian "Beej Jorgensen" Hallbeej ...

  6. FRP represents an intersection of two programming paradigms.

    FRP represents an intersection of two programming paradigms. Functional programming Functional progr ...

  7. [转]9个offer,12家公司,35场面试,从微软到谷歌,应届计算机毕业生的2012求职之路

    1,简介 毕业答辩搞定,总算可以闲一段时间,把这段求职经历写出来,也作为之前三个半月的求职的回顾. 首先说说我拿到的offer情况: 微软,3面->终面,搞定 百度,3面->终面,口头of ...

  8. 9个offer,12家公司,35场面试,从微软到谷歌,应届计算机毕业生的2012求职之路

    1,简介 毕业答辩搞定,总算可以闲一段时间,把这段求职经历写出来,也作为之前三个半月的求职的回顾. 首先说说我拿到的offer情况: 微软,3面->终面,搞定 百度,3面->终面,口头of ...

  9. (转)9个offer,12家公司,35场面试,从微软到谷歌,应届计算机毕业生的2012求职之路

    原文:http://www.cnblogs.com/figure9/archive/2013/01/09/2853649.html 1,简介 毕业答辩搞定,总算可以闲一段时间,把这段求职经历写出来,也 ...

随机推荐

  1. poj 3084(最小割)

    题目链接:http://poj.org/problem?id=3084 思路:题目的意思是不让入侵者进入保护的房间,至少需要锁几道门.网络流建模:设一个超级源点,源点与有入侵者的房间相连,边容量为in ...

  2. iOS开发,利用文件流,算大文件的MD5值(程序不会导致内存崩溃)

    CFStringRef FileMD5HashCreateWithPath(CFStringRef filePath, size_t chunkSizeForReadingData) { // Dec ...

  3. Win10下Hyper-V设置网络连接

    具体方法如下. 1.点击虚拟交换机管理 2.创建虚拟交换机 选择内部 3.选择链接类型

  4. mybatis的oracle的in超过1000的写法

    <if test="preIds != null and preIds.size() > 0"> AND PRE_ID IN <trim suffixOve ...

  5. 10.php引用(&)详解及注意事项

    <?php function &test() { static $b=0;//申明一个静态变量 $b=$b+1; echo $b; return $b; } $a=test();//这条 ...

  6. 网站行为跟踪 Website Activity Tracking Log Aggregation 日志聚合 In comparison to log-centric systems like Scribe or Flume

    网站行为跟踪 Website Activity Tracking 访客信息处理 Log Aggregation   日志聚合 Apache Kafka http://kafka.apache.org/ ...

  7. CURLOPT_SSL_VERIFYPEER CURLOPT_SSL_VERIFYHOST

    w /** * Set curl options relating to SSL. Protected to allow overriding. * @param $ch curl handle */ ...

  8. gerrit添加appkey以及简单添加分支

    最近团队开放用上gerrit版本项目管理工具,简单说一下appkey配置过程 首先是拿到gerrit分配的账户密码.然后进入到首页,假如是新搭建的应该是没有信息,我这里有一些提交的信息,然后找到右上角 ...

  9. SOE不能进入断点调试

    一.前言 任何程序开发,如果不能进入断点调试,是非常的痛苦的. 如果有过SOE开发经验的人都知道,SOE开发过程中调试是非常麻烦的.任何在SOE开发模板中的修改都需要重新编译工程,重新生成.soe 文 ...

  10. [luogu4556]雨天的尾巴

    [luogu4556]雨天的尾巴 luogu 发现是一顿子修改然后再询问,那么把修改树上差分一下再线段树合并 但是... 如果你只有35分... https://www.luogu.org/discu ...