尊敬的.NET开发工程师

2 篇文章 0 订阅
1 篇文章 0 订阅

@[TOC](.NET 中级开发常见面试题目(干货))

尊敬的.NET开发工程师

你们好! 博主很荣幸与你们在同一个行业,以下的面试题希望对你们有所帮助,如有不足之处请补充和指点。

.NET CORE

  1. 什么是.NET CORE?
    .NET CORE 是ASP.NET 的升级版本,是一个免费的,开源的,配置更多,跨平台的web开发框架,
  2. .NET 和.NET CORE的区别在哪里?有什么优势?
    优势在于.NET CORE 是一个跨平台的,开源的,可移植的,可扩展性的,高性能的框架。
  3. .NET CORE中的中间件是什么?在什么情况下使用?原理是什么?
    中间件是注入到应用程序中用于处理请求响应的组件。
    中间件用于构建可扩展的应用程序,它可以帮助开发人员更轻松的实现应用程序的可重用性和可维护性,更好管理应用程序的组件和资源。
  4. 依赖注入是什么?依赖注入的几种方式?
    依赖注入是一种软件设计模式,它允许将组件之间的依赖关系从组件的实现中分离出来,从而使组件可以在不同的环境下重复使用。
    构造函数注入,属性注入,接口注入,方法注入。
  5. .NET CORE SERVICE服务的生命周期?
    初始化 ,运行,关闭,销毁。
  6. redis是什么?有几种数据类型?
    字符串,列表,hash表,集合,无序集合。
  7. 详细描述RabbitMQ中间件?
    是一种消息中间件,它可以帮助应用程序在分布式系统中进行异步通信,它提供了一种可靠的方式开传递数据信息,并且可以支持大量的消费者和生产者。
  8. .NET CORE 有哪些中间件 常见有几种?请详细说明?*
    IIS, WebSockets,SignalR。
    IIS是一种web服务器软件,用于处理HTTP请求,提供静态文件服务,支持ASP,.NET 等动态网页。
    webSockets是一种可以在客服端和服务端简历双向通信的技术。
    Signalr是一个实时通信库,可以让您在web应用程序中实现通信功能。
  9. 什么是单例模式?什么是DDD?
    单例模式是一种设计模式,它确保一个类只有一个实例,并提供一个全局访问点来访问该实例。
    DDD的是领域驱动设计,是一种软件设计模式,应用于实现复杂的软件设计,对程序进行解耦和封装,分为战略设计和战术设计两大块,战略设计是以为业务的角度出发,划分不同的业务领域,战术设计是以技术的角度出发,主要以技术实现为主。

.NET 和C#

  1. 什么是.NET?
    .net 是一个开放源代码的跨平台开发平台。
  2. .NET什么情况下用到锁?
    保护共享资源,防止多个线程访问同时访问该资源,从而导致数据不一致的问题。
  3. .NET怎么捕获异常?有哪几种方式?
    try catch finall,或者使用日志写入异常数据。
  4. 当一个程序需要处理大量数据的时候,程序运行很慢,还有可能阻塞,怎么避免阻塞和进行优化处理?
    使用异步加载方法。
  5. 简单描述什么是AOP?
    面向切面对象,是一种编程技术,它允许开发人员将程序分解为可以重用的模块,这些模块可以在不同的程序中重复使用。
  6. 什么事泛型?泛型有哪些好处?
    泛型是一种编程技术,它允许程序员在编写代码时,使用参数化类型,以便在编译时可以检查类型的安全性。
  7. 简单描述什么是异步加载?
    在不阻塞浏览器的情况下。加载网页内容的一种技术。
  8. 委托是什么?事件是什么?
    可以把一个方法作为参数代入另一个方法,类似于c++中的函数的指针,允许一个或多个方法调用委托给另一个对象。
    事件事一种编程技术,它允许您在特定的时间点触发特定的代码。
  9. 用过哪几种设计模式?
    工厂模式,抽象工厂模式,单例模式。
  10. 什么是ORM?什么是EF
    对象关系映射,它是一种技术用于面向对象的编程语言中的对象映射大关系数据库的表。EF是一个用于.NET 的ORM框架,用于构建数据访问层。

数据库

  1. 什么是.存储过程?
    预编译的SQL语句,由多行sql语句组合而成的。
    存储过程是一种特殊的程序,可以被多次调用,可以接收参数,也可以返回结果。
  2. 什么是事务?
    是一组操作。要么全部成功要么全部失败,它们是原子性的,意味着它们不能被中断,只能作为一个整体来处理。
  3. 视图和存储存储过程的区别?
    视图是一张虚拟表,它可以从一个或多个表中检索数据但是不能接收参数,也不能执行SQL语句。
    存储过程是一种特殊的程序,可以被多次调用,可以接收参数,执行一系列的SQL语句,并可以返回结果。
  4. SQL SERVER 和oracle的区别?各有哪些优势?
    sql server和oracle主要区别在于它们的架构,可用性,安全性,可扩展性和可移植性,sql server 提供了更多的可用性和安全性,oracle提供了更多的可扩展性和可移植性。
  5. 什么聚集索引?和非聚集索引?详细说明区别和优点?
    聚集索引是主键值,非聚集索引不是主键值,聚集索引一个表只能有一个,非聚集索引一个表可以有多个,聚集索引的物理存储记录是物理上连续,
    非聚集索引是逻辑上连续,聚集索引查询比非聚集索引要快,聚集索引是一种特殊的索引它会对索引列的值进行排序,非聚集索引是一种普通索引不会进行排序。
  6. 索引的优缺点?
    增加查询和检索数据的速度,能快速定位到数据,在进行增删改操作的时候会对数据维护造成一定的影响。
  7. 怎么优化SQL语句?
    不使用*号,尽量少用连接,左连接替换内连接,优化分组语句,建立索引,union 替换union all,取别名,使用合理的数据类型,使用合理的查询参数,避免使用子查询。
  8. 在数据量达到几个亿的情况下怎么对数据库进行优化?
    使用ES技术优化,数据库ES技术是一种基于事件的技术,它可以帮组开发人员构建自动响应事件的程序,从而提高应用程序的可扩展性和可维护性。
  9. 什么情况下不走索引查询扫描整个表?
    模糊查询,索引值为空,数据类型不正确,当索引中数据量大于数据表数据量的时候。
    10.ORDER BY 排序走索引吗?
    会走索引,取决于索引类型和排序的字段是否在索引中。

总结

以上就是博主在面试中面试官问到的问题,希望能对你们有所帮助,现在找工作两年以上的经验基本上都不会问一些基础的问题,大部分面试官都是会问底层的一些原理和新的技术,我们作为一个开发人员一定不要固步自封,安于现状,一定要去学习新的知识和加深自己对框架的理解,不然的话会被这个社会淘汰,躺平和不可能躺平的,只能卷,使劲卷吧,互联网的黄金时代已经过去了,不卷找工作都难难难!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

自在猫先生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值