PAIP.java程序调试的注意点及流程总结

本文总结了使用Java开发过程中进行程序调试时的几个关键点和流程,包括在IntelliJ IDEA中启动Tomcat调试、远程调试通过JPDA、设置Tomcat自动重新加载等,并详细解释了在修改类、web.xml、HIBERNATE.hbm.xml和SPRING配置文件时的自动编译和部署问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

PAIP.java程序调试的注意点及流程总结

以前虽然一直也在写JAVA程序,但是没怎么总结过,今天总结一下以备后用.

 ----作者Attilax , 1466519819@qq.com---
1.在IDE中启动TOMCAT的调试(不推荐)
----------------------------------------------
这种实际上是以SHAREMEMORY的方式来进行调试的.要面临一些部署CONTEXT的RELOAD的问题.


2.远程调试通过JPDA(推荐)
------------------------------
tomcat6w.exe>java> JAVA OPTIONGS> -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=8001

IDE中NB6.5 >DEBUG>ATTACH DEBUGGER>JPDA , HOST:yourhostname,port:xxx

3.设定TOMCAT自动RELOAD
---------------------------------------
这样在修改类后,通过IDE部署(默认是保存就自动编译并部署了 ),然后可以VM自动应用更改.
<Context path="/app" docBase="D:\NetBeansProjects\xx\build\web" reloadable="true"  debug="9">
<WatchedResource>WEB-INF/struts-config.xml</WatchedResource>
<WatchedResource>WEB-INF/web.xml</WatchedResource>
</Context>
但是,有时候并不能自动编译部署,需要注意
注意类修改后,上面会有一个鱼叉的图标(可以在代码视图TAB上看到,也可以PROJ文件列表展开时看到)。。表明修改了。。如果自动编译了,这个

鱼叉就消失了。。有时候需要手动编译(右键》编译,或者DEBUG状态下,点击图标三个绿方块,APPLY CODE CHANGE),如果同时修改了几

个类,只编译最高层的类就可以了,IDE会自动层级编译。。

3.web.xml以及WEB_INF下的XML更改问题
----------------------------------------------
当修改XML文件后,已经自动更新到编译目录了..但是TOMCAT的RELOAD的机制是不起作用的...需要手动RELOAD..进入TOMCAT的MANAGER,

手动RELOAD相对的APP,以重新读取WEB.XML配置

4.HIBERNATE.hbm.xml的更改问题
--------------------------------------
HBM.XML一般会放在CLASS目录下..一般会自动更改更新的...有时候不能自动更新,可以DEBUG状态下APPLY CODE CHANGE,或者项目

>BUILD.. 就可以了.. 它会自动RELOAD的.很少情况下,需要手动RELOAD..
如果是SPRING中集成HB配置文件,因为MS是一次性读取,好向是必须要手动RELOAD的才生效..

5.SPRING和STRUTS配置文件**.XML的问题
-------------------------------------------------
虽然 **.XML已经更新,但是 不生效的问题,这是由于SPRING,sTRUTS只读一次配置文件造成的,只能手动RELOAD..

 

03-12
### PAIP编程珠玑中的示例代码解释 PAIP(Paradigms of Artificial Intelligence Programming)是一本深入探讨人工智能编程范式的书籍,其中包含了大量 Lisp 编写的程序实例。这些例子不仅展示了如何实现特定的人工智能算法,还提供了关于良好软件工程实践的重要见解。 #### 示例:通用求解器框架 书中介绍了一个名为 `defun` 的宏来定义函数,在构建通用问题解决器时非常有用[^1]: ```lisp (defun solve (problem) "Find a solution to the given problem." (let ((solution nil)) ;; Attempt to find a solution using backtracking. (labels ((try-next-option () (when (not solution) (if (no-more-options-p ()) (return-from try-next-option nil) (let* ((option (next-option))) (cond ((goal-reached-p option) (setf solution option)) (t (push-state option) (solve problem) (pop-state)))))))) (try-next-option) solution))) ``` 这段代码实现了回溯法解决问题的一般模式。通过递归调用自身并尝试不同的选项直到找到解决方案为止。如果当前路径无法通向目标,则会恢复之前的状态继续探索其他可能性。 此方法能够有效地处理许多复杂的组合优化类问题,并且由于其灵活性可以很容易地适应各种具体应用场景下的需求变化。 #### 示例:自然语言理解模块 另一个重要的部分涉及到了自然语言处理技术的应用案例——基于语法分析树结构来进行语义解析: ```lisp (defun parse-sentence (sentence) "Parse SENTENCE into its constituent parts and build an interpretation tree." (multiple-value-bind (subject verb-object) (split sentence 'verb) `(sentence :subject ,(parse-noun-phrase subject) :action ,verb-object))) (defun parse-noun-phrase (np-string) "Interpret NP-STRING as either a simple noun or compound phrase." ...) ``` 上述片段演示了如何将输入字符串分割成主谓宾成分,并进一步解析名词短语的具体含义。这种层次化的表示方式有助于后续更高级别的推理操作以及对话管理等功能的设计与实现。 #### 示例:专家系统规则引擎 最后值得一提的是书中对于专家系统的讨论,特别是有关于事实库管理和匹配机制的部分: ```lisp (defstruct fact id pattern bindings) (defun match-patterns (pattern facts) "Return all FACTS that unify with PATTERN, along with their BINDINGS." ...) (defun add-fact (kb new-fact) "Add NEW-FACT to knowledge base KB after checking consistency against existing rules." ...) ``` 这里展示了一种简单而有效的知识表达形式及其相应的查询接口设计思路。通过对模式进行统一化计算从而快速定位符合条件的事实条目;而在更新数据库前则需确保新加入的信息不会引起逻辑矛盾等问题的发生。 以上仅是从《Programming Pearls》一书摘取的一些精彩片段,实际上该著作涵盖了更为广泛的内容领域和技术细节等待读者去发掘学习。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值