对于超快的代码,我们必须保持引用的位置 - 将尽可能多的紧密使用的数据保存在 CPU 缓存中:
http://en.wikipedia.org/wiki/Locality_of_reference
实现这一目标的技术是什么?有没有人能举个例子?
我对 Java 和 C/C++ 示例感兴趣。很想知道人们用来停止大量缓存交换的方法。
问候
最佳答案
这可能太笼统了,没有明确的答案。与 Java 相比,C 或 C++ 中的方法会有很大差异(语言布局对象的方式不同)。
基本原则是,将要在闭环中访问的数据放在一起。如果您的循环在类型 T 上运行,并且它具有成员 m1...mN,但在关键路径中仅使用 m1...m4,请考虑将 T 分解为包含 m1...m4 的 T1 和包含 m4 的 T2。 ..mN.您可能想向 T1 添加一个指向 T2 的指针。尽量避免与缓存边界未对齐的对象(非常依赖于平台)。
使用连续的容器(C 中的普通旧数组,C++ 中的 vector )并尝试管理迭代向上或向下,但不要随机跳遍整个容器。链表是局部性的 killer ,列表中的两个连续节点可能位于完全不同的随机位置。
Java 中的对象容器(和泛型)也是一个 killer ,而在 Vector 中引用是连续的,实际对象不是(有额外的间接级别)。在 Java 中有很多额外的变量(如果你一个接一个地 new 两个对象,这些对象可能最终会位于几乎连续的内存位置,即使会有一些额外的信息(通常是两个或三个指针)之间的对象管理数据。GC 会四处移动对象,但希望不会使事情比运行前更糟。
如果你专注于 Java,创建紧凑的数据结构,如果你有一个有位置的对象,并且要在一个紧密的循环中访问,考虑持有一个 x 和 y 基元类型在您的对象中,而不是创建一个 Point 并持有对它的引用。需要更新引用类型,这意味着不同的分配、额外的间接性和更少的局部性。
关于java - 将数据保存在缓存、位置的技术?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9821720/
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳
我试过重新启动apache,缓存的页面仍然出现,所以一定有一个文件夹在某个地方。我没有“公共(public)/缓存”,那么我还应该查看哪些其他地方?是否有一个URL标志也可以触发此效果? 最佳答案 您需要触摸一个文件才能清除phusion,例如:touch/webapps/mycook/tmp/restart.txt参见docs 关于ruby-如何在Ubuntu中清除RubyPhusionPassenger的缓存?,我们在StackOverflow上找到一个类似的问题:
尝试在我的RoR应用程序中实现计数器缓存列时出现错误Unknownkey(s):counter_cache。我在这个问题中实现了模型关联:Modelassociationquestion这是我的迁移:classAddVideoVotesCountToVideos0Video.reset_column_informationVideo.find(:all).eachdo|p|p.update_attributes:videos_votes_count,p.video_votes.lengthendenddefself.downremove_column:videos,:video_vot
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
我的模型有defself.empty_building//stuffend我怎样才能对这个现有的进行rspec?,已经尝试过:describe"empty_building"dosubject{Building.new}it{shouldrespond_to:empty_building}endbutgetting:Failure/Error:it{shouldrespond_to:empty_building}expected#torespondto:empty_building 最佳答案 你有一个类方法self.empty_bu
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
我正在尝试使用Curbgem执行以下POST以解析云curl-XPOST\-H"X-Parse-Application-Id:PARSE_APP_ID"\-H"X-Parse-REST-API-Key:PARSE_API_KEY"\-H"Content-Type:image/jpeg"\--data-binary'@myPicture.jpg'\https://api.parse.com/1/files/pic.jpg用这个:curl=Curl::Easy.new("https://api.parse.com/1/files/lion.jpg")curl.multipart_form_