页面跳转自动更新/广州seo关键字推广

页面跳转自动更新,广州seo关键字推广,网页课程设计心得体会,西宁网站制作费用是多少钱lambda 延迟执行总览 有关在Java和低延迟中使用Lambda的主要问题是: 他们会产生垃圾吗,您能做些什么吗? 背景 我正在开发一个支持不同有线协议的库。 这个想法是,您可以描述要写入/读取的数据,并且有线协议确定它是否…

lambda 延迟执行

总览

有关在Java和低延迟中使用Lambda的主要问题是: 他们会产生垃圾吗,您能做些什么吗?

背景

我正在开发一个支持不同有线协议的库。 这个想法是,您可以描述要写入/读取的数据,并且有线协议确定它是否使用带有JSon或YAML等字段的文本,带有FIX的字段编号的文本,带有BSON的字段名称的二进制或YAML的二进制形式,具有字段名称,字段编号或完全没有字段meta的二进制。 值可以是固定长度,变量长度和/或自描述数据类型。

其想法是它可以处理各种架构更改,或者如果您可以确定架构是相同的(例如,通过TCP会话),则可以跳过所有内容而仅发送数据。

另一个大想法是使用lambda支持这一点。

Lambdas有什么问题

主要问题是需要在低延迟应用程序中避免大量垃圾。 名义上,每次您看到lambda代码时,这都是一个新对象。

幸运的是,Java 8大大改进了Escape Analysis 。 Escape Analysis使JVM通过将新对象解包到堆栈中来替换它们,从而有效地为您分配了堆栈。 Java 7中提供了此功能,但是很少消除对象。 注意:当您使用探查器时,它往往会阻止Escape Analysis正常工作,因此您不能信任使用代码注入的探查器,因为探查器可能会说正在创建对象,而没有探查器则不会创建对象。 Flight Recorder似乎确实与Escape Analysis混为一谈。

Escape Analysis一直都有古怪之处,而且看来仍然如此。 例如,如果您具有IntConsumer或任何其他原始使用者,则可以在Java 8 update 20 – update 40中消除lambda的分配。但是,在没有发生这种情况的情况下,布尔值是一个例外。 希望在将来的版本中可以解决此问题。

另一个怪癖是发生对象消除的方法的大小(内联后)很重要,在相对适度的方法中,转义分析可以放弃。

具体情况

就我而言,我有一个读取方法,如下所示:

public void readMarshallable(Wire wire) throws StreamCorruptedException {wire.read(Fields.I).int32(this::i).read(Fields.J).int32(this::j).read(Fields.K).int32(this::k).read(Fields.L).int32(this::l).read(Fields.M).int32(this::m).read(Fields.N).int32(this::n).read(Fields.O).int32(this::o).read(Fields.P).int32(this::p).read(Fields.Q).int32(this::q).read(Fields.R).int32(this::r).read(Fields.S).int32(this::s).read(Fields.T).int32(this::t).read(Fields.U).int32(this::u).read(Fields.V).int32(this::v).read(Fields.W).int32(this::w).read(Fields.X).int32(this::x);
}

我正在使用lambda设置框架可以处理可选,缺失或乱序字段的字段。 在最佳情况下,可以按提供的顺序使用字段。 在模式更改的情况下,顺序可以不同或具有不同的字段集。 使用lambda可使框架以不同方式处理顺序字段和乱序字段。

使用此代码,我进行了测试,对对象进行了1000万次序列化和反序列化。 我将JVM配置为具有-Xmn14m -XX:SurvivorRatio=5的eden大小为10 MB的伊甸园空间-Xmn14m -XX:SurvivorRatio=5空间是比率为5:2的两个幸存者空间的5倍。 Eden空间是年轻一代总数的5/7,即10 MB。

通过具有10 MB的Eden大小和1000万次测试,我可以通过计算-verbose:gc打印的GC的数量来估计产生的垃圾。对于我得到的每个GC,每个测试平均要创建一个字节。 当我改变序列化和反序列化的字段数时,我在Intel i7-3970X上获得了以下结果。

Lambda相关垃圾

在此图表中,您可以看到,对于以相同方法反序列化的1到8个字段(即最多8个lambda),几乎不会创建垃圾,即最多只有一个GC。 但是,在9个或更多字段或lambda上,转义分析失败,并且您将创建垃圾,垃圾随文件数的增加而线性增加。

我不希望您相信8是一个神奇的数字。 尽管我找不到这样的命令行设置,但是它更可能是方法大小(以字节为单位)的限制。 当方法增长到170字节时,会发生差异。

有什么可以做的吗? 最简单的“修复”方法是将一种方法中的一半字段反序列化,将另一种字段中的一半字段反序列化,从而将代码分为两种方法(如果需要,可以将更多方法拆分),从而能够在不产生垃圾的情况下反序列化9到16个字段。 这是“ bytes(2)”和“ ns(2)”的结果。 通过消除垃圾,代码的平均运行速度也更快。

注意:使用14 x 32位整数对对象进行序列化和反序列化的时间不到100 ns。

其他说明:

当使用事件探查器YourKit(在这种情况下)时,由于Escape Analysis失败,没有产生垃圾的代码开始产生垃圾。

我打印了方法内联 ,发现某些关键方法中的assert语句阻止了它们的内联,因为这使方法变大了。 我通过在启用断言的情况下通过工厂方法创建断言的方式来创建by main类的子类来解决此问题。 默认类没有断言,也没有性能影响。

在我提出这些断言之前,我只能反序列化7个字段而不会触发垃圾回收。

当我用匿名内部类替换lambda时,我看到了类似的对象消除,尽管在大多数情况下,如果可以使用首选的lambda。

结论

Java 8在清除寿命很短的对象产生的垃圾方面似乎更聪明。 这意味着在低延迟应用程序中可以选择诸如传递lambda之类的技术。

编辑

尽管我不确定为什么,但我找到了在这种情况下有用的选项。

如果我使用选项-XX:InlineSmallCode=1000 (默认值)并将其更改为-XX:InlineSmallCode=5000则上面的“固定”示例将开始产生垃圾,但是如果将其减少为-XX:InlineSmallCode=500甚至是代码我最初给出的示例不产生垃圾。

翻译自: https://www.javacodegeeks.com/2015/01/java-lambdas-and-low-latency.html

lambda 延迟执行

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

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

相关文章

C语言“悬空指针”和“野指针”究竟是什么意思?

各位,提起C语言我们很自然就会想到指针二字,没错,作为C的核心和灵魂,它的地位咱们就不再赘述了,今天我们想跟大家讲的是指针中的两个特有名词:“悬空指针”和“野指针”。悬空指针C语言中的指针可以指向一块…

grad在python什么模块_深度学习(Deep Learning)基础概念1:神经网络基础介绍及一层神经网络的python实现...

此专栏文章随时更新编辑,如果你看到的文章还没写完,那么多半是作者正在更新或者上一次没有更新完,请耐心等待,正常的频率是每天更新一篇文章。 该文章是“深度学习(Deep Learning)”系列文章的第一部分&…

ubuntu终端命令停止_从命令行关闭Linux计算机的5种方法

没有操作系统是完美的。 即使相对稳定,驱动程序和应用程序也可能存在问题。 Linux也不例外。 尽管比Windows更稳定(在许多情况下,并非全部!),但可能还需要重新启动Linux计算机。 这可能是因为某些东西不起作用。 或者,您可能通过SSH连接到远程计算机或服务器,并希望它重新…

C语言编写简单朗读发音小工具!!

各位,今天给大家带来C语言结合VBS脚本写的一个简单的朗读小工具,做一个能够发音的C语言程序(保证简单,人人都能学会)。具备的知识体系:C语言基本框架C语言输入输出C语言文件操作C语言system函数VBS指令&…

未发现oracle(tm)客户端和网络组件_SpringColud Eureka的服务注册与发现

一、Eureka简介本文中所有代码都会上传到git上,请放心浏览 项目git地址:https://github.com/839022478/Spring-Cloud在传统应用中,组件之间的调用,通过有规范的约束的接口来实现,从而实现不同模块间良好的协作。但是被…

sap寄售退货单_多个退货单

sap寄售退货单我曾经听说过,过去人们一直在努力使方法具有单个出口点。 我知道这是一种过时的方法,从未认为它特别值得注意。 但是最近我与一些仍坚持该想法的开发人员联系(最后一次是在这里 ),这让我开始思考。 因此…

课堂经验值管理小程序_微信小程序怎么管理门店?

微信门店小程序是一种不用注册下载就能使用的购物平台,近年来很是流行,而且它操作简单,能让用户快速找到自己需要的产品,然后进行购买,深得用户喜爱,有用户的地方就会有商家,商家想拥有自己的微…

C语言 | 直接插入排序

解题思路:直接插入排序是一种最简单的排序方法,其基本操作是将一条记录插入到已排好的有序表中,从而得到一个新的、记录数量增1的有序表。C语言源代码演示:#include//头文件 int main()//主函数 {void insort(int post[],int n)…

mysql+after+commit_Spring事务aftercommit原理及实践

来道题CREATE TABLE goods (id bigint(20) NOT NULL AUTO_INCREMENT,good_id varchar(20) DEFAULT NULL,num int(11) DEFAULT NULL,PRIMARY KEY (id),KEY goods_good_id_index (good_id)) ENGINEInnoDB DEFAULT CHARSETutf8mb4 COLLATEutf8mb4_0900_ai_ciClass.forName("c…

序列化和反序列化的概念_序列化的概念

序列化和反序列化的概念讨论了为什么Optional不可序列化以及如何处理(即将推出)之后,让我们仔细看看序列化。 总览 这篇文章介绍了序列化的一些关键概念。 它尝试精简地执行此操作,而不会涉及太多细节,包括将建议降至…

C语言必学的12个排序算法:基数排序

# 基本思想基数排序(radix sort),同样时一种非比较的内部排序算法,主要基于多关键字排序的思想进行排序,它将单个关键字按照基数分成“多个关键字”进行排序。例如整数789是一个关键字,可以按照十进制位划分多关键字(十…

有没有code能改xml内容_Spring源码解析-applicationContext.xml加载和bean的注册

applicationContext文件加载和bean注册流程​ Spring对于从事Java开发的boy来说,再熟悉不过了,对于我们这个牛逼的框架的介绍就不在这里复述了,Spring这个大杂烩,怎么去使用怎么去配置,各种百度谷歌都能查到很多大牛教…

C语言数据类型转换

首先变量的数据类型是可以转换的。转换的方法有两种,一种是自动转换,另一种是强制转换。自动转换即当不同类型的数据进行混合运算时,编译系统将按照一定的规则自动完成。而强制类型转换是由程序员通过编程强制转换数据的类型。自动转换的规则…

java 类持久化_Java 持久化之 -- IO 全面整理(看了绝不后悔)

目录:一、java io 概述什么是IO?IO包括输入流和输出流,输入流指的是将数据以字符或者字节形式读取到内存 分为字符输入流和字符输入流输入流指的是从内存读取到外界 ,分为字符输入流和字节输出流Java IO即Java 输入输出系统。不管…

idea 找不到或无法加载主类_解决IDEA中Groovy项目no Groovy library is defined的问题

实验环境IDEA2019.1.2Groovy-2.5.8错误重现新建了一个Groovy工程,指定了groovy版本,如图新建了一个简单的Groovy Class,运行,出现如下错误错误的尝试(以下是试错过程,并不能解决问题,读者可以不要跟着操作&…

C语言标识符、关键字和注释

这一节主要讲解C语言中的几个基本概念。标识符定义变量时,我们使用了诸如“a”“abc”“mn123”这样的名字,它们都是程序员自己起的,一般能够表达出变量的作用,这叫做标识符(Identifier)。标识符就是程序员…

java 类.class_面试官:Java反射是什么?我回答不上来!

一.概念反射就是把Java的各种成分映射成相应的Java类。Class类的构造方法是private,由JVM创建。反射是java语言的一个特性,它允程序在运行时(注意不是编译的时候)来进行自我检查并且对内部的成员进行操作。例如它允许一个java的类获取他所有的成员变量和…

巧解C语言运算符的优先级和结合性

本篇文章我们从一个例子入手讲解,请看下面的代码:#include int main(){ int a 16, b 4, c 2; int d a b * c; int e a / b * c; printf( "d%d, e%d\n", d, e); return 0; }运行结果:d24, e81) 对于表达式a b * c&#xff0…

jms mdb_MDB!= JMS,反之亦然

jms mdb基本 消息驱动Bean(又称为MDB)只是另一个EJB,例如无状态,有状态或单例。 使用MessageDriven批注指定。 MDB用于异步消息处理 它们与无状态EJB 相似 ,因为它们都是由EJB容器池化的 但是,它们与无状…

C语言中的三目运算符是啥?有何用处?

一般来说,C语言中的三目运算符为a?b:c即有三个参与运算的量。由条件运算符组成条件表达式的一般形式为:表达式1? 表达式2:表达式3求值规则为:如果表达式1的值为真,则以表达式2 的值作为条件表达式的值,否…