.NET高级工程师面试经历

简介: .NET高级工程师面试经历

1.SQL Server数据库操作的原子性,出Select之外,Update、Insert、Delete的操作都是原子性的,不可拆分,执行的最小单位;可以用于充值交费中 ,如果多个请求进行更新同一条 数据时,直接使用update  Table1 set  money=money+100 这种方式就可以避免多个语句,更新一条记录导致的更新失败的问题(一般想法是,先查询当前的账户余额,然后进行更新,这种想法太low);可以直接使用一条更新语句即可;

2.关于单例模式是面试的必问的题目,最直接的回答:确保一个类只有一个实例,并提供一个访问它的全局访问点;概念拆分:1)一个类只有一个实例;2)提供一个全局访问点;如何保证一个类只有 一个实例,定义私有的构造函数,这样外界就不能通过new关键字进行 创建实例了;                                                                                                                                                  

///单例模式

public class Singleton

{

//定义一个静态变量来保存类的实例

private static Singleton unique;

//定义一个标识确保线程的安全同步

private static readonly object locker=new object();

//定义私有的构造函数,使外界不能创建改类的实例

private Singleton()

{

}

//定义共有方法提供一个全局访问

public static Singleton GetInstance()

{

 //当第一个线程运行到这里,此时会有locker对象“加锁”

 //当第二个线程运行该方法时,首先检测到locker对象为“加锁”状态,该线程就会等待挂起,等待第一个线程解锁

 //locker语句执行完成之后(即线程运行完成之后)会对该对象“解锁”

 lock(locker)

 {

  //如果类的实例不存在则创建,否则直接返回

  if(uniq ue==null)

  {

   unique=new Singleton();

  }

 }

 return unique;

}

 

}

3.using的使用

命名空间、引用插件dll、最重要的是数据库的链接,在using里面会进行事务的处理;关闭数据库链接、释放空间;


4.关于秒杀活动的并发问题

关于大并发量的处理,使用lock进行数据的限制,只有一个操作完成之后,第二个操作才能进来,并且数据库使用update进行数据的操作;如果操作失败则不会进行插入操作;


5.关于.Net项目跨平台的问题,.NET 项目经过编译器之后,会生成IL(中间件文件);

6.观察者模式的用法以及好处,主要思想是订阅者、发布者,发布者主要用于触发订阅者事件,订阅者内部具体的实现与发布者无关;

7.关于大数据的处理;数据层如何优化(索引、尽量避免是*、like 、not in等操作、使用分页存储过程的方式)、Redis的缓存数据库的用法、读写分离数据库的 用法、使用轻量级的ORM(NPoco)等操作;

8.关于接口与抽象类的使用;


接口是可以支持类的多实现的,一个类可以实现多个接口;但是一个类只能继承一个抽象类;

9.关于webapi开发接口的安全问题,可以推荐使用JWT的方式进行接口调用的加密:                                                                  

JWT即JSON web Tokens ,可以用来安全的传递信息,因为这些信息是经过数字签名的

JWT可以使用一种加密算法比如HMAC算法,也可以使用公钥/私钥的非对称算法

因为JWT签名后的信息够短,可以放在URL里,request body里、http header里,传输够快

负载信息里面包含所有你想要的信息,避免不止一次的去查询数据库

JWT的使用场景主要包括

1)认证,这是比较常见的使用场景,只要用户登陆过一次系统,之后的请求都会包含签名出来的token

,通过token也可以用来实现单点登陆

2)交换信息,通过使用密钥对来安全的传递信息,可以知道发送者是谁,放置信息被篡改

JSON web Tokens由三部分组成,用英文句点分割(.),一般看起来例如xxx.yyy.zzz

分为:

Header 头信息

PayLoad 负载信息,实际数据

Signature 由头信息+负载信息+密钥 组合之后进行加密得到

1)Header头信息通常包含两部分,type:代表token的类型,这里使用的是JWT类型。alg:使用的Hash算法

,例如HMAC SHA256或RSA

{

"alg":"HS256",

"type":"JWT"

}

//这会被经过base64URL编码形成第一部分

2)PayLoad 一个token的第二部分是负载信息,它包含一下声明Claim(实体的描述,通常是一个User信息,还包括一些

其它的元素)

声明分三类

a)Reserved Claims,这是一套预定义的声明,并不是必须的,这是一套易于使用。操作性强的声明,包括iss(issuer)

exp(expiration time)、sub(subject)、aud(audience)

b)Public Claims

c)Private Claims,交换信息的双方自定义的声明

3)signature使用header中指定的算法将编码后的headr、编码后的payload、一个secret进行加密

例如使用的是HMAC SHA256算法,大致流程类似于:HMACSHA256(base64UrlEncode(header)+"."+base64UrlEncode(payload)+"."+secret)

这个signature字段被用来确认JWT信息的发送者是谁,并保证信息没有被修改;

由于没有使用Cookies,Cross-Origin Resource Sharing(CORS),跨域的资源访问

相关文章
|
1月前
|
SQL 数据库 C#
C# .NET面试系列十一:数据库SQL查询(附建表语句)
#### 第1题 用一条 SQL 语句 查询出每门课都大于80 分的学生姓名 建表语句: ```sql create table tableA ( name varchar(10), kecheng varchar(10), fenshu int(11) ) DEFAULT CHARSET = 'utf8'; ``` 插入数据 ```sql insert into tableA values ('张三', '语文', 81); insert into tableA values ('张三', '数学', 75); insert into tableA values ('李四',
65 2
C# .NET面试系列十一:数据库SQL查询(附建表语句)
|
1月前
|
开发框架 算法 搜索推荐
C# .NET面试系列九:常见的算法
#### 1. 求质数 ```c# // 判断一个数是否为质数的方法 public static bool IsPrime(int number) { if (number < 2) { return false; } for (int i = 2; i <= Math.Sqrt(number); i++) { if (number % i == 0) { return false; } } return true; } class Progr
58 1
|
1月前
|
并行计算 安全 Java
C# .NET面试系列四:多线程
<h2>多线程 #### 1. 根据线程安全的相关知识,分析以下代码,当调用 test 方法时 i > 10 时是否会引起死锁? 并简要说明理由。 ```c# public void test(int i) { lock(this) { if (i > 10) { i--; test(i); } } } ``` 在给定的代码中,不会发生死锁。死锁通常是由于两个或多个线程互相等待对方释放锁而无法继续执行的情况。在这个代码中,只有一个线程持有锁,且没有其他线程参与,因此不
105 3
|
16天前
|
安全 应用服务中间件 网络安全
渗透测试工程师面试题大全
渗透测试工程师面试题大全
|
30天前
|
敏捷开发 安全 API
C/C++ 工程师面试:如何精彩展示你的项目经验并获得高分
C/C++ 工程师面试:如何精彩展示你的项目经验并获得高分
73 0
|
1月前
|
消息中间件 Dubbo Java
互联网 Java 工程师1000道面试题(485页)
互联网 Java 工程师1000道面试题(485页)
28 0
|
1月前
|
SQL 存储 关系型数据库
C# .NET面试系列十:数据库概念知识
#### 1. 为什么要一定要设置主键? 设置主键是数据库设计中的一个重要概念,有几个主要原因: 1、唯一性 ```c# 主键必须保证表中的每一行都有唯一的标识。这样可以避免数据冗余和不一致性。如果没有主键或者主键不唯一,就可能出现数据混乱或错误。 ``` 2、查询性能 ```c# 数据库系统通常会使用主键来加速数据检索。主键通常会被索引,这样可以更快速地找到特定行的数据,提高查询效率。 ``` 3、关联性 ```c# 主键常常用于建立表与表之间的关系。在关系数据库中,一个表的主键通常与其他表中的外键建立关联,这种关系对于数据的一致性和完整性非常重要。 ``` 4、数据完
131 1
C# .NET面试系列十:数据库概念知识
|
1月前
|
XML 开发框架 .NET
C# .NET面试系列八:ADO.NET、XML、HTTP、AJAX、WebService
## 第二部分:ADO.NET、XML、HTTP、AJAX、WebService #### 1. .NET 和 C# 有什么区别? .NET(通用语言运行时): ```c# 定义:.NET 是一个软件开发框架,提供了一个通用的运行时环境,用于在不同的编程语言中执行代码。 作用:它为多语言支持提供了一个统一的平台,允许不同的语言共享类库和其他资源。.NET 包括 Common Language Runtime (CLR)、基础类库(BCL)和其他工具。 ``` C#(C Sharp): ```c# 定义: C# 是一种由微软设计的面向对象的编程语言,专门为.NET 平台开发而创建。 作
174 2
|
1月前
|
开发框架 中间件 .NET
C# .NET面试系列七:ASP.NET Core
## 第一部分:ASP.NET Core #### 1. 如何在 controller 中注入 service? 在.NET中,在ASP.NET Core应用程序中的Controller中注入服务通常使用<u>依赖注入(Dependency Injection)</u>来实现。以下是一些步骤,说明如何在Controller中注入服务: 1、创建服务 首先,确保你已经在应用程序中注册了服务。这通常在Startup.cs文件的ConfigureServices方法中完成。例如: ```c# services.AddScoped<IMyService, MyService>(); //
63 0
|
1月前
|
开发框架 前端开发 .NET
C# .NET面试系列六:ASP.NET MVC
<h2>ASP.NET MVC #### 1. MVC 中的 TempData\ViewBag\ViewData 区别? 在ASP.NET MVC中,TempData、ViewBag 和 ViewData 都是用于在控制器和视图之间传递数据的机制,但它们有一些区别。 <b>TempData:</b> 1、生命周期 ```c# TempData 的生命周期是短暂的,数据只在当前请求和下一次请求之间有效。一旦数据被读取,它就会被标记为已读,下一次请求时就会被清除。 ``` 2、用途 ```c# 主要用于在两个动作之间传递数据,例如在一个动作中设置 TempData,然后在重定向到另
99 5