草庐IT

out_canopy

全部标签

java - 如何从代码库中删除 System.out.println

我们有一个巨大的(旧的遗留java)代码库,其中许多文件(大约5k)都有System.out.println。出于清理/性能原因,我们计划删除它们。我们如何编写一个脚本来替换它们而不在代码中引入任何问题?脚本不能盲目删除它们,因为以下情况可能会成为问题:if()some.code...elseSystem.out.println(...);DB.close();我正在考虑将它们替换为“;”。这将处理上述情况。你看到任何其他问题吗?还有其他建议吗? 最佳答案 你有没有考虑过这个愚蠢的案例:System.out.println("Pri

Java:System.out.println() 这么慢的原因是什么?

对于可以在文本编辑器中完成的小型逻辑程序,为了跟踪,我使用经典的System.out.println()。我想你们都知道在大量迭代中使用它是多么令人沮丧。为什么这么慢?背后的原因是什么? 最佳答案 这与JVM无关。将文本打印到屏幕只涉及操作系统在绘制字母,尤其是滚动方面的大量工作。如果将System.out重定向到文件,速度会快得多。 关于Java:System.out.println()这么慢的原因是什么?,我们在StackOverflow上找到一个类似的问题:

java - HSQLDB SQL异常 : Out of memory establishing database connection

我们有一个带有本地HSQLDB数据库的桌面应用程序。一些客户报告他们的应用程序停止工作。当我尝试使用DbVisualizer打开它时,我可以在调试控制台上看到:12:45:32[DEBUGpool-2-thread-1D.?]RootConnection:jdbcDriver.connect("jdbc:hsqldb:C:\test\database.db",{user=**,password=})java.sql.SQLException:errorinscriptfileline:56outofmemoryatorg.hsqldb.jdbc.Util.sqlException(Un

java - Apache Http 客户端打印 "[read] I/O error: Read timed out""

我正在使用apachehttp客户端v4.5并将其用作REST客户端。在某些情况下,我发现一个错误“[读取]I/O错误:读取超时”,它来自httpclient框架,当它读取接收到的内容并将其显示为最后一条消息时。它似乎没有影响,但是我想知道是否有人知道它来自哪里以及如何解决它。根据以下线程(link),这似乎是“多线程”配置的问题。但是我只使用http客户端的默认配置,当我使用版本v4时,我不知道如何将“多线程”设置为false以查看它是否有任何区别。我也尝试设置超时,但没有帮助。有什么提示吗?日志:15:48:05.984[main]DEBUGorg.apache.http.wire

java - 什么可能导致套接字 ConnectException : Connection timed out?

我们有一个Webstart客户端,它使用java.net.HttpsURLConnection通过HTTPS发送序列化对象来与服务器通信。在我的本地机器和我们办公室的测试服务器上,一切都运行良好,但我遇到了一个非常非常奇怪的问题,它只发生在我们的生产和暂存服务器上(而且偶尔会出现)。我知道这些服务器与我们办公室的服务器之间的主要区别是它们位于其他地方,与它们的客户端-服务器通信速度相当慢,但在此之前的很长一段时间内,它在生产中也运行良好。无论如何,这是正在发生的事情:客户端在HttpURLConnection上设置读取超时等选项和Content-Type等属性后,调用getOutput

java - 将 System.out.println 重定向到日志

在我的项目测试套件中有大量使用System.out.println我正在尝试将这些输出重定向到日志文件(通过配置或从单点而不重构整个项目),以便在必要时可以禁用以提高性能。我正在使用log4j进行日志记录。有谁知道这可能吗?如果是这样怎么办?提前致谢。 最佳答案 鉴于最好替换System.out.println(),有时我们别无选择。无论如何,我已经为此做了一些实用程序:SystemOutToSlf4j.enableForClass(MyClass.class)然后所有源自MyClass的println将被重定向到记录器。Seeth

java - 使用 JGit 从 Git 存储库中 check out 特定修订

我正在尝试使用jGit克隆存储库并checkout特定提交。假设提交哈希是:1e9ae842ca94f326215358917c620ac407323c81。我的第一步是://CloningtherepositoryGit.cloneRepository().setURI(remotePath).setDirectory(localPath).call();然后我发现了另一个建议这种方法的问题:git.checkout().setCreateBranch(true).setName("branchName").setUpstreamMode(CreateBranchCommand.Se

解决ssh: connect to host github.com port 22: Connection timed out

当连接GitHub时无法连接到22端口时,可以尝试将端口更换为443首先,尝试使用以下命令从GitHub克隆仓库:$gitclonegit@github.com:xxxxx/xxxx.gitmy-awesome-proj如果出现以下错误信息:Cloninginto'my-awesome-proj'...ssh:connecttohostgithub.comport22:Connectiontimedoutfatal:Couldnotreadfromremoterepository.这说明不能通过22端口连接到GitHub。2.接下来,尝试使用以下命令测试SSH连接:$ssh-Tgit@gith

signature hdr data: BAD, no. of btyes(9088) out of range 问题排查与解决方案

在使用yum工具安装gcc的时候,报出了signaturehdrdata:BAD,no.ofbtyes(9088)outofrange的问题这是由于centos8中rpm工具存在的一个bug,在校验安装包头部大小的时候,应当限制为64M,但是实际限制了64k这个问题存在于rpm-4.14.3-4.el8.x86_64等版本查看你本机的rpm版本可以使用命令rpm-qrpm解决方案是手动安装更高版本的rpmdnfinstallrpm-4.14.3-26.el8.x86_64再使用这个安装命令的时候,推荐的依赖工具中包含了tpm2-tss-2.3.2-6.el8.x86_64.rpm但是这个包的头

爬虫你还在用selenium吗,out了!

最近遇到了一件事情:我的chrome浏览器升级了,但是对应的webdriver还没有升级,我只能被迫的接受使用safari浏览器实现爬虫。虽然是mac自带的浏览器,但是我chrome浏览器用惯了,改不过来习惯了。但是最近发新闻还是被迫的使用safari浏览器作为浏览器。我也一直在从slenium作为爬虫的框架,它主要webdriver,这样就有了诸多的问题:配置比较麻烦,对于新手可能不是很友好版本必须和浏览器的版本匹配。我之前的一段时间就是因为chrome升级了,但是driver没升级导致无法使用脚本操作服务器selenium新版本的api和老版本的出入较大。之前在解决问题时,发现很多旧文档中