1. 如何调试java进程
Java程序员必须知道的10个调试技巧
调试可以帮助识解决应用程序缺陷,在本文中,作者将使用大家常用的的开发工具Eclipse来调试Java应用程序。但这里介绍的调试方法基本都是通用的,也适用于NetBeans IDE,我们会把重点放在运行时上面。
在本文中使用的是Eclipse Juno版(Eclipse 4.2),在开始前给大家提3点建议!
不要使用System.out.println作为调试工具
把所有涉及到的组件日志级别激活并使用
使用日志分析器来读取日志
1.条件断点
如果你不知道如何添加断点,只需点击左边面板(行号前面)断点即被创建。在调试界面中,"断点"视图会把所有被创建的断点列出来。我们可以给它加一个布尔条件,也就是说,该断点会被激活并且如果布尔条件为真,就会执行该断点,否则将会跳过往下执行。
2.异常断点
在断点视图中,有一个J!标记按钮!我们可以使用该按钮来添加一个Java异常断点。例如,我们想让程序在遇到空指针异常(NullPointerException)时,仍然能继续调试,那么我们可以使用该按钮来添加一个异常断点!
3.监视点
这是一个非常好的功能,当选定的属性访问或修改程序时,程序会停止执行并允许进行调试。在Outline视图中选择一个类变量并从上下文菜单中选择切换监视点,属性监视点将会被创建,在断点(Breakpoints)视图中会把所有监视点用列表的形式显示出来。
4.评估/检查
按Ctrl+Shift+D或者Ctrl+Shift+I来显示选定变量或者表达式的值。我们也可以给一个变量或表达式添加永久观察点,当程序在调试时,这些观察点就会在表达式视图(Expression view)中显示出来。
5.修改变量值
在调试过程中,我们可以修改变量值。先选好一个变量然后进入变量视图(Variables view),根据变量类型在其对应的Value列里输入值即可。
6.在Main函数里面停止执行
在运行/调试设置中,编辑配置对话框中有"Main"这个选项卡,我们可以勾选"Stop in main"这个复选框。如果选中,那么在调试一个基于main方法的Java程序时,程序会在main方法第一行位置便停止执行。
7.环境变量
并不是在系统属性中添加环境变量,我们可以在编辑配置对话框中很方便地进行添加。
8.Drop to Frame
这也是我最喜欢的一个功能。调试期间,可以重新跳到调用堆栈框架的开始处执行,并且变量值也会回到最初。根据回档调整堆栈的深度,这个功能的主要用途是所有变量状态可以快速回到方法开始执行时候的样子,然后你可以重新进行一遍一遍执行,这样就可以在你关注的地方进行多次调试,但是在执行过程中也会产生一些副作用,比如插入到数据库里面的数据是无法删除的!
9.分布过滤
当我们进入(F5)方法的时候,我们还可以访问其外部库(比如java.*),我们可能不需要这个库,就可以在Perference选项卡页面添加一个过滤器来排除这个包。
10.进入、跳出和返回
我把这个放在最后一点,在调试过程中,这些是必须要了解(最好掌握)的东西:
F5——进入:移动到下一个步骤,如果当前行有一个方法调用,该控件将会跳转到被调用方法的第一行执行。
F6——跳出:移动到下一行。如果在当前行有方法调用,那么会直接移动到下一行执行。不会进入被调用方法体里面。
F7——返回:从当前方法中跳出,继续往下执行。
F8——移动到下一个断点处执行。
2. java心跳是怎么回事儿
1.什么是心跳包?
心跳包就是在客户端和服务器间定时通知对方自己状态的一个自己定义的命令字,按照一定的时间间隔发送,类似于心跳,所以叫做心跳包。
用来判断对方(设备,进程或其它网元)是否正常运行,采用定时发送简单的通讯包,如果在指定时间段内未收到对方响应,则判断对方已经离线。用于检测TCP的异常断开。基本原因是服务器端不能有效的判断客户端是否在线,也就是说,服务器无法区分客户端是长时间在空闲,还是已经掉线的情况。所谓的心跳包就是客户端定时发送简单的信息给服务器端告诉它我还在而已。代码就是每隔几分钟发送一个固定信息给服务端,服务端收到后回复一个固定信息如果服务端几分钟内没有收到客户端信息则视客户端断开。
比如有些通信软件长时间不使用,要想知道它的状态是在线还是离线就需要心跳包,定时发包收包。发包方:可以是客户也可以是服务端,看哪边实现方便合理,一般是客户端。服务器也可以定时发心跳下去。一般来说,出于效率的考虑,是由客户端主动向服务器端发包,而不是服务器向客户端发。客户端每隔一段时间发一个包,使用TCP的,用send发,使用UDP的,用sendto发,服务器收到后,就知道当前客户端还处于“活着”的状态,否则,如果隔一定时间未收到这样的包,则服务器认为客户端已经断开,进行相应的客户端断开逻辑处理。
3. java 如何实现长连接心跳检测机制
FTP的取文件过程,如果有异常,都可以捕捉到、并进行处理了
4. java服务端检测APP是否在线
socket,心跳包,互相发,服务端发送时链接超时就说明客户端下线。
5. java中Socket的心跳包设置问题
使用一个线程进行监控,如果空闲一定时间就发送一个心跳包。对于异步Socket可以一个线程监控多个连接。
6. java的自动发送心跳包究竟是该写在服务器还是客户端
socket.setKeepAlive()应该写在客户端,server.accept()是服务器端的。
心跳的也有现成的,不过依赖别的类。大概贴一下,就是这么个意思。
{
privateCommandDealcommand;
/**
*@returnthecommand
*/
publicCommandDealgetCommand(){
returncommand;
}
/**
*@paramcommand
*thecommandtoset
*/
publicvoidsetCommand(CommandDealcommand){
this.command=command;
}
publicvoidrun(){
longmaxWait=SendConfig.hbhb_wait;
if(maxWait<1000){
maxWait=1000;
}
DatelastTime;
longtimeDiv=0;
while(1==1){
lastTime=SocketQueueObject.getLastContactTime();
if(lastTime!=null){
timeDiv=(newDate()).getTime()-SocketQueueObject.getLastContactTime().getTime();
System.out.println("TimeDiv:"+timeDiv);
}
//上次联系的时间超过最大等待,或者还没联系过
if(lastTime==null||timeDiv>=maxWait){
System.out.println("HBHB");
command.sendHbhbCommand();
}elseif(maxWait>timeDiv){
maxWait=maxWait-timeDiv;
}
try{
this.sleep(maxWait);
}catch(Exceptione){
e.printStackTrace();
}
}
}
{
privatestaticLoggermsg_logger=Logger.getLogger("socketMsg");
@SuppressWarnings("unchecked")
publicListdoCommand(,Mapcommand)throwsException{
List<String>commandList=(List)command.get(Constants.SMSCOMMAND);
byte[]hbhbMsg=TL1Tool.createCommand(commandList.get(0));
msg_logger.info("sendmessagetosmspacked:"+newString(hbhbMsg,"ISO-8859-1"));
TL1RetrunMessageretMsg=socketQueueObject.commNGNServer(hbhbMsg);
retMsg.resolve();
msg_logger.info("recevicemessagefromsms:"+retMsg.getMessage());
ListreturnList=newArrayList();
returnList.add(retMsg);
returnreturnList;
}
}
你可以自己找找看啊。