草庐IT

硬件同步

全部标签

使用 HashMap 实现多线程的 Java 单例同步

我有以下类(class):publicclassAggregationController{privateHashMap>messages;privateHashMapcounters;BooleanbuildAggregateReply;privatebooleanisAggregationStarted;privatestaticHashMapinstances=newHashMap();privateAggregationController()throwsMbException{messages=newHashMap>();counters=newHashMap();build

java - 静态方法上的同步有什么作用?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:HowdosynchronizedstaticmethodsworkinJava?我想知道如果在静态方法上使用synchronized会发生什么。该类是否锁定了该方法?这与非静态方法上的同步有何不同?谢谢

java - 如何在不使用 this 的情况下在接口(interface)默认方法内进行同步?

我在需要同步的接口(interface)中有许多默认方法,似乎只有this可用:defaultvoidaddUniqueColumns(Listnames){synchronized(this){...dosomething}}问题是,我想在私有(private)锁上同步而不是this以便更好地控制:defaultvoidaddUniqueColumns(Listnames){synchronized(lock){//howtogetaprivatelockinadefaultmethod??...dosomething}}解决方案?聪明的解决方法?或者只是忍受它:)!

java - 保持 i18n 资源同步

我正在寻找i18n属性文件的编辑器/比较器,以帮助我保持不同语言文件的同步。基本上,它会比较一堆属性文件并显示哪些键在特定语言中不存在。属性看起来像component.titlepage.title=helloworld简单的差异是不可能的,因为右侧将因语言而异。我们目前的基础设施:Java应用程序使用maven2构建系统不同组件的不同i18n属性文件。(每个组件每种语言1个属性文件) 最佳答案 Checkstyle工具,我通常将其作为每次checkin主分支后完成的每个持续集成构建的一部分运行,它会告诉您任何给定的属性文件集是否具

java - 哪个硬件因素对快速代码编译很重要

我必须经常编译java代码,尤其是像GWT这样需要很长时间才能完成的东西。我无法避免这种开销,但我想用更好的硬件将它降到最低。哪个因素会使这些编译尽可能快?(我知道这有点主观,但在编译时,我确信某些因素比其他因素更重要)。例如,我认为在编译时,以3.6GHz/Core运行的双核可能比以2.8Ghz/Core运行的四核更快(尤其是当java代码/GWT代码编译当前是单线程时).那么,针对这个具体问题,在购买硬件时应该考虑哪些因素呢?编辑:说这些编译我觉得很笼统,没有提到我的具体情况。我正在处理GWT和Scala编译,这太慢了,尽管我在编译期间没有观察到硬盘负载过高。我应该使用4+核2.4

java - Java中方法、对象、类的同步

关于在多线程环境中使用同步,我需要一些说明。我在下面有一个小例子Class。但我实际上发现很难对以下内容的工作方式进行测试;我想要测试用例的原因是为了了解同步如何处理这些不同的场景如果一个线程调用SharedResource.staticMethod,它将获得类的锁。这是否意味着SharedResource的instance,比如x,必须等到它获得lock才能执行x.staticMethod.将block中的this同步,获取该部分代码或整个的锁对象。即另一个thread可以在同一个object上调用同一个method吗?但执行不属于同步块(synchronizedblock)的其余代

java - Spring MVC 中的同步方法

我正在尝试在springController中使用同步方法。因为我们的支付网关一次点击方法[@RequestMapping(value="/pay",method=RequestMethod.POST)]不同的交易[txnid:txn01&txn02]。但是由于使用同步块(synchronizedblock),这2个不同的事务处理一个一个地处理而不是并行。问题->为什么我在Controller中使用同步块(synchronizedblock)是说事务[txn01]命中[@RequestMapping(value="/pay",method=RequestMethod.POST)]两次,

java - 什么是Java中的同步上下文

你们都知道Java中的同步上下文可以是实例。在某个加载类的java.lang.Class实例上。在给定的对象上我需要问;当我写Dimensiond=newDimension();synchronized(d){//criticalatomicoperation}给定对象的同步实际上等于实例上的同步。所以当我编写synchronized(d)时,其中d是对象的一个​​实例,然后线程将获得所有同步实例代码块的锁。能否请您提供有关同步上下文的更多详细信息。我们将不胜感激。 最佳答案 synchronized关键字提供对其引入的代码块(可能

java - 同步块(synchronized block)是否有最大可重入限制?

众所周知,ReentrantLock有最大重入限制:Integer.MAX_VALUE;是否synchronized块也有可重入限制吗?更新:我发现很难为同步重入编写测试代码:publicclassSyncReentry{publicstaticvoidmain(String[]args){synchronized(SyncReentry.class){synchronized(SyncReentry.class){//...writesynchronizedblockforever}}}}任何人都可以帮助编写一些用于同步重入限制测试的代码吗? 最佳答案

java - 使用依赖于硬件的 VM 参数(重新)启动 Java 应用程序的正确方法?

编辑我不想使用JavaWebStart我有一个Java应用程序,我想使用不同的VM参数运行它,具体取决于启动它的系统所具有的内存量。例如,如果机器有1GB或更少的内存,如果它有2GB,我想传递“-Xmx200m”和“-Xmx400m”,如果它有8GB,我想传递“-Xmx800m”(这些只是示例).有没有可移植的方法来做到这一点?我试过第一个微型Java应用程序(因此可移植)确定可用内存量,然后启动一个新的Java应用程序,但我认为这不是很干净。截至目前,我已经编写了Bashshell脚本,这些脚本根据配置使用正确的参数调用Java应用程序,但它仅适用于OSX上的Linux。解决这个问题