书籍推荐:《More Effective C#》

 
 

640?wx_fmt=jpeg

很多年前看过Bill Wagner的《Effective C#》第一版,涵盖了C#2.0相关语言特性的最佳实践,教我们怎样更优雅地去编写C#代码,当时觉得受益匪浅。最近拿到了《More Effective C#》第二版,目前看了大概三分之二,让我对C#的的应用有了更深入的了解,书虽没看完,但还是要推荐一下。

《More Effective C#》第二版涵盖到了C#7.0的特性,全书分为5个大的章节,类型处理、API设计、异步编程、并行处理和动态编程,我觉得深入理解前三章便能让您在工作中如虎添翼,学习和了解C#中的一些特性,并且能知道在什么场景下使用这些特性,真正做到了知其然也知其所以然。

只要涉及到编程,总会回归到各种数据类型的操作,怎样合理的使用数据类型,怎样避免一些陷进,这些在第一章中都会涉及到,比如在判断两个对象相等有下面一些原则:

不只是给出了实践的方法,更是说清楚了其中的原委。

一个有追求的程序员,一定不甘心每天只做CRUD,随着经验的增长,您可能需要去编写更下游的程序,需要提供安全、好用、可扩展的方法或接口供上游调用,即便您只是写写WebAPI,依然会被各种端去调用,第二章的API设计会让您少走很多弯路。

比如我们平时在设计类时,碰到需要做拷贝的,就会很自然想到去实现ICloneable接口,书中告诉了我们为什么不要去实现ICloneable接口,以及什么情况下可以去实现ICloneable接口。

还有,在调用.NET一些底层方法时,有时会出现很多的重载版本,那么在我们写代码时,会去借鉴,也会写出有很多重载版本的方法。书中建议我们在初次设计方法时,可以利用可选参数和命名参数来设计方法的参数,可以减少方法的重载版本,但发布后,如果有调整,建议添加重载版本。

第三章讲述了怎样使用异步编程,内容虽然不是很多,但如果您已经使用过异步编程,这些会让您理解更加深刻。下面举一个小例子。

在C#7中加入了本地方法的特性,可以让我们在方法的内部写方法,代码如下:

static void LocalMethod(){    string name = "oec2003";    string name1 = "oec2004";    Console.WriteLine(AddPrefix(name));    Console.WriteLine(AddPrefix(name1));    string AddPrefix(string n)    {        return $"Hello {n}";    }}
    string name = "oec2003";
    string name1 = "oec2004";

    Console.WriteLine(AddPrefix(name));
    Console.WriteLine(AddPrefix(name1));

    string AddPrefix(string n)
    
{
        return $"Hello {n}";
    }
}

可能您知道有这么一个特性,但并不知道该什么时候用,在不知道的情况下,为了去使用某个特性,可能出现滥用。书中给出了该特性的一个应用场景。看下面一段示例代码:

public Task<string> LoadMessage(string userName){    if (string.IsNullOrWhiteSpace(userName))    {        throw new AggregateException(message: "username is null");    }    return LoadMessageImpl();    async Task<string> LoadMessageImpl()    {        var name = await LoadMessageAsync();        var message = name ?? "No Message";        return message;    }}Task<string> LoadMessageAsync(){    var task = Task.Run(() =>    {        Thread.Sleep(5000);        return "oec2003";    });    return task;}
    if (string.IsNullOrWhiteSpace(userName))
    {
        throw new AggregateException(message: "username is null");
    }
    return LoadMessageImpl();

    async Task<stringLoadMessageImpl()
    
{
        var name = await LoadMessageAsync();
        var message = name ?? "No Message";
        return message;
    }
}
Task<stringLoadMessageAsync()
{
    var task = Task.Run(() =>
    {
        Thread.Sleep(5000);
        return "oec2003";
    });
    return task;
}


本文是我阅读到现在的一个最直观的感受,书中的内容我在理解、消化并进行实践后会继续分享出来。总之,好书是需要反复阅读的,直到看到某一小节的名称便能说出它的来龙去脉,才是真正的掌握。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Effective C”是指使用C语言进行编程时,在代码的编写和设计中遵循的一些有效原则和最佳实践。以下是关于如何编写高效的C代码的一些重要原则。 首先,关注代码的可读性和可维护性。良好的代码应该易于阅读和理解,使得其他开发人员能够轻松地理解代码的意图和执行流程。为了提高代码的可读性,应该使用有意义的变量和函数名,并适当地注释代码。 其次,避免过度优化。当编写C代码时,可能会有一种倾向,即过度优化以提高代码的执行速度。然而,这往往会使代码变得复杂和难以维护。在大多数情况下,应该首先写出能正常工作的代码,然后在必要时进行优化。 另外,内存管理是编写高效C代码的关键。正确地分配和释放内存,避免内存泄漏和内存访问错误是至关重要的。可以使用malloc和free函数进行动态内存分配和释放,但是一定要注意释放已经分配的内存,以避免内存泄漏问题。 此外,避免使用过多的全局变量。全局变量的使用可能会导致代码的不可预测性和可维护性的降低。应该尽可能地将变量的作用范围限制在函数内部,并使用参数传递数据。 最后,进行适当的错误处理和异常处理。有效的C代码应该能够处理各种可能的错误情况,并提供适当的错误消息和恢复机制,以保证程序的稳定性和可靠性。 总之,“Effective C”是通过遵循一些有效的编程原则和最佳实践,以提高C代码的质量和效率。这些原则包括关注代码的可读性和可维护性,避免过度优化,正确地进行内存管理,避免过多的全局变量,以及进行适当的错误处理和异常处理。遵循这些原则可以帮助开发人员编写高效、可扩展和可维护的C代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值