.NET面试深度解析:递归、SQL、委托与事件、LINQ实战

1星 需积分: 10 37 下载量 167 浏览量 更新于2024-09-08 1 收藏 42KB DOCX 举报
"2017年度.NET高频面试题" 这篇资料汇总了2017年.NET面试中的一些常见问题,涉及递归算法、SQL查询、委托与事件、LINQ操作以及字符串和类型系统的理解。 1. 递归算法求30位数字 这段代码展示了一个递归函数`MyFoun_04`,用于计算斐波那契数列的第n项。斐波那契数列的规律是每一项等于前两项之和,前两项都是1。此问题考察了开发者对于递归的理解和使用。递归算法在解决某些问题时非常有效,但要注意避免无限循环和性能问题,因为它可能导致大量的函数调用。 2. SQL语句获取特定范围记录 SQL语句`SELECT * FROM Persons ORDER BY Id OFFSET 2 ROWS FETCH NEXT 3 ROWS ONLY`用于获取表`Persons`中ID排序后的第31至第40条记录。`OFFSET`用于跳过指定数量的行,`FETCH NEXT`用于获取接下来的行数。这种查询方式在处理分页数据时十分常用。 3. 委托和事件 委托是.NET中的一种引用类型,它存储了方法的引用。事件是一种特殊类型的委托,遵循发布-订阅模式。发布器类(即包含事件的类)发布事件,而订阅器类通过事件处理程序订阅这些事件。事件可以保护发布者和订阅者之间的耦合,确保只有订阅了事件的类才会收到通知。 4. LINQ查询偶数子项 `MyFoun_07`函数演示了如何使用LINQ从数组`MyNum`中筛选出大于100的偶数。LINQ简化了数据查询和转换,这里使用了`from`关键字进行查询,`where`关键字进行条件过滤,`select`关键字进行选择,最后通过`foreach`遍历输出结果。 5. 字符串的null和空字符串 在C#中,`string str = null`表示字符串引用为空,即没有指向任何字符串对象。而`string str = ""`表示一个长度为0的字符串,即空字符串。它们在内存中的表现不同,null表示未分配内存,而空字符串则占用了一块内存空间。 6. C#中的值类型和引用类型 值类型包括基本类型如整型、浮点型等,它们直接存储数据,离开作用域后自动释放内存,存储在堆栈中。引用类型如类实例,只存储数据的引用,引用的对象在内存堆中,离开作用域后不立即释放,需要等待垃圾回收机制。 以上内容涵盖了.NET开发中的一些基础和进阶知识点,对于理解和准备.NET面试具有很高的参考价值。了解并掌握这些概念和技术,有助于提升.NET开发者的专业水平。