- 浏览: 1846095 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (665)
- 闲话 (17)
- ruby (1)
- javascript (40)
- linux (7)
- android (22)
- 开发过程 (11)
- 哥也读读源代码 (13)
- JVM (1)
- ant (2)
- Hibernate (3)
- jboss (3)
- web service (17)
- https (4)
- java基础 (17)
- spring (7)
- servlet (3)
- 杂记 (39)
- struts2 (10)
- logback (4)
- 多线程 (2)
- 系统诊断 (9)
- UI (4)
- json (2)
- Java EE (7)
- eclipse相关 (4)
- JMS (1)
- maven (19)
- 版本管理 (7)
- sso (1)
- ci (1)
- 设计 (18)
- 戒烟 (4)
- http (9)
- 计划 (4)
- HTML5 (3)
- chrome extensions (5)
- tomcat源码阅读 (4)
- httpd (5)
- MongoDB (3)
- node (2)
最新评论
-
levin_china:
勾选了,还是找不到
用spring annotation声明的bean,当打包在jar中时,无法被扫描到 -
GGGGeek:
我用的maven-3.5.0,还没有遇到这种情况,使用jar ...
用spring annotation声明的bean,当打包在jar中时,无法被扫描到 -
GGGGeek:
受益匪浅,从组织项目结构,到技术细节,讲的很到位,只是博主不再 ...
一个多maven项目聚合的实例 -
Aaron-Joe-William:
<?xml version="1.0" ...
hibernate逆向工程 -
li272355201:
http://archive.apache.org/dist/ ...
tomcat源码阅读(一)——环境搭建
1、有一个方法,有一段类似于下面这样:
结果运行过程中,发现有时候会报数据库已经锁定的异常。最后才定位到上面这段代码。原因是在上面的run()方法中打开了数据库,这个时候会自动锁定Database,如果在关闭数据库之前,另外一个线程B也进行数据库操作,就会报这个异常。如果数据库已经关闭之后,另外一个线程B请求数据库操作,就没有问题。
所以在新线程中进行数据库操作,或者是TimerTask中进行数据库操作的时候,要注意考虑并发的问题,也许就会有数据库锁定的异常。
2、另外一段代码,将TimerTask的销毁操作放在了Service的onDestory()方法里,但是发现有时候会报TimerTask已经schedule的异常。开始就觉得很奇怪,不是已经在onDestory()方法里关闭了TimerTask了吗?后来想到,Service的onDestory()方法不是一定有机会执行的。在资源不足的时候,系统会强行关闭Service,在这种情况下,onDestory()方法是没有机会执行的。
所以,绝对不能依赖组件的onDestory()方法。
3、这次项目管理有一个失误的地方。就是在项目设计早期,没有关注数据库表设计。到了后期才来检查数据库的设计,结果发现有很多地方需要变更,这就造成建表语句、模型对象、DAO都要修改,开发和测试的成本都非常高。
所以以后一定要在早期就关注数据库设计,如果有迫不得已的数据库变更(这个几乎是难免的),也要趁早进行
4、有的时候,发现两个组员都是更新了最新的代码,可是一个能正常跑起来,另一个人就总是报错。这种情况,一般是因为数据库错误引起的,虽然是同样的代码,但是却不是同样的数据库。这种情况下,需要把旧的应用卸载,重新启动。这样就会触发SqliteDatabaseOpenHelper的onCreate()方法,重新建立一致的数据库
5、前期把整个应用的常量,都放在一个Constants类里,这样虽然避免了硬编码,但是其实由于Constants类里充斥了各种各种的常量,也失去了可维护的意义。所以如果常量太多的话,可以考虑根据模块或者业务,分散到不同的Constants类里
6、一般跳转到别的Activity,是调用startActivity()方法,不过如果需要在新Activity里做完某些操作以后,再通知原先的Activity的话,应该调用startActivityForResult()方法,然后实现onActivityResult()方法
7、有一次在DDMS里发现了has leaked window的异常告警。这种情况一般是在Activity里创建了Dialog,然后又没有及时关闭引起的。解决的办法很简单,在需要创建Dialog的地方,调用showDialog()方法,然后在Activity里实现onCreateDialog()方法,这样的话,Activity就会管理Dialog的生命周期,就不会发生上述的问题了
8、一般连接android底层的linux,用adb shell命令就可以了。但是如果同时开启了模拟器,又连接了真机,就不能这样了,必须用以下的命令:
adb devices,这个命令可以看到有哪些设备,包括了模拟器和真机
然后用adb -s (deviceId) shell,就可以连接到目标终端上
或者还有一个办法,用adb -d shell连接到设备上,用adb -e shell连接到模拟器上
9、我自己定义了一个VO类,可是用Intent.putExtra()方法竟然放不进去,原来是这个VO没有实现Serializable接口
10、项目中业务上需要很多后台长时间运行的Service,可是后来发现Service实在太多了,所以换了一个方案。把实现业务逻辑的Service,都改成用IntentService实现。只开启一个长时间后台运行的Service,在这个Service里用多个TimerTask,定时去startService()各个IntentService。这样应用就只有一个驻留Service了
11、很多Service都去实现onStart()方法,其实这是不对的,onStart()是一个遗留方法。Android2.2以上的版本,官方推荐是实现onStartCommand()方法
12、如果没有多线程的需求的话,使用IntentService替代Service是一个不错的选择。一方面不需要编码另起线程(Service默认是跑在UI Thread里的,这点相当恐怖),另一方面,也不需要显式地调用stopSelf(),或者stopService()。IntentService的问题是,如果需要并发地处理请求,则晚来的Intent只能排队
13、TimerTask比较多的话,一个最佳实践(或者是迷信)是:用3、7、11、13、17这样的素数错开运行的时间
14、一个已经调用了.cancel()方法的TimerTask,不能被再次作为Timer.schedule()的参数,需要重新实例化一个TimerTask
15、没有特别的需求的话,个人建议可以在AndroidManifest.xml里不配置intent-filter,这样就强制代码只能用显式的Intent来跳转Activity或者开启Service,不能用隐式的Intent来调用。
这种做法虽然损失了一些面向组件的灵活性,但是定位问题会比较简单。因为比较容易查出来,某个Service被哪些组件启动了,或者某个Activity可以从哪些页面跳转过来
当然,如果Activity和Service被设计为允许其他应用使用,那必须要支持隐式的Intent调用
16、数据库字段的命名,还是有点讲究的。比如在T_PERSON表里,字段就没必要再命名成PERSON_NAME,直接叫NAME就可以了,前者比较冗余。这个虽然是小问题,但是对于追求细节完美的应用来说,还是要注意的。如果前期没有注意,到项目后期再统一优化,代价会大很多
17、原来经常用getSharedPreference()方法,来获取自定义SP文件。其实发现,用PreferenceManager.getDefault()方法就可以获得一个默认的SP文件了
18、DTO和VO,建议重载toString()方法,调试会很方便
19、Activity的findViewById()方法,和View的findViewById()是不一样的。
前者一般都在onCreate()方法里调用setContentView()方法,然后findViewById()就是从这个xml文件里找ID
后者一般调用一个inflate()方法,然后findViewById()方法是从这个xml文件里找ID
所以在另一个xml文件里定义的组件,在没有引入该xml文件的Activity里,用findViewById()方法是找不到的。项目里因为这个原因,发现了几次NPE
new Thread(){ public void run(){ // 做了一些数据库操作 db.close(); } }.start();
结果运行过程中,发现有时候会报数据库已经锁定的异常。最后才定位到上面这段代码。原因是在上面的run()方法中打开了数据库,这个时候会自动锁定Database,如果在关闭数据库之前,另外一个线程B也进行数据库操作,就会报这个异常。如果数据库已经关闭之后,另外一个线程B请求数据库操作,就没有问题。
所以在新线程中进行数据库操作,或者是TimerTask中进行数据库操作的时候,要注意考虑并发的问题,也许就会有数据库锁定的异常。
2、另外一段代码,将TimerTask的销毁操作放在了Service的onDestory()方法里,但是发现有时候会报TimerTask已经schedule的异常。开始就觉得很奇怪,不是已经在onDestory()方法里关闭了TimerTask了吗?后来想到,Service的onDestory()方法不是一定有机会执行的。在资源不足的时候,系统会强行关闭Service,在这种情况下,onDestory()方法是没有机会执行的。
所以,绝对不能依赖组件的onDestory()方法。
3、这次项目管理有一个失误的地方。就是在项目设计早期,没有关注数据库表设计。到了后期才来检查数据库的设计,结果发现有很多地方需要变更,这就造成建表语句、模型对象、DAO都要修改,开发和测试的成本都非常高。
所以以后一定要在早期就关注数据库设计,如果有迫不得已的数据库变更(这个几乎是难免的),也要趁早进行
4、有的时候,发现两个组员都是更新了最新的代码,可是一个能正常跑起来,另一个人就总是报错。这种情况,一般是因为数据库错误引起的,虽然是同样的代码,但是却不是同样的数据库。这种情况下,需要把旧的应用卸载,重新启动。这样就会触发SqliteDatabaseOpenHelper的onCreate()方法,重新建立一致的数据库
5、前期把整个应用的常量,都放在一个Constants类里,这样虽然避免了硬编码,但是其实由于Constants类里充斥了各种各种的常量,也失去了可维护的意义。所以如果常量太多的话,可以考虑根据模块或者业务,分散到不同的Constants类里
6、一般跳转到别的Activity,是调用startActivity()方法,不过如果需要在新Activity里做完某些操作以后,再通知原先的Activity的话,应该调用startActivityForResult()方法,然后实现onActivityResult()方法
7、有一次在DDMS里发现了has leaked window的异常告警。这种情况一般是在Activity里创建了Dialog,然后又没有及时关闭引起的。解决的办法很简单,在需要创建Dialog的地方,调用showDialog()方法,然后在Activity里实现onCreateDialog()方法,这样的话,Activity就会管理Dialog的生命周期,就不会发生上述的问题了
8、一般连接android底层的linux,用adb shell命令就可以了。但是如果同时开启了模拟器,又连接了真机,就不能这样了,必须用以下的命令:
adb devices,这个命令可以看到有哪些设备,包括了模拟器和真机
然后用adb -s (deviceId) shell,就可以连接到目标终端上
或者还有一个办法,用adb -d shell连接到设备上,用adb -e shell连接到模拟器上
9、我自己定义了一个VO类,可是用Intent.putExtra()方法竟然放不进去,原来是这个VO没有实现Serializable接口
10、项目中业务上需要很多后台长时间运行的Service,可是后来发现Service实在太多了,所以换了一个方案。把实现业务逻辑的Service,都改成用IntentService实现。只开启一个长时间后台运行的Service,在这个Service里用多个TimerTask,定时去startService()各个IntentService。这样应用就只有一个驻留Service了
11、很多Service都去实现onStart()方法,其实这是不对的,onStart()是一个遗留方法。Android2.2以上的版本,官方推荐是实现onStartCommand()方法
12、如果没有多线程的需求的话,使用IntentService替代Service是一个不错的选择。一方面不需要编码另起线程(Service默认是跑在UI Thread里的,这点相当恐怖),另一方面,也不需要显式地调用stopSelf(),或者stopService()。IntentService的问题是,如果需要并发地处理请求,则晚来的Intent只能排队
13、TimerTask比较多的话,一个最佳实践(或者是迷信)是:用3、7、11、13、17这样的素数错开运行的时间
14、一个已经调用了.cancel()方法的TimerTask,不能被再次作为Timer.schedule()的参数,需要重新实例化一个TimerTask
15、没有特别的需求的话,个人建议可以在AndroidManifest.xml里不配置intent-filter,这样就强制代码只能用显式的Intent来跳转Activity或者开启Service,不能用隐式的Intent来调用。
这种做法虽然损失了一些面向组件的灵活性,但是定位问题会比较简单。因为比较容易查出来,某个Service被哪些组件启动了,或者某个Activity可以从哪些页面跳转过来
当然,如果Activity和Service被设计为允许其他应用使用,那必须要支持隐式的Intent调用
16、数据库字段的命名,还是有点讲究的。比如在T_PERSON表里,字段就没必要再命名成PERSON_NAME,直接叫NAME就可以了,前者比较冗余。这个虽然是小问题,但是对于追求细节完美的应用来说,还是要注意的。如果前期没有注意,到项目后期再统一优化,代价会大很多
17、原来经常用getSharedPreference()方法,来获取自定义SP文件。其实发现,用PreferenceManager.getDefault()方法就可以获得一个默认的SP文件了
18、DTO和VO,建议重载toString()方法,调试会很方便
19、Activity的findViewById()方法,和View的findViewById()是不一样的。
前者一般都在onCreate()方法里调用setContentView()方法,然后findViewById()就是从这个xml文件里找ID
后者一般调用一个inflate()方法,然后findViewById()方法是从这个xml文件里找ID
所以在另一个xml文件里定义的组件,在没有引入该xml文件的Activity里,用findViewById()方法是找不到的。项目里因为这个原因,发现了几次NPE
发表评论
-
android培训文档提纲(四)
2011-11-27 23:28 12521、生命周期方法onSaveInstanceState()是在 ... -
Tasks and Back Stack
2011-11-22 23:47 1187Even though the activities may ... -
上周开发过程中几个简单问题的总结
2011-11-21 13:18 1368上周开发中组员遇到几个问题,都不是大问题,但都耽搁了一些时间。 ... -
android培训文档提纲(三)
2011-11-12 23:47 17701、Activity和Service组件是Context的子类 ... -
android的Log组件和logcat命令
2011-11-12 23:03 6331项目进入开发阶段了, ... -
android培训文档提纲(二)
2011-11-07 21:10 1670一、Each Activity can make an ... -
android培训文档提纲(一)
2011-10-23 14:05 1610最近项目快要进入开发 ... -
顶部有一排按钮,最底下还有FooterView的ListView页面
2011-08-13 15:46 3308先上效果图: 下面详细说说这个页面是怎么做出来的: 1、 ... -
实现屏幕下方展示的TAB分页
2011-08-09 23:22 2182这篇博客是参考helloandroid兄的腾讯微博应用,我整理 ... -
PendingIntent
2011-08-08 16:02 1564在开发SMS等应用时,有时调用相关的API会要求提供一个类型为 ... -
android数据持久化总结
2011-08-06 12:23 19241、 通过Context.getSharedPreferenc ... -
intent and service
2011-08-04 00:07 1426明天才开始讨论包需求 ... -
最近两周android总结
2011-08-01 23:42 1621最近2周预研做得差不多 ... -
没有单元测试,怎能写代码
2011-07-25 17:56 1575项目前期的技术点预研完成了,最近开始做原型开发。 之前没有在 ... -
android process and thread
2011-07-18 16:31 1702前三周android预研中,把可能用到的技术点都识别了,并完成 ... -
android第三周小结
2011-07-18 10:16 13681. 系统自带的通讯录应用,联系人名单保存在data/data ... -
onPause()方法的特殊性
2011-07-15 17:11 2937onPause(), onStop(), onDestroy( ... -
activity存在的三种状态
2011-07-15 16:44 1781An activity can exist in essent ... -
android第二周小结
2011-07-14 10:50 11681. 做了短信侦听的Broadca ... -
android一周小结
2011-07-04 21:26 1239做了一周android预研,总结以下几条: 1. 用DDMS ...
相关推荐
在过去的六个月中,成功开发了37项新产品,其中41%已进入批量生产阶段,16%正在进行客户验证,22%等待验证,而其余21%仍处于研发阶段。这些新产品主要面向国际客户,占比78%,包括多个知名跨国公司,涉及锥环、支撑...
在撰写一篇半年工作总结时,我们需要全面回顾这六个月的工作情况,包括个人成就、团队协作、项目进展、遇到的挑战以及未来规划。以下是对这些关键点的详细阐述: 首先,个人成就部分是总结的核心,应详细列出在这...
根据统计,至6月底,开发区共签订了21个招商项目合同,合同引资总额达到87亿元,实际到位资金为19.8亿元,显示出了强劲的增长势头。 在项目建设方面,2011年开发区精心规划实施了15个重点产业项目,总投资额高达62....
上半年的回款表现为1-6月份完成了总计元的项目金额,从3月到6月底的四个月回款额达到了元。值得注意的是,部分网站是免费制作的,还有部分欠款正在积极回收。这反映了数据中心在项目执行和资金管理方面的工作情况,...
在2017年8月加入****以来,我经历了将近一年半的充实工作,期间参与了多个关键项目,不仅提升了我的专业技能,也增强了我的团队协作和项目管理能力。 在本年度的主要工作中,我参与并主导了多个项目的开发,...
这份文档可能是由林业部门或相关机构编写的,旨在总结过去六个月的成果、经验教训以及可能面临的问题。描述中的信息与标题相同,进一步确认了这是一个总结性质的文件。 在“教育”这一标签下,我们可以推测这份文件...
【县商务局XX年半年工作小结】 这篇文章是对某县商务局在XX年上半年工作成果的总结,主要涉及以下几个核心知识点: 1. 招商引资:县商务局的首要任务之一是完成年度的招商引资总额目标。半年内,已实现45430万元的...
随着年中的到来,对过去六个月的工作进行总结,有助于更好地制定接下来的发展战略,以及为个人职业成长提供指导。 首先是培训方面的总结。作为销售人员,对市场的敏感度和营销技巧是基本素质。11月底新加入的销售...
通过以上对入职半年工作总结的内容梳理,我们可以看到这位员工在过去六个月的时间里不仅积累了宝贵的工作经验和技能,还明确了自己在未来发展中的方向和目标。这不仅有助于个人职业生涯的发展,也为公司带来了积极的...
利用我在部门内的人脉关系,我仅用了一个多月的时间就完成了这些繁琐的手续,为企业的运营打下了坚实的基础。 在土地交付方面,我作为企业(公司)土地交付工作小组的一员,密切关注进展情况,与拆迁办等相关单位...
5. 下个月的工作计划:对下个月的工作计划和目标的记录。 6. 建议:本月遇到的重要问题和应引起重视的问题,以及因此产生的建议。 通过该月报,可以了解项目的当前状态和未来规划,及时发现和解决问题,提高项目的...
总结来说,“易语言半黑月自绘时钟源码.rar”为我们提供了一个集易语言编程、自定义界面设计、时间信息处理于一体的综合性学习案例。它不仅仅是一段代码,更是易语言编程智慧的结晶,是开发者们技术提升和艺术灵感的...
它帮助企业了解过去六个月的业务表现,找出成功之处与不足,并为下半年的工作提供方向。以下是对这份"企业半年度回顾总结报告模板"中六个核心维度的详细解读: 一、业绩完成情况 这是对企业最直观的评估,包括: 1....
会议在7月10日举行,由王涛溪主持,包括科技处、清河采油厂等多个部门的相关人员参与,对4个已完成的科研项目和2个新立项的项目进行了评审。 在评估环节,首先由科技治理中心汇报了半年工作成果,得到了高度评价,...
在过去的六个月中,最令人振奋的莫过于我们公司的业绩有了显著的增长。这不仅仅是数字上的提升,更是团队凝聚力和执行力的体现。我深刻地意识到,个人的成长离不开团队的支持和领导的指导。通过不断向周围的优秀同事...
这个系统由一个团队在短短半个月内完成,并获得了教师的高度评价。项目不仅提供了完整的源代码,方便其他开发者学习和借鉴,还记录了开发过程中的经验与挑战,为软件开发的学习者提供了宝贵的实战案例。 WinForms是...
通过半个月的 android 实习,我基本掌握了 Android 应用程序开发的一般流程,对常用控件基本掌握其用法,对其事件的监听方法也基本掌握。学习 Android 不仅是对前沿开发技术的了解,也是对编程知识的一次提升。 ...
每个月就有几万十几万甚至更多的进帐,凭空多出个"食利阶层"。 2. 慎选程序设计语言 男怕入错行,女怕嫁错郎。初学者选择程序设计语言需要慎重对待。软件开发不仅仅是掌握一门编程语言了事,它还需要其他很多方面...