我刚刚注意到一个 question询问递归数据类型(“自引用类型”)在 C++ 中有什么好处,我很想大胆地断言
It's the only way to construct data structures (more precisely containers) that can accept arbitrary large data collections without using continuous memory areas.
也就是说,如果您没有随机访问数组,您将需要某种方式(逻辑上)引用该类型中的一个类型(显然,您不必使用 MyClass* next 成员可以说 void* next 但它仍然指向 MyClass 对象或派生类型)。
但是,我对绝对陈述很谨慎——只是因为我想不出某事并不意味着它不可能,所以我是否忽略了什么?是否存在既不使用类似于链表/树的机制组织的数据结构,也不仅使用连续序列?
注意:这两个标记为 c++和 language-agnostic因为我对 C++ 语言特别感兴趣,而且对理论方面也很感兴趣。
最佳答案
It's the only way to construct data structures (more precisely containers) that can accept arbitrary large data collections without using continuous memory areas.
想了想,这个说法似乎是正确的。事实上,这是不言而喻的。
假设我在非连续 内存中有一个元素集合。还假设我当前位于元素 e。现在的问题是,我如何知道集合中的下一个 元素?有什么办法吗?
给定集合中的元素e,只有两种方法可以计算下一个元素的位置:
如果我假设它位于偏移量 sizeof(e) 而不管 e 是什么,那么这意味着下一个元素从当前元素开始结束。但这意味着该集合位于连续内存中,这在本次讨论中是被禁止的。
元素 e 本身告诉我们下一个元素的位置。它可以存储地址本身或偏移量。无论哪种方式,它都在使用自引用的概念,这在本次讨论中也是被禁止的。
在我看来,这两种方法的基本思想完全相同:它们都实现了自引用。唯一的区别是,在前者中,自引用是隐式实现的,使用 sizeof(e) 作为 offset。这种隐式自引用由语言本身支持,并由编译器实现。在后者中,它是显式的,一切都由程序员自己完成,因为现在 offset(或指针)存储在元素本身中。
因此,我看不到任何第三种方法来实现自引用。如果不是自引用,那么人们会使用什么术语来描述计算元素 e 的下一个元素的位置。
所以我的结论是,你的说法是绝对正确的。
关于c++ - 递归类型真的是构建非连续任意大小数据结构的唯一方法吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12113444/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
我正在尝试设置一个puppet节点,但rubygems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由rubygems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby
我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco
我主要使用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
我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer
设置:狂欢ruby1.9.2高线(1.6.13)描述:我已经相当习惯在其他一些项目中使用highline,但已经有几个月没有使用它了。现在,在Ruby1.9.2上全新安装时,它似乎不允许在同一行回答提示。所以以前我会看到类似的东西:require"highline/import"ask"Whatisyourfavoritecolor?"并得到:Whatisyourfavoritecolor?|现在我看到类似的东西:Whatisyourfavoritecolor?|竖线(|)符号是我的终端光标。知道为什么会发生这种变化吗? 最佳答案
我的瘦服务器配置了nginx,我的ROR应用程序正在它们上运行。在我发布代码更新时运行thinrestart会给我的应用程序带来一些停机时间。我试图弄清楚如何优雅地重启正在运行的Thin实例,但找不到好的解决方案。有没有人能做到这一点? 最佳答案 #Restartjustthethinserverdescribedbythatconfigsudothin-C/etc/thin/mysite.ymlrestartNginx将继续运行并代理请求。如果您将Nginx设置为使用多个上游服务器,例如server{listen80;server