- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试递归地获取两个目录的差异并将它们注册为 github 问题。
如果目录有几个文件,scala.sys.process.Process 会按我预期的那样工作。
➜ Desktop ls -la
(snip)
drwxr-xr-x@ 5 garbagetown staff 170 Sep 19 22:53 2.1.5
drwxr-xr-x@ 5 garbagetown staff 170 Sep 19 11:26 2.2.0
(snip)
➜ Desktop ls -la 2.1.5/style
(snip)
-rw-r--r--@ 1 garbagetown staff 1206 Sep 19 22:53 book.css
-rw-r--r--@ 1 garbagetown staff 278 Sep 19 22:53 external.png
-rw-r--r--@ 1 garbagetown staff 175 Sep 19 22:53 header-pattern.png
-rw-r--r--@ 1 garbagetown staff 12985 Sep 19 22:53 main.css
➜ Desktop scala
Welcome to Scala version 2.10.3 (Java HotSpot(TM) 64-Bit Server VM, Java 1.7.0_21).
Type in expressions to have them evaluated.
Type :help for more information.
scala> import scala.sys.process.Process
import scala.sys.process.Process
scala> Process("diff 2.1.5/style 2.2.0/style").!!
res0: String = ""
但是目录有很多文件和目录,scala.sys.process.Process 抛出 RuntimeException,如下所示。
➜ Desktop ls -la 2.1.5/manual
(snip)
-rw-r--r--@ 1 garbagetown staff 9139 Sep 19 22:53 Highlights.md
-rw-r--r--@ 1 garbagetown staff 2737 Sep 19 22:53 Home.md
-rw-r--r--@ 1 garbagetown staff 8444 Sep 19 22:53 Migration.md
-rw-r--r--@ 1 garbagetown staff 15202 Sep 19 22:53 Modules.md
-rw-r--r--@ 1 garbagetown staff 670 Sep 19 22:53 User-Groups-around-the-World.md
-rw-r--r--@ 1 garbagetown staff 937 Sep 19 22:53 _Sidebar.md
drwxr-xr-x@ 3 garbagetown staff 102 Sep 19 22:53 about
drwxr-xr-x@ 7 garbagetown staff 238 Sep 19 22:53 book
drwxr-xr-x@ 8 garbagetown staff 272 Sep 19 22:53 detailledTopics
drwxr-xr-x@ 9 garbagetown staff 306 Sep 19 22:53 gettingStarted
drwxr-xr-x@ 9 garbagetown staff 306 Sep 19 22:53 hacking
drwxr-xr-x@ 6 garbagetown staff 204 Sep 19 22:53 javaGuide
drwxr-xr-x@ 16 garbagetown staff 544 Sep 19 22:53 sandbox
drwxr-xr-x@ 7 garbagetown staff 238 Sep 19 22:53 scalaGuide
➜ Desktop scala
Welcome to Scala version 2.10.3 (Java HotSpot(TM) 64-Bit Server VM, Java 1.7.0_21).
Type in expressions to have them evaluated.
Type :help for more information.
scala> import scala.sys.process.Process
import scala.sys.process.Process
scala> Process("diff 2.1.5/manual 2.2.0/manual").!!
java.lang.RuntimeException: Nonzero exit value: 1
at scala.sys.package$.error(package.scala:27)
at scala.sys.process.ProcessBuilderImpl$AbstractBuilder.slurp(ProcessBuilderImpl.scala:131)
at scala.sys.process.ProcessBuilderImpl$AbstractBuilder.$bang$bang(ProcessBuilderImpl.scala:101)
at .<init>(<console>:9)
at .<clinit>(<console>)
at .<init>(<console>:7)
at .<clinit>(<console>)
at $print(<console>)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:601)
at scala.tools.nsc.interpreter.IMain$ReadEvalPrint.call(IMain.scala:734)
at scala.tools.nsc.interpreter.IMain$Request.loadAndRun(IMain.scala:983)
at scala.tools.nsc.interpreter.IMain.loadAndRunReq$1(IMain.scala:573)
at scala.tools.nsc.interpreter.IMain.interpret(IMain.scala:604)
at scala.tools.nsc.interpreter.IMain.interpret(IMain.scala:568)
at scala.tools.nsc.interpreter.ILoop.reallyInterpret$1(ILoop.scala:756)
at scala.tools.nsc.interpreter.ILoop.interpretStartingWith(ILoop.scala:801)
at scala.tools.nsc.interpreter.ILoop.command(ILoop.scala:713)
at scala.tools.nsc.interpreter.ILoop.processLine$1(ILoop.scala:577)
at scala.tools.nsc.interpreter.ILoop.innerLoop$1(ILoop.scala:584)
at scala.tools.nsc.interpreter.ILoop.loop(ILoop.scala:587)
at scala.tools.nsc.interpreter.ILoop$$anonfun$process$1.apply$mcZ$sp(ILoop.scala:878)
at scala.tools.nsc.interpreter.ILoop$$anonfun$process$1.apply(ILoop.scala:833)
at scala.tools.nsc.interpreter.ILoop$$anonfun$process$1.apply(ILoop.scala:833)
at scala.tools.nsc.util.ScalaClassLoader$.savingContextLoader(ScalaClassLoader.scala:135)
at scala.tools.nsc.interpreter.ILoop.process(ILoop.scala:833)
at scala.tools.nsc.MainGenericRunner.runTarget$1(MainGenericRunner.scala:83)
at scala.tools.nsc.MainGenericRunner.process(MainGenericRunner.scala:96)
at scala.tools.nsc.MainGenericRunner$.main(MainGenericRunner.scala:105)
at scala.tools.nsc.MainGenericRunner.main(MainGenericRunner.scala)
我该如何解决这个问题?
最佳答案
diff
有一种稍微不同寻常的方式来传达退出状态。通常 POSIX utils 在成功时返回 0,在错误时返回非零。如果没有发现差异,Diff 返回 0,如果发现差异,则返回 1,等等。 Process
认为这是执行错误并抛出异常。因此,您需要解决该问题。
一种方法是改用此方法 ( doc ):
abstract def lines_!(log: ProcessLogger): Stream[String]
它不会抛出非零错误状态。
例如:
Process("diff 2.1.5/manual 2.2.0/manual").lines_!.foreach(println)
关于scala.sys.process.Process 抛出 RuntimeException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21831618/
我真的很难弄明白这一点。当我查看 logcat 指向错误的位置时,它指向这一行: throw new RuntimeException(i); 在里面 public void onDetach() {
@Transactional (noRollbackFor=RuntimeException.class) public void methodA (Entity e){ service.met
我正在开发简历应用程序并遇到以下异常 在gradle文件上,我尝试了所有可能的解决方案,使缓存重启无效,并且干净的gradle不起作用 java.lang.RuntimeException:java.
我的项目在 Android Studio 3.0.1 上的 Whatchap 中,这是我的设计 gradle。build.gradle(应用程序) 应用插件:'com.android.applicat
// Top-level build file where you can add configuration options common to all sub-projects/modules.
您好,目前我正在开发包括解析服务器的项目,并且在将解析库添加到我的项目后,当我运行它时,它显示此错误,任务“:app:checkDebugDuplicateClasses”执行失败。 Exec
我找到了 another post显示我们如何创建我们自己的检查异常,它也返回不同于 500 的 HTTP 状态代码。但是,我需要它是一个 RuntimeException。然后,我找到了WebApp
我尝试在 7.40 系统上演示具有动态方法名称的 CALL METHOD 语句。我使用下面的测试代码,在第 27 行得到一个 ABAP 运行时错误。异常描述中的错误分析状态 ... 在类 LCL 中,
我的ViewModel类抛出了RunTimeException。它基本上不能创建ViewModel类的实例。这是堆栈跟踪: 2019-05-29 01:27:56.700 9698-9698/com.
我安装了Hive 0.9.0,运行它时出现错误: ./hive Logging initialized using configuration in jar:file:/usr/lib/hive-0.
当我尝试在 android 4.1.1(galaxy nexus)上运行 opencv(2.4.2) sample3时。我收到RuntimeException。 Logcat指向此处:(android
Java中除了RuntimeException之外还有其他可能发生的异常吗?谢谢。 最佳答案 是的,有三种种。 检查异常 编译器会让您知道何时可以抛出它们,很可能是由于环境中的故障。 如果程序可以
这个问题已经有答案了: Why runtime exception is unchecked exception? (5 个回答) 已关闭 7 年前。 我知道受检查的异常继承自 Exception并且
这里发生了什么? 为什么 IOException (RemoteException) 的检查子级会转换为 RuntimeException? 摘自here的片段 import java.rmi.Rem
源代码(osmand)没有错误 我使用了 eclipse 和 sdk 模拟器 2.2,从 googlecode checkout (osmand应用程序) 我的代码: public void onCr
我开始研究线程,我不明白为什么下面的简单代码不起作用。它正在抛出: RuntimeException: can't create handler inside thread that has not
我想为自己破例。但是当我抛出异常时,程序就关闭了。那么我怎样才能运行我的方法3次然后关闭程序呢? (我的程序在intArray之后关闭,但我想遍历dobleArray和charArray) 这是我的异
我有一个扩展 HttpServlet 的类包含以下两个方法。当客户端向 Tomcat 服务器上运行的 Web 应用程序发出请求时,http 请求将通过此类处理,但是如果 doSomething 方法抛
在很多地方,我都会遇到几个检查异常,例如 IOException、ParseException、JSONException 等。我必须做出两个选择 - 通过在方法签名末尾添加 throws 来引发相同
RuntimeExceptions 应该指示编程错误,我希望我的应用程序在我的可观察对象中的某些东西抛出 RuntimeException 时崩溃。 最好的方法是什么?现在我正在考虑这个解决方案(它是
我是一名优秀的程序员,十分优秀!