草庐IT

python - 相当于python的-R选项影响ints的hash

coder 2023-08-14 原文

我们有大量 python 代码,它们接受一些输入并产生一些输出。

我们想保证,给定相同的输入,无论 python 版本或本地环境如何,我们都会产生相同的输出。 (例如,代码是在 Windows、Mac 还是 Linux 上以 32 位或 64 位运行)

我们一直在自动化测试套件中强制执行此操作,方法是在使用和不使用 python 的 -R 选项的情况下运行我们的程序并比较输出,假设这会抖动我们的输出意外出现的任何位置最终依赖于 dict 的迭代。 (我们代码中最常见的不确定性来源)

但是,当我们最近调整我们的代码以也支持 python 3 时,我们发现了一个地方,我们的输出部分取决于对使用 intdict 的迭代作为 key 。与 python2 相比,这个迭代顺序在 python3 中发生了变化,并且使我们的输出不同。我们现有的测试(全部在 python 2.7 上)没有注意到这一点。 (因为 -R 不影响 int 的散列)一旦找到,修复起来很容易,但我们希望早点找到它。

有没有什么方法可以进一步对我们的代码进行压力测试,并让我们相信我们已经找出了所有最终隐式依赖于不同 python 版本/环境可能不同的东西的地方?我认为像 -RPYTHONHASHSEED 这样的东西适用于数字以及 strbytesdatetime 对象可以工作,但我对其他方法持开放态度。但是,如果可能的话,我希望我们的自动化测试机器只需要安装一个 python 版本。

另一种可接受的替代方法是通过调整 pypy 来运行我们的代码,以便在从 dict 迭代项目时使用不同的顺序;我认为我们的代码在 pypy 上运行,尽管我们从未明确支持过它。但是,如果某个 pypy 专家为我们提供了一种在不同运行时调整字典迭代顺序的方法,我们将努力实现这一目标。

最佳答案

在这里使用 PyPy 不是最佳选择,因为它始终保留其字典中的插入顺序(使用一种方法使字典使用更少内存)。我们当然可以让它改变枚举命令的顺序,但它没有达到目的。

相反,我建议破解 CPython 源代码以更改散列在 dictobject.c 中的使用方式。例如,在每个 hash = PyObject_Hash(key); 之后if (hash == -1) { ..error.. }; 您可以添加 hash ^= HASH_TWEAK; 并使用不同的 HASH_TWEAK< 值编译不同版本的="">。 (我曾经做过这样的事情,但我找不到了。你需要注意哈希值是原始值还是修改后的值。)

关于python - 相当于python的-R选项影响ints的hash,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44324494/

有关python - 相当于python的-R选项影响ints的hash的更多相关文章

  1. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  2. ruby-on-rails - Rails 源代码 : initialize hash in a weird way? - 2

    在rails源中:https://github.com/rails/rails/blob/master/activesupport/lib/active_support/lazy_load_hooks.rb可以看到以下内容@load_hooks=Hash.new{|h,k|h[k]=[]}在IRB中,它只是初始化一个空哈希。和做有什么区别@load_hooks=Hash.new 最佳答案 查看rubydocumentationforHashnew→new_hashclicktotogglesourcenew(obj)→new_has

  3. ruby - 将数组的内容转换为 int - 2

    我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]

  4. ruby-on-rails - 如何从 format.xml 中删除 <hash></hash> - 2

    我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为

  5. ruby - Ruby 的 Hash 在比较键时使用哪种相等性测试? - 2

    我有一个围绕一些对象的包装类,我想将这些对象用作散列中的键。包装对象和解包装对象应映射到相同的键。一个简单的例子是这样的:classAattr_reader:xdefinitialize(inner)@inner=innerenddefx;@inner.x;enddef==(other)@inner.x==other.xendenda=A.new(o)#oisjustanyobjectthatallowso.xb=A.new(o)h={a=>5}ph[a]#5ph[b]#nil,shouldbe5ph[o]#nil,shouldbe5我试过==、===、eq?并散列所有无济于事。

  6. ruby - 默认情况下使选项为 false - 2

    这是在Ruby中设置默认值的常用方法:classQuietByDefaultdefinitialize(opts={})@verbose=opts[:verbose]endend这是一个容易落入的陷阱:classVerboseNoMatterWhatdefinitialize(opts={})@verbose=opts[:verbose]||trueendend正确的做法是:classVerboseByDefaultdefinitialize(opts={})@verbose=opts.include?(:verbose)?opts[:verbose]:trueendend编写Verb

  7. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  8. ruby-on-rails - 使用 config.threadsafe 时从 lib/加载模块/类的正确方法是什么!选项? - 2

    我一直致力于让我们的Rails2.3.8应用程序在JRuby下正确运行。一切正常,直到我启用config.threadsafe!以实现JRuby提供的并发性。这导致lib/中的模块和类不再自动加载。使用config.threadsafe!启用:$rubyscript/runner-eproduction'pSim::Sim200Provisioner'/Users/amchale/.rvm/gems/jruby-1.5.1@web-services/gems/activesupport-2.3.8/lib/active_support/dependencies.rb:105:in`co

  9. ruby-on-rails - 添加回形针新样式不影响旧上传的图像 - 2

    我有带有Logo图像的公司模型has_attached_file:logo我用他们的Logo创建了许多公司。现在,我需要添加新样式has_attached_file:logo,:styles=>{:small=>"30x15>",:medium=>"155x85>"}我是否应该重新上传所有旧数据以重新生成新样式?我不这么认为……或者有什么rake任务可以重新生成样式吗? 最佳答案 参见Thumbnail-Generation.如果rake任务不适合你,你应该能够在控制台中使用一个片段来调用重新处理!关于相关公司

  10. Python 相当于 Perl/Ruby ||= - 2

    这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Pythonconditionalassignmentoperator对于这样一个简单的问题表示歉意,但是谷歌搜索||=并不是很有帮助;)Python中是否有与Ruby和Perl中的||=语句等效的语句?例如:foo="hey"foo||="what"#assignfooifit'sundefined#fooisstill"hey"bar||="yeah"#baris"yeah"另外,类似这样的东西的通用术语是什么?条件分配是我的第一个猜测,但Wikipediapage跟我想的不太一样。

随机推荐