Java和.NET(C#)的开发用到的技术对比总结

声明:我指的是一般的Java和.NET(C#)的后台开发用到的技术总结

最近一直在应聘ing,楼主的项目还是.NET(C#)项目居多,Java项目相对少,在这也吐槽下,招.NET(C#)的公司实在是少的可怜,其实非常喜欢C#语法和VS宇宙第一编辑器的,虽然.NET Core口碑不错,但无奈于生态不如Java,所以发展的还是太慢了,介于此,秋招楼主投的还是Java技术后台的岗位居多,但遇到招.NET(C#)的公司还是心里一动,肯定要投一下的。

好了不水了,下面我从“大局观”的角度来比较一下一般的Java和.NET(C#)的项目后台用到的技术。以便在面试的时候可以系统的和面试官介(chui)绍(niu)下。

当然,由于是应对秋招,这里所用到的例子项目是非常初级,简单的项目。大牛级别的绕过忽略此文haha。

总结 开发

 1. 视图层技术——HTML,CSS,JS,AJAX,Tiles,Velocity,FreeMarker

 2. 持久层技术

 Java——Hibernate,Ibatis,Mybatis,DBUtils,SimpleJDBC等

 .NET(C#)——EF、Dapper、NHibernate(很多还有好多国产的,比如SqlSugar 、Chloe )

 详见:https://www.cnblogs.com/jackytang/p/9111980.html

 3. web框架:

 Java—— Spring MVC、Spring Boot 、Spring Cloud、Struts等

 .NET(C#)——WebForm、ASP.NET MVC(主流)、ASP.NET Core(跨平台)

 4. 项目构建工具

 Java——Maven

 .NET(C#)——Nuget

 5. 日志框架

 Java——JDKLog、Log4J、LogBack、SLF4J、SLF4J

 详见此文:https://www.cnblogs.com/baizhanshi/p/7911123.html

 .NET(C#)——

 Log4Net.dll:轻量级的免费开源.NET日志记录框架。

 Enterprise Library Log Application Black:微软企业库日志记录。

 Elmah:实现最流行的ASP.NET应用异常日志记录框架。

 NLog:是一个简单灵活的日志记录类库,性能比Log4Net高,使用和维护难度低。

 6. 版本控制 Git

数据库技术

 1. SQL语句

 2. 参数调优

操作系统

 1. 熟练掌握一种Linux系统,原理,Shell命令

 2. Windows操作系统基础必须了下。 

服务器技术

 Java——

 1. 熟练使用并理解一个Web应用服务器技术的原理(Tomcat)

 2. 熟练使用并理解一个Web服务器技术的原理(Nginx)

 .NET(C#)——

 1. 熟练使用并理解一个Web应用服务器技术的原理(IIS+.NET Framework(开源之前))

 2. 熟练使用并理解一个Web服务器技术的原理(IIS、Kestrel)

注1:关于Web应用服务器和Web服务器技术可以读读这两篇文章:

 

 

https://www.cnblogs.com/vipyoumay/archive/2017/08/31/7455431.html

注2:在这里我还要罗嗦几句,.Net 开源之后和之前还是有很大区别的,不懂。NET 技术的JAVA 同学想要转.NET 的还是直接转.NET Core吧(haha ,有么?)。

比如:

.NET的Web服务器:包括 IIS Express、Internet Information Services (IIS)、外部主机或自定义 Web 服务器

.NET Core的Web服务器:与ASP.NET不同,ASP.netCore使用的是自托管web服务器Kestrel,所以IIS目前对于ASP.netCore只充当转发请求的代理而已,反向代理到ASP.netCore就需要iis之前没有的模块称为:AspNetCoreModule,此模块包含在ANCM(官网说明:ANCM)中,下载地址:.NET Core Windows Server Hosting

https://www.nuget.org/packages/Microsoft.AspNetCore.Hosting.WindowsServices/

缓存技术

1. 熟练使用并理解一种缓存技术(Redis, Memcache,EhCache)

非关系型数据库

2. 熟练使用并理解一种非关系型数据库(MongoDB)

.NET(C#)专用:

Microsoft Velocity:微软自家分布式缓存服务框架。 

EnyimMemcached:访问Memcached最优秀的.NET客户端,集成不错的分布式均衡算法。

中间件技术

Java——

1. JMS:activeMQ和kafka

2. RPC: Dubbo

.NET Core ——

内在的中间件就有挺多了。

Authentication 提供身份验证支持 

CORS 配置跨域资源共享

Response Caching 提供缓存响应支持

Response Compression 提供响应压缩支持

Routing 定义和约束请求路由

Session 提供用户会话管理

Static Files 为静态文件和目录浏览提供服务提供支持

URL Rewriting Middleware 用于重写 Url,并将请求重定向的支持

设计模式

1. 了解并能够使用几种最主要的设计模式,这个是基础,必学

网络

1. 熟悉http,TCP协议等网络基础,必学

虚拟机

Java——

Java虚拟机:

1. 熟悉jvm运行原理,内存分布

2. jvm参数调优

.NET(C#)——
CLR 

公共语言运行时。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zywfpd.html