草庐IT

ios-class-guard

全部标签

java - 是否有 Checkstyle/PMD 规则 "Non-abstract classes should not be named AbstractXXX"?

我正在处理的Java项目结合使用了代码分析工具:PMD、Checkstyle和FindBugs。这些发现了大量错误、样式问题等,但经常有一个漏网之鱼:publicclassAbstractBadlyNamedClass{//Notabstract!//...}注意相反的方式被检查,即publicabstractBadlyNamedClass给出PMD警告“抽象类应命名为AbstractXXX”。任何人都可以建议是否有一种方法可以检查这一点,可以使用上述工具之一(可能是某种自定义规则?)或其他可以完成这项工作的自动化工具? 最佳答案

java - 用于 UNIX sys/classes/gpio 文件的 NIO watchservice

是否可以在/sys/class/gpio/gpioX设备树中的文件上设置JAVANIOWatchService以监督那里的变化?直接从Java中检测GPIO文件(即GPIO输入)的变化是个不错的主意,但我担心这不受支持。确认它不受支持(可能还有原因)就足够了。 最佳答案 Java7NIOFileWatcher的linux实现使用inotify。Inotify是一个linux内核子系统,用于通知文件系统更改。它有限制并且不适用于/proc、/sys和网络共享。请阅读inotifylimitationsonwiki:Inotifydoe

java - "implicit anonymous class parameter"在这种情况下是什么意思?

在AndroidStudio中,以下代码将变量commandBytes着色以指示“隐式匿名类参数”:publicbooleanwriteCommand(byte[]commandBytes){if(writeCommandInProgress.compareAndSet(false,true)){writeSubscription=bleDevice.establishConnection(asBleServiceRef,false).flatMap(rxBleConnection->rxBleConnection.writeCharacteristic(asInputCharId,c

Java 垃圾收集器 : top object classes promoted (by size)?

请告诉我在每次年轻GC事件之后确定提升到老年代的年轻代内存组成的最佳方法是什么?理想情况下,我想知道负责的类名,比如每个“年轻一代->老一代”提升block中80%的堆;例子:我有600M的younggen,每个tenure提升6M;我想知道这个6M是由哪些对象组成的。谢谢。 最佳答案 没有简单的方法可以做到这一点,但是,我最近一直在分析大型java应用程序的内存性能,并且可以分享一些经验。以下是我如何找到哪些对象被提升到老一代:首先,您需要确定“旧/永久”空间中有哪些对象。这基本上就是标准的Java堆分析。为此,我推荐jmap。它

java - Java 中的 "inner class emulation"是什么?

刚刚在阅读eclipseJDT的文档时发现了这一点:IMethodBinding.getParameterTypes():...Note:Theresultdoesnotincludesyntheticparametersintroducedbyinnerclassemulation.我在JLS中找不到任何对内部类仿真的引用...有人知道这个仿真是什么吗?举个例子,也会有所帮助。:) 最佳答案 我认为Eclipse文档编写者对术语的理解有点松散。就JLS而言,内部类就是内部类,不需要模拟。但是,内部类通过典型的JVM实现的方式有点棘

java - 从关闭文件方法抛出 IOException 时如何管理事务(包括文件 IO)

我最近开始使用Spring的数据源事务管理器。我现在有问题。我的事务包括对数据库表的更新和对文件的写操作。它工作正常,但我对文件I/O有一些疑问。正如您在下面看到的,我已经将我的bean的openFile和closeFile方法分别配置为init方法和destroy方法,这反过来又提供了这些方法,就像构造函数和析构函数一样被调用。如果文件没有正确关闭,一些记录可能没有成功写入output.txt文件,这意味着我也无法正确处理事务管理。但是,我想回滚那些尚未附加到平面文件的数据库更新。使用我的解决方案,似乎不可能将fileClose方法添加到事务中。有谁知道如何正确执行此所需操作?如有任

java - 不能直接调用父类(super class)型构造函数——为什么不呢?

我有以下Java示例类:publicclassA{}publicclassSuper{protectedSuper(){}publicSuper(Aa){}}publicclassSubextendsSuper{}publicclassConsumer{publicConsumer(){Subsub=newSub(newA());//compilererror}}编译器错误指出参数不能应用于Sub中的默认构造函数,这是完全可以理解的。我很好奇的是这个决定背后的理由。Java在Sub中生成默认的空构造函数;为什么在这种情况下不能在幕后调用它?这主要是理智的手持情况,还是有技术原因?编辑我

使用 findbugs 的 java 编译错误。 com.sun.tools.javac.code.Symbol$CompletionFailure : class file for javax. annotation.meta.When not found

我正在尝试使用findbugs1.3.2的注释。我在一个简单的测试中使用了edu.umd.cs.findbugs.annotations.NonNull注释,它工作正常。但是,现在我有一个大项目,由子模块组成,使用maven,我通过在某个java文件中导入该注释得到以下编译错误:com.sun.tools.javac.code.Symbol$CompletionFailure:classfileforjavax.annotation.meta.Whennotfound可能是什么问题?我尝试在所有子模块中添加findbugs依赖项。也许它与jsr305冲突?我看到我们的依赖项之一使用js

java - Java 中的 int.class 包含什么?为什么它甚至有效?

在Java中,像int.class这样的原语有一个类文字是有效的。在Java中引入autoboxing功能之前是否允许这样做?我们从int.class中得到的对象实际上包含什么?为什么有效? 最佳答案 int不是类,所以int.class没有意义。原因是他们很便宜,使用一个Class来表示所有类型。因此,例如,Method.getReturnType()返回一个Class,它实际上可以代表一个类、原始类型、数组,甚至是void。在泛型出现之前,这很好,因为没有太多种类的类型。在泛型之后,事情变得非常困惑,新的Type层次结构就更没有

java - xs :integer produces @XmlElement with "type=String.class" 上的 JAXB javaType 自定义

当使用XJC从XSD生成Javabean时,我需要映射xs:integer至Integer而不是BigInteger.我添加了一个javaType标记到我的JAXB自定义文件(如本网站的许多答案中所述),并且工作正常。但是在生成的代码中我注意到@XmlElement标签现在有一个type=String.class参数.所以现在我想知道,为什么String?是因为parse和print方法正在从/向字符串对象转换吗?我试过xjc:javaType而不是jaxb:javaType,允许我替换生成的Adapter1自定义MyAdapter,但发生了完全相同的事情。如果这是正常的XJC行为,是