CLR与JVM

640?wx_fmt=jpeg



首先要纠正垃圾回收在于JVM和.NET的CLR的平台功能而不是语言本身。


存在一些历史差异主要是因为.Net的设计是从java(和其他基于gc的平台)演变中吸取教训改良后的结果。



CLR一开始就设计成了分代垃圾回收,但是初始JVM没有分代垃圾收集器。第一代的JVM垃圾收集器往往是Mark和Sweep这样简单。但随着发展,JVM已引用了分代垃圾回收机制

JVM提供了大量选项来调整GC各个方面或者在不同模式直接 的切换,例如

640?wx_fmt=jpeg



相比之下,CLR几乎没有提供这样繁琐个性化配置,CLR通过不断优化.NET或者.NETCore的性能来达到通用高性能和依靠服务器端的性能收集器来进行优化,最新基准测试.NETCore的性能已经在前几相当可观,避免开发人员花大量时间在clr调优又能享受极高性能,更关键的是可让所有应用无关底层平台配置而进行快速升级,而JVM提供的底层配置可不断修改jvm配置以适应业务发展,但是,这样个性化配置也是一把双刃剑,JVM调优不是一件容易的事,他是几十个配置叠加的效果,往往并不只是把GC频率和调大调小那样简单,另一方面这些JVM的优化只是用来掩盖问题的手段。真正为何引发性能问题而往往被忽视,到最后还是不得不去寻找问题根源




640?wx_fmt=jpeg



CLR和JVM之间的5个相似点和不同点


CLR和JVM之间的最大相似之处包括:


 ● 两台虚拟机(VM)


 ● 两者都包括垃圾收集


 ● 两者都采用基于堆栈的操作


 ● 两者都包括运行时级安全性


 ● 两者都有异常处理方法


CLR和JVM之间的主要区别包括:


 ● CLR被设计为与语言无关,JVM被设计为特定于Java


 ● CLR最初只与Windows兼容(已发布多年的.netcore和将来的.net5都是跨平台),JVM适用于所有主要操作系统


 ● CLR使用JIT编译器,JVM使用称为Java HotSpot的专用JIT编译器


 ● CLR包含闭包,async await协程和指针声明/操作的指令,而JVM则没有


● 值类型的处理,JVM中根据逃逸分析的参数来决定何时哪些对象在堆上创建,否则在栈或者寄存器上创建以减少内存空间,而在CLR中是原生支持值类型


 


什么是虚拟机?


不难猜测虚拟机(VM)是计算机操作系统的虚拟仿真。除此之外,这种系统抽象有两种不同的实现方式。


系统虚拟机作为全功能操作系统存在,通常创建为替代使用物理机器。通过这种方式,多个环境可以同时在同一台机器上运行。但是,这听起来不像我们熟悉的CLR和JVM。


公共语言运行时(CLR)和Java虚拟机(JVM)都是进程虚拟机。这意味着它们不是执行整个操作系统,而是专门设计用于运行流程或程序而不依赖于平台环境。


深入研究CLR与JVM的相似之处


CLR和JVM都是虚拟机,它们都执行与平台无关的操作,即执行已编译的源代码。从本质上讲,这些虚拟机既可以作为程序员源代码和系统机器代码之间的中间步骤,也可以通过各种类型的处理器实现更高的可用性。在下图中,您可以看到两者的高级功能实际上是很相同的。




640?wx_fmt=jpeg



CLR与JVM高级功能


除了基本功能之外,还包括垃圾收集,运行时安全性和异常处理的方法。最后提到的一个相似之处是,它们都采用基于堆栈的操作,这是存储和检索操作数及其结果的最常用方法。


但是,当然,对于这些VM共享的每个相似性,可以找到实现上的差异。尽管如此,正如编程语言一样,这些虚拟机的开发互相学习。一个实现类似垃圾收集的  mark-sweep-compact 方法,另一个很快就会跟进。


主要差异:


语言和平台兼容性


CLR和JVM之间的一个潜在差异(尽管可能影响它们的开发方式)JVM是专门用于Java的,而CLR是为了与语言无关而设计的。相反,CLR最初设计为仅在Windows操作系统上运行,而JVM始终与操作系统无关。众所周知,随着发展16年微软发布.netcore,现在有了在Linux和Mac上运行的CoreCLR。


这导致了这样一个情况,即在大多数情况下,CLR和JVM之间的差异也是使用它们的语言之间的差异。或者,也可以说语言之间的一些最重要的差异。


JIT编译


我们在VM级别看到的一个很大的区别是,虽然两者都使用JIT(即时)编译,但编译器不会被调用同时运行。CLR在运行时调用时将所有MSIL代码编译为机器代码。JVM使用名为HotSpot的专用性能引擎将Java字节码JIT编译为机器可读代码。它的不同之处在于它编译和优化了最常用的代码中的“热点”。


每种编译策略在性能方面都有自己的权衡。因为CLR在运行时会编译一次所有机器代码,所以在某些情况下执行时间会有所改善。但另一方面,如果需要高频率的一小部分代码,Java的HotSpot编译器可以通过额外的优化来提高效率。


语言特色的实现


另一个较小的区别是CLR是使用指令来构建处理泛型类型以及运行时类型。基本上,这意味着CLR识别例如List <int>和List <String>之间的区别,而JVM则不能(Java实现的泛型是作为编译器的一部分,换句话说他只是语法糖,而没有真正的在执行期间判断类型,往往用java泛型要考虑到类型擦除的问题)。CLR还允许用户以Structs的形式定义新的值类型,而基于JVM的语言中的值类型是固定的(byte,short,int,long,float,double,char,boolean)。


生产监控和异常处理


虽然两者都包含异常处理方法,但两者之间的总体差异可能会影响与不同异常和错误监视工具的兼容性。反过来,这会影响故障排除策略和工作流程。




表现和采用


众所周知JAVA在运行期间占用大量内存,一方面由于没有原生支持值类型导致的内存占用,另一方面虽然JVM支持由开发人员设置GC策略,但是往往设置的低于CLR平台很大概率会导致应用没有更多可用空间而崩溃。




社区


说到竞争对手,我们知道.NET和Java都有强大的社区支持它们。在这些社区中,开发人员会在StackOverflow等网站上提出问题并进行深入的对话。搜索VM的名称可以发现,与已标记为8,628次的JVM相比,CLR已标记了3,250次。


在StackOverflow之外,还有微软和Oracle自己培养的广泛社区。在那里,用户可以找到与CLR和JVM不仅仅相关的其他信息和资源。包括云中的实施,故障排除问题等。


除此之外,社区肯定更多地围绕个人语言和平台,如.NET,Java,C / C ++,Scala等。


最后的想法


在最高级别查看这些VM,CLR和JVM之间的差异似乎几乎可以忽略不计。但是,在许多(如果不是大多数)情况下,VM级别的差异反映了使用它们的语言之间的主要差异。由于构建了这些VM及其相应语言的方式,每个VM的功能略有不同,以便提供作者想要提供的功能






参考


https://www.oracle.com/webfolder/technetwork/tutorials/obe/java/gc01/index.html




https://stackoverflow.com/questions/453610/javas-virtual-machine-and-clr


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/314894.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Mutex进行线程处理

Mutex就像一个C&#xff03;锁(lock)&#xff0c;但它可以跨多个进程工作。换句话说&#xff0c;Mutex可以是计算机范围的&#xff0c;也可以是应用程序范围的。Mutex是一个同步原语&#xff0c;也可用于进程间同步。当两个或多个线程需要同时访问共享资源时&#xff0c;系统需…

Educational Codeforces Round 75 (Rated for Div. 2) D. Salary Changing 二分 + check

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 直接算不好算&#xff0c;考虑二分这个中位数midmidmid。 考虑如何checkcheckcheck&#xff0c;这个分情况来就好了&#xff1a; (1)mid>a[i].r(1)mid>a[i].r(1)mid>a[i].r&#…

【Linux】Linux常见指令解析上

目录 1. 前言2. ls指令3. pwd指令4. cd指令3.1 cd常见快捷指令 4. touch指令5. mkdir指令6. rmdir指令 && rm指令 &#xff08;重要&#xff09;6.1 rmdir指令6.2 rm指令 7. man指令 1. 前言 这篇文章我们将详细介绍一下Linux下常见的基本指令。 2. ls指令 语法: ls [选…

PYPL 7月榜单公布:Java份额出现下降趋势

PYPL(PopularitY of Programming Language&#xff0c;编程语言流行指数) 7 月份的榜单已发布&#xff0c;目前包含四个排行榜&#xff0c;囊括编程语言、IDE、ODE(Online IDE) 以及数据库四大领域。PYPL 是非常流行的参考指标&#xff0c;其榜单数据的排名均是根据榜单对象在 …

Codeforces Round #593 (Div. 2) D. Alice and the Doll 暴力 + 二分

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 还以为这个题有什么高深的算法&#xff0c;结果就是个暴力。 由于n∗mn*mn∗m达到了1e101e101e10的级别&#xff0c;所以直接暴力肯定是不行的&#xff0c;考虑有很多空格&#xff0c;我们…

远古魔力 | 在Windows 10和Azure App Service里跑上世纪的ASP

ASP&#xff08;没有.NET&#xff09; 即 Active Server Pages &#xff08;动态服务器页面&#xff09;是一项由微软公司在1996年推出的技术&#xff0c;能够在IIS中运行动态网站。也许许多90后及千禧一代程序员并没有听说过它&#xff0c;但很多老程序员曾经用ASP编写了诸如D…

P2375 [NOI2014] 动物园 kmp fail指针/倍增

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 由kmpkmpkmp中失配数组nenene的含义我们知道&#xff0c;ne[i],ne[ne[i]],...ne[i],ne[ne[i]],...ne[i],ne[ne[i]],...都是iii的相等的前后缀&#xff0c;但是可能有重叠的部分&#xff0c…

DDD“上吊绳驱动开发”,开发要想不被“吊死”,该如何自救?

话题缘起01今天在DevOps案例深度研究讨论群里&#xff0c;群友们围绕一种开发模式展开了讨论&#xff1a;DDD&#xff08;Deadline Driven Development&#xff09;&#xff0c;期限驱动开发&#xff0c;大家似乎更愿意将其翻译成“上吊绳驱动开发”。这种开发模式是说在接到新…

「Sqlserver」数据分析师有理由爱Sqlserver-好用的插件工具推荐

在此系列中&#xff0c;笔者为大家带来一些以数据分析师视角去使用Sqlserver的系列文章&#xff0c;希望笔者走过的路能够给后来者带来一些便利。背景介绍在数据分析师的角色下&#xff0c;使用数据库更多的是为了从数据库中获取数据&#xff0c;和数据库交互的语言是SQL&#…

P4824 [USACO15FEB]Censoring S kmp + 栈

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 如果删除之后两个串不拼起来就是个裸kmpkmpkmp了&#xff0c;但是这个题能拼起来&#xff0c;拼起来之后还有可能生成一个新的串&#xff0c;而且起点在当前位置之前。 考虑是否能找到删掉…

使用kubectl管理k8s集群(三十)

前言Foreword在搭建k8s集群之前&#xff0c;我们需要先了解下kubectl的使用&#xff0c;以便在集群部署出现问题时进行检查和处理。命令和语法记不住没有关系&#xff0c;但是请记住主要的语法和命令以及帮助命令的使用。在下一篇&#xff0c;我们将讲述使用Kubeadm来创建k8s集…

P3435 [POI2006]OKR-Periods of Words kmp + fail指针

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 转换一下题意&#xff0c;就是求一个最小公共前后缀&#xff0c;显然可以暴跳nenene数组&#xff0c;复杂度O(n2)O(n^2)O(n2)&#xff0c;注意到我们每次都跳的话会跳到很多重复的位置&…

架构杂谈《四》

分布式一致性协议一、引言在分布式系统中&#xff0c;为了保证数据的高可用&#xff0c;通常会将数据保留多个副本(replica)&#xff0c;这些个副本会放在不同的物理机上&#xff0c;为了对用户提供正确的数据&#xff0c;我们需要保证这些放在不同物理机上的副本是一致的。为了…

Codeforces Round #246 (Div. 2) D. Prefixes and Suffixes kmp + dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 通过完美子串的定义&#xff0c;我们不难发现满足条件的子串就是kmpkmpkmp中ne[n]ne[n]ne[n]不断向前跳得到的串&#xff0c;现在问题就是如何求这些前缀串在串中出现的次数了。 考虑一个前…

译 | 宣布ML.NET 1.2 及模型生成器更新(用于 .NET 的机器学习)

原文&#xff1a;Cesar De la Torre翻译&#xff1a;Edi Wang我们很高兴地宣布ML.NET 1.2 和模型生成器和 CLI 的更新。ML.NET是 .NET 开发人员的开源和跨平台机器学习框架。ML.NET还包括模型生成器(Visual Studio 的简单 UI 工具)和ML.NET CLI(命令行界面),以便使用自动机器学…

Codeforces Round #590 (Div. 3) F. Yet Another Substring Reverse 子集dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 之前做过类似的题&#xff0c;翻转一个字串相当于将任意两个不相交的串连在一起。再一看字符集≤20\le20≤20&#xff0c;那就是铁子集dpdpdp了。 定义f[i]f[i]f[i]表示状态为iii的串的长度…

一个超轻量级工作流引擎:Workflow-Core

近期工作上有一个工作流的开发需求&#xff0c;自己基于面向对象和职责链模式捣鼓了一套小框架&#xff0c;后来在github上发现一个轻量级的工作流引擎轮子&#xff1a;Workflow-Core&#xff0c;看完其wiki之后决定放弃之前自己造的轮子&#xff0c;使用这个开源项目来改造&am…

Codeforces Round #590 (Div. 3) E. Special Permutations 差分 + 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 直接考虑比较难想&#xff0c;这种公式题基本都是将部分答案看成一个整体&#xff0c;考虑xi,xi1x_i,x_{i1}xi​,xi1​的贡献的。 假设当前的xix,xi1y,x<yx_ix,x_{i1}y,x<yxi​x,xi1…

ASP.NET Core 3.0中支持AI的生物识别安全

本文共两个部分&#xff0c;这是第一部分&#xff0c;其中介绍了 ASP.NET Core 3 中旨在将授权逻辑与基本的用户角色相分离的基于策略的授权模型。此部分提供了此授权进程的基于生物识别信息&#xff08;如人脸识别或语音识别&#xff09;的具体示例。在此示例中&#xff0c;检…

架构杂谈《五》

保证最终一致性的模式在大规模、高并发服务化系统中&#xff0c;一个功能被拆分成多个具有功能单一的子功能&#xff0c;一个流程会有多个系统的多个单一功能的服务组合实现&#xff0c;如果使用两阶段提交协议和三阶段提交协议&#xff0c;确实能解决系统间的一致性问题。其实…