What is a practical usage of Code Contracts in .NET 4.0?

后端 未结 4 1778
生来不讨喜
生来不讨喜 2021-02-03 20:01

In order to fully understand and take advantage of the new features and enhancements provided with the coming of the new .NET Framework 4.0, I would like to get an example of

相关标签:
4条回答
  • 2021-02-03 20:16

    From The Code Contracts User Manual:

    Contracts allow you to express preconditions, postconditions and object invariants in your code for runtime checking, static analysis, and documentation.

    Code Contracts are used for static verification; imagine if - at compile time - you caught not only syntax errors but also logic errors. This is the vision of static program verification.

    Real World Example

    You could use contracts (and static verification) to reduce the cost of testing... in particular regression testing. As an example, let's say I write some code which fulfills some business needs... but later, performance needs change, and I'm required to optimize. If I first write a contract, then - when my new optimized code is verified - if it no longer fulfills the original contract I'll get an error message in my IDE, just like if I had a compile time error. As a result, you find and resolve the bug almost immediately, which costs less than a round of testing.

    0 讨论(0)
  • 2021-02-03 20:18

    There is a freely available chapter about code contracts in the upcoming book C# in Depth, second edition. By some guy named Jon Skeet, some of you may be familiar with him :)

    As for practical usage. You can use them anywhere in your code, but especially if you're developing framework / API type libraries that lots of people will be using, I expect them to come in quite handy. Static verification of your code saves a lot of time compared to finding out at runtime that you didn't handle some edge case.

    You may document your method usage all you like, but will people actually read that documentation? Is it allowed to have string parameter x in method y be null, or not? Code contracts can provide that information, to take the guesswork out of the equation.

    Here's an example of just such a case:

    static int CountWhitespace(string text)
    {
        Contract.Requires<ArgumentNullException>(text != null, "text");
        return text.Count(char.IsWhiteSpace);
    }
    

    The verification will complain if anyone tried to pass a string to CountWhitespace that might be null. In addition, it will throw an ArgumentNullException at runtime.

    I've only recently converted my private class library to .NET 4.0, but I plan to add code contracts to it real soon.

    0 讨论(0)
  • 2021-02-03 20:19

    There is a lot of places where contracts are used in .Net. >>Sources<<

    0 讨论(0)
  • 2021-02-03 20:20

    Have you ever seen a NullReferenceException and wished that the compiler could have warned you about it at compile time to avoid finding out the hard way - with your program crashing?

    With code contracts you can write things like:

    Contract.Requires(foo != null);
    

    This isn't just a runtime check - you can set it up so that if you call this function with an argument that might be null you will get a compile error.

    Here's a real world example:

    Address GetAddress(Customer customer)
    {
        Contract.Requires<ArgumentNullException>(customer != null, "customer");
        return addressBook.FindCustomer(customer);
    }
    
    0 讨论(0)
提交回复
热议问题