当我在类中使用字段注入(inject)时,像这样:
@Inject
private MyClass myField;
我可以对这个字段的“safe publication”状态做任何假设吗?或者换句话说,假设 MyClass 本身是线程安全的,那么在使用该字段时是否应该注意任何并发风险?
我的本能通常是尽可能创建所有字段 final,但这不适用于字段注入(inject)。当然,我可以使用构造函数注入(inject),但我通常最终不得不创建一个额外的“假”无参数构造函数来进行代理。问题不大,但使用字段注入(inject)更方便。另一种选择可能是将该字段标记为易变的(或者甚至对其使用锁...),但这真的有必要吗?
JSR-299 规范似乎没有回答这个问题。我在像 Weld 这样的实现上使用 CDI。
最佳答案
也许这种情况下的线程安全已被故意排除在规范之外,这意味着无法保证线程安全。
让我们想一想:如果一个线程写入的字段被另一个线程读取,除非存在某种形式的先行关系,否则另一个线程可能读取陈旧数据。 Guice 最终要么使用反射来设置 myField 的值,要么使用自动生成的 setter 。没有 happens-before 关系,因此反射写入 happens-before 字段读取或方法调用 happens-before 字段读取(除非使用锁、volatiles 或其他方式形成 happens-before 关系)。
因此,我会说看到空值的可能性(可能相当低)。
编辑:根据 http://bit.ly/1m4AUIz在构造函数结束后写入最终字段(通过反射)与在构造函数中初始化字段具有相同的语义。因此,使 Guice 注入(inject)的字段成为最终字段,将它们设置为 null,它应该可以正常工作。这确实是一个非常黑暗的 JVM 角落 :-) 此外,根据 http://bit.ly/1m4AwJU Guice 仅在一个线程中执行注入(inject),这使其成为线程安全的……在我看来,在性能方面似乎很奇怪,但显然它是这样工作的。
关于java - 注入(inject) (@Inject) 字段是否已安全发布?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13864443/
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
我有一个表单,其中有很多字段取自数组(而不是模型或对象)。我如何验证这些字段的存在?solve_problem_pathdo|f|%>... 最佳答案 创建一个简单的类来包装请求参数并使用ActiveModel::Validations。#definedsomewhere,atthesimplest:require'ostruct'classSolvetrue#youcouldevencheckthesolutionwithavalidatorvalidatedoerrors.add(:base,"WRONG!!!")unlesss
我想向我的Controller传递一个参数,它是一个简单的复选框,但我不知道如何在模型的form_for中引入它,这是我的观点:{:id=>'go_finance'}do|f|%>Transferirde:para:Entrada:"input",:placeholder=>"Quantofoiganho?"%>Saída:"output",:placeholder=>"Quantofoigasto?"%>Nota:我想做一个额外的复选框,但我该怎么做,模型中没有一个对象,而是一个要检查的对象,以便在Controller中创建一个ifelse,如果没有检查,请帮助我,非常感谢,谢谢
这个问题在这里已经有了答案:Checktoseeifanarrayisalreadysorted?(8个答案)关闭9年前。我只是想知道是否有办法检查数组是否在增加?这是我的解决方案,但我正在寻找更漂亮的方法:n=-1@arr.flatten.each{|e|returnfalseife
我正在编写一个小脚本来定位aws存储桶中的特定文件,并创建一个临时验证的url以发送给同事。(理想情况下,这将创建类似于在控制台上右键单击存储桶中的文件并复制链接地址的结果)。我研究过回形针,它似乎不符合这个标准,但我可能只是不知道它的全部功能。我尝试了以下方法:defauthenticated_url(file_name,bucket)AWS::S3::S3Object.url_for(file_name,bucket,:secure=>true,:expires=>20*60)end产生这种类型的结果:...-1.amazonaws.com/file_path/file.zip.A
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
我知道我可以指定某些字段来使用pluck查询数据库。ids=Item.where('due_at但是我想知道,是否有一种方法可以指定我想避免从数据库查询的某些字段。某种反拔?posts=Post.where(published:true).do_not_lookup(:enormous_field) 最佳答案 Model#attribute_names应该返回列/属性数组。您可以排除其中一些并传递给pluck或select方法。像这样:posts=Post.where(published:true).select(Post.attr
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查
我的日期格式如下:"%d-%m-%Y"(例如,今天的日期为07-09-2015),我想看看是不是在过去的七天内。谁能推荐一种方法? 最佳答案 你可以这样做:require"date"Date.today-7 关于ruby-检查日期是否在过去7天内,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/32438063/