找回密码
 加入我们

QQ登录

只需一步,快速开始

搜索
查看: 15952|回复: 66

[Treo650] 论650的稳定性(关键字:查无此人ROM 寂夜清风软件包 NVFS DBCache)

[复制链接]
发表于 2007-3-29 21:31 | 显示全部楼层 |阅读模式
各位胖友好。偶去年入手600,今年3月22日忍不住650的高分真彩屏的诱惑,终于买下650(2200元,加上去年的treo 600要1600元,也是差不多去年一台650的价格,白赚一台600,呵呵)。" z( s5 i0 y% c# Z+ I
  t; w3 ~5 e; h/ R% C* B
拿到650的时候,正是单位里最忙的阶段,每天工作象在军训,到家什么都不想做,但是有了650,就难以忍受600的屏幕啦(各位600的胖友不要生气,偶对显示效果比较在意。),又没有时间一点一点的摆弄(palm的机器可是要好好折腾半个月才行啊),怎么办呢?
2 N: R5 h, n1 M' ^
. m, n% ]6 b, |0 m) c2 l! L# v6 b“吹友吧”是我去年来过的,当时似乎很简陋,帖子也少,顺手存下来,就没有再来过。这次从收藏夹里打开,才发现,俨然已经成了我们胖& V- @6 ]7 ~5 E# x& s) @2 ~
友的宝库了。最让我感动的是两位版主(寂夜清风和色鱼,如果有遗漏,还望海涵)敬业的态度。首页的精华贴几乎囊括650的所有重要知识,里面的版面,两位版主也是尽心尽力,给大家排忧解难。% }1 m8 A# f; ?
得了,我也不去找软件了,就直接刷了高分图标的查无版ROM,然后按照寂版的教程把他的软件包一股脑的扔进我的650。
% s# d0 p& s; I+ T, N
5 d2 i3 G9 A# p: U! g+ M. F$ t& Q: l9 w罗里八嗦说了一堆和标题无关的话(坛子里是不是按字数给稿酬啊?呵呵。),是想表达对两位版主和各位在坛子里热心助人的朋友的感谢,我能在短短几天就把650摆弄好,你们是我最需要感谢的人。
- X9 V8 u# q" l; y/ B" h( b
/ y9 @5 }, j7 v& _但不可否认的,寂版的软件包可能还是有一些软件冲突,也许在有的机器上没问题,但从我严格按照寂版的操作步骤来做的情况来看,难免还是会发生系统重启的情况。现将崩溃时reset doctor的记录汇报如下,供各位高手参考:0 f6 d) [" Y5 j" c& U1 K
' z$ H5 f1 Z- f* z
07-3-28 18:19   system crash "MemoryMgr.c Line:3842,Nil Ptr"
" K: h. G5 X$ q07-3-28 23:49 system crash while running 掌易 "Field68K.c,Line:247,form object(field) not found"# W& d/ d9 w- }* q% l0 P
07-3-28 23:54 system crash while running butler "preferences.c,Line:263,pref db open error") K: V- t( {( V3 p# r* i
07-3-29 0:01 system crash while running 掌易 "Field68K.c,Line:247,form object(field) not found"
" }% Y3 c; b+ ^1 }- {$ N3 m/ ?6 F1 J3 y6 [5 `( Y
需要说明的是,我装的是寂版27日夜里发布的2.47.1(掌易用上了巨硬的字库)。而在出错的期间,我的屏幕右下角总是有输入状态的提示符(“中”/“英”两字),也不知道在哪里设置消除,最后,没办法,用rscbackup恢复备份。没有右下角的提示标志了,然后退出了zlauncher,直接用系统launcher,系统今天一天没有发生重启。
$ I+ G8 n! w1 @. D0 P' |7 c) e$ ~2 f  v" L( G# c3 v8 t
除了上面写的这些崩溃日志,我前两天装了寂版的2.47,重启更加频繁(也许是我装好后,试各个软件导致配置文件过大?),因为机器重做,reset doctor的日志丢失,也没办法留下记录了。但是,我印象中,重启并非固定在哪个程序运行时,发生的很随机,甚至按电话键点亮屏幕都会重启。
1 w. Z2 m0 e5 y- b0 n
: a! b* [% `4 `( T) K, r还有一点疑问就是,大家的DBCache是不是一直都稳定在一个数值?我的650重启后,会在11M左右,但用了一段时间后,基本上就剩下2-3MB了,特别是用rscbackup后,下降最为明显。寂版如果不太忙,是不是可以帮我诊断一下?(我的机器除了您的软件包,自己仅装了adarian money 3.6,daynotez 2.9.1和一个fieldplus,应该不算太多吧。)2 K4 C! n3 p) g+ j2 A
# I9 N/ S7 ^  Z# l1 d" e: x) h8 F
为了解决这个困扰我,也困扰坛里各位朋友的问题,我在网上四处谷歌了一番,结果在reset doctor的帮助文件里发现了一个线索,关于NVFS结构和系统崩溃的论述(http://www.hobbyistsoftware.com/InsideYourTreo/cache-crash.php),标题是“How to fix a Cache Crash 如何修复cache崩溃”,写得非常好,文字简洁,条理清晰。今天中午,我用午休的时间(难得啊,军训还有午休)翻译了一遍,放在这里,供各位参考,也算是我在吹友吧里潜水多日,给大家的一个小小的礼物吧。# w3 |1 H: B* O4 e1 T3 a) Y) \6 X5 o
! d( f* k. X: I. J& H
本来还想按照文中叙述的方法找到各个软件测试一下,寂版软件包里到底是哪个软件导致系统不稳定,但今天实在太累了,只有改天再试。如果有朋友等不及,也可以按照文章中的步骤测试一下,大家一起讨论,让寂版的软件包“更快、更高、更强”!* _- Q2 `0 y- Z/ h5 z5 K; G- V

3 y8 p. Z( M# E) r文章贴在二楼,翻译仓促,可能有些字句没有斟酌,但基本意思是没有问题的。原文和图大家可以参看http://www.hobbyistsoftware.com/InsideYourTreo/cache-crash.php+ I) @4 g+ I. r+ Q  d, c
# l% @5 `' J& S4 W$ r8 ?: |
[ 本帖最后由 anil 于 2007-3-29 21:48 编辑 ]

评分

参与人数 1威望 +10 收起 理由
寂夜清风 + 10 精品文章

查看全部评分

 楼主| 发表于 2007-3-29 21:34 | 显示全部楼层
如何修复cache崩溃) J; X3 _2 N+ ~$ L% Q

$ @  `, ^: D  A! J- ]http://www.hobbyistsoftware.com/InsideYourTreo/cache-crash.php
# t" f) c' G) V1 Q4 i
0 a, s8 Z7 |( }# U" C# b不稳定的palm会让你疯狂。更郁闷的是你无法确定究竟哪个程序引发了这个问题。
) V/ g" X6 J( Y如果你遇见的崩溃是随机的,看起来并非和某个特定的动作相关,那么这篇文章应该能帮助你。- G# _( Y  Z% `1 z4 l% g$ E4 Y  o
我会解释其中一部分这样的崩溃是来自哪里,同时,给你一些如何查找它们的线索。5 A' I; M$ g" \' K( w
这种类型的崩溃适用于所有使用了NVFS(non-volatile file system非挥发性内存系统)内存的palm设备。包括650以上的treo、life drve、tungsten E2、T5、Tungsten X 和 Zire Z22,今后可能有更多这样的掌机问世。
/ y" d( F% S1 \$ C+ n. c+ u4 Y0 `" n( Q" w3 B5 m
我们会用“Palm Internals”来观察treo的内部情况,用“Reset Doctor”来管理这些崩溃,同时有助于这些崩溃发生的更频繁:)。通过强制崩溃的频繁发生,更容易的制造这些崩溃,你可以更快的判断问题出在哪里。
7 s3 b0 m: g2 N- [  L9 V, C! T  R
1 H* G" ]" s! g$ M4 y7 x快速cache翻新% V# d7 V9 ~8 \: ^/ B. c
我以treo 650为例,虽然各机型的存储容量不同,但适用于所有用NVFS内存的设备。) {. e* f7 K) k. x9 c
Treo 650宣称有32MB(23MB用户可用)的内存,但这并非表示你可以用到这么多内存。+ L& I# h" G& S- F/ Y
你不可能用23MB内存来运行一个应用程序。
. H( B9 u& V8 |; j) U运行中的应用程序无法抓取整块内存用来运算。$ m- R3 L+ G3 ]! f; Y. U
这和你的treo 600的内存是完全不同的。% N, N# T/ e/ b4 e8 z7 T, r
实际上,650的内存更象是一块内建的32MB SD卡,我下面将谈到NVFS内存的这种情况。3 ?; q3 a# B1 s  e7 _

5 H' T' y7 I$ G3 pPalm不能在SD卡中运行程序,你必需把程序拷入RAM,在RAM中运行(你的launcher为你做了这些事,如果没有,那么get initiate(译者注:这句偶翻译不好,请达人指教))。你可能已经注意到从卡上运行程序会有延迟,那是你的launcher正在把程序拷入RAM。6 \) n) }  c/ q  A: h- C: L7 s

+ s4 S1 e5 l" {* p/ z& H7 ^4 RNVFS内存有同样的限制。你不能在NVFS内存上运行程序,系统也不能用它作为工作内存来进行运算等工作。为了做运算等工作,palm有一些正常的内存,在650上,大约是12MB,这就是我们所说的DBCache。" S: ^( U9 o. N7 D7 D7 n& e& P

9 K/ T+ y0 n8 P- y你设备上运行的程序认为它们可以拥有和处理的是一台有23MB内存的正常设备。它们希望可以存取数据库、创建数据库和使用这些内存。这意味着系统必需做一些设定的基础工作,在需要的时候动态的调用数据库和程序进入DBCache。当然,你不能把一夸特东西装到一品特的锅里,同样,23MB的NVFS和仅12MB的DBCache,DBCache必然会被装满。这时,系统不得不清理一些它认为不再需要的数据,这样就会导致错误。2 B7 i5 o+ t2 }

/ a% |+ a, |: I  O3 @6 u在这里,你可以了解更多NVFS和DBCache的细节。6 O. B1 ^- [' l) d2 G
/ x+ f! x* T9 s
这样的确相当复杂,但Palm使用这样的结构有几个重要的原因。
2 \1 b& ^  m0 y& u* k
+ t: T6 F0 g; t; R, F) @1、就象SD卡,你的NVFS内存不需要用电力保存数据,这意味着电池耗尽也不会丢失数据。
9 y: e/ X" q' S. G2、既然NVFS内存不用电,那么,你的palm就可以有更长的电池续航能力。
8 m1 H+ h' M/ w# T+ u, {# h. N3、NVFS内存价格便宜。这使得我们的palm可以用较低的价格获得较多的内存,坦白的说,我很惊奇厂家为什么没有提供给我们1G内存的设备。(译者:我考,650也太小气了吧!)
' B$ [# F' f: I" S4 h0 q4 \% ?+ Z' F
哪里出错了?
* s/ _* W/ _0 D) ^) C我在上次的文章《公告、后台程序和快速上网的treo》中,我解释了程序是如何注册系统通告,当特定的事件发生时,操作系统调用该程序,给它处理数据的机会。. H1 K3 x7 ?4 k$ f# ]: W
7 ]5 H/ Y( a* `  c+ r% o
下面是它出错的步骤:
' }. h; ]: |. y% C1、一个程序(这里我们称呼它为“糟糕程序”)注册“hvch”通告,这是一个由任意一个虚拟字符被处理时发出的通告。你随时可能获得虚拟字符,比如按下键盘上的一个键、电池达到一定的容量、一个警报消除等等。& I5 n& _7 A6 _( \
2、“糟糕程序”关心的是速度,所以它注册了“the fast way绿色通道”。这意味着它告诉系统当通告发生时,请系统去某个特定的内存地址调用处理函数。- l, ?( Z: U2 d8 ]* ~2 n* y; O
3、“糟糕程序”一般都是几年前写的,当时它们的作者并不了解NVFS,所以,程序不会再做任何其它事,它开始坐等通告的发生。$ L- _9 @$ o9 e( j4 \% f5 Y" E4 U! r
4、在你阅读文档、玩游戏等的前几个小时里,程序会工作的很正常。% S. v0 y* a7 }5 w  p( f, \
5、到了某个临界点时,DBCache装满了。, K' x9 s* `7 o% d8 d5 g! d. f
6、系统开始察看DBCache,它高兴的发现没有任何程序会用到这个“糟糕程序”,于是,系统把所有改动拷贝进入NVFS,然后在DBCache里面把它删除。
8 [6 `6 m* A3 g2 ^" a7、几乎与此同时,系统获得了一个虚拟字符,它开始试图去那个通告所注册的内存地址,运行相应的代码。比如说现在这个内存地址变成了你正在阅读的一个网页的代码,于是,系统崩溃了。: I' Y& m3 o7 {+ u8 |; r+ l+ L3 m
如果这时,你查看你的“崩溃日志”,你会看见一个类似“Emul68KMain.c, Line:403, illegal instruction xxxx at address xxxxxxxx”的错误提示信息。' I" U- r, \) R( _- ?; ^+ I2 Z7 U
现在编写的大部分程序都已经了解的NVFS的特性,所以,在上面第3步,它们会锁住自己的代码,禁止系统把它们从DBCache中清除出去。$ L4 \  K  M' B& }# q4 R
* C' U8 ~' @5 O: g( t
Cache崩溃,你遇见过么?
' W/ {/ A- i7 i9 BDBCache崩溃的确很难弄清楚。它有可能引起、也有可能不引起上表所列的错误,你也永远无法知道它发生的时间。
/ M) @9 a# ^! {+ v2 W一个简单的检查方法是使用“Reset Doctor”。它可以让你按一个键来清除你的DBCache。如果这样引起了一次崩溃(或者在你清除DBCache后不久发生崩溃),那么,你的系统就是有这个cache崩溃问题。6 s0 j; n/ B5 C# ]# W, F* d, `2 G
“Reset Doctor”也可以让你自动清除DBCache来保持一定量的空闲内存。一个程序退出和另一个程序启动时,如果必要,“Reset Doctor”会清空DBCache。这意味着DBCache清理未必会在一个程序实际被打开时发生(这是另一件可能导致故障的操作)。更重要的是,“Reset Doctor”可以在它清除DBCache和系统重启时保存信息至日志文件。如果你的日志文件显示崩溃是在DBCache被清除后不久发生的,那么,这是系统有cache崩溃问题的又一信号。
! E* v& Q" v9 |# `
+ h1 T# X# C/ T) _Cache崩溃:你可以做什么
, ^+ D6 _9 ~5 F" x, k- l9 ?! f% X我们能很方便的找到大多数注册为“the fast way绿色通道”通告的程序,同时也很方便能判断出它们是否锁定了自己。下面是做法:
, f% `+ _; i0 S1)运行“Palm Internals” 点击“Notif”按钮,你可以看见如下列表:/ b5 Y+ f6 ]5 q1 k0 _' n) n2 @
*如果系统的状态相当差——甚至运行“Palm Internals”都会导致cache被清空、系统重启,那么你必须把你怀疑有问题的程序移到卡里,手动重启机器,然后再次运行“Palm Internals”。如果可以正常运行,你可以逐步将这些程序移回内存同时注意观察是否有问题。
" e2 w0 R8 e5 v6 \7 }9 l' F0 T2)检查这个列表,找到其中在它们注册后含有'm68k xxxx DBCache'字样的程序(这些是那些注册为“the fast way绿色通道”的程序)。我的列表中会有“butler”和其他一些“糟糕程序”。这些就是你的怀疑对象。
" b; {( C. h4 b; m! `3)选择menu-locked DBs,这可以显示哪些数据库被锁定。
, v; i% j. o& A' d' m9 l5 T4)检查你的“怀疑列表”中的每一个程序。如果其中一个程序没有锁定自己的源代码,那么可能它就是导致出错的原因。我这里,“butler”已经锁定,而另外一个“糟糕程序”则没有。1 F* r9 s- j$ j! Q$ _( i
5)选择menu-protected DBs。列出哪个数据库做了保护,不被删除。2 M; S3 ^: D7 _9 A: Z2 I
6)检查你的“怀疑列表”中的每一个程序。这个检查相对不太重要,但程序应该能保护自己从而能知道系统什么时候会再次删除它们。“butler”被保护,另外一个“糟糕程序”则没有。
5 J; O# O  K0 M
. B6 |7 x$ r) k; m0 b# N: Z你现在已经有了风险程序的列表,尝试把它们删除(或者移到卡里)。如果走运的话,你的palm就会稳定。! ?6 R5 v$ H' y- k" z+ d
一旦你弄清除这些风险程序,你可以不再运行它们,或者用类似“Resco Locker”的程序来锁定它。一个附加的好处是:你现在已经确切知道哪个程序有风险,你可以不必再锁定其他的程序!过度使用“Resco Locker”有可能迅速填满你的cache,而且看起来会导致它自身出现问题。
/ C' {- i1 {% p' L8 r
1 O7 q8 E, d# {6 ]( ^. l/ t这样做容易么?
6 a  w7 @) _5 o& b! K" {希望如此!不幸的是,还有一些事会发生。
: P1 k" e9 F! Z你的“怀疑列表”并不十分完整。一些程序不使用通告直接潜入你的系统。它可以在后台做任何处理,并且不会显示在通告列表,你也就无法把它加入怀疑名单里。“LudusP”就是这样一个例子,它虽然是潜入系统,但我确信它给自己加上了保护。  }# @" E4 L0 e4 ]3 r
还有一些程序仅在特定环境下才会注册通告。举例来说,一个程序可能为与通告相关的电话注册了“the slow way慢速通道”,但当电话正在进行时,它为关键按键注册了“the fast way绿色通道”。% q) S- N9 {$ l0 W
/ q1 T4 Y: D( T7 t& ]+ X/ h- D
还有么?谁知道呢!palm总会用一些特殊的方式让我们吃惊……
. N! `) V. G  L, n& Y& g0 ?. e而且,这也是我们期待的……(译者:对于崩溃,我可一点都不期待!)
$ r$ c3 I3 y4 L' I- X& n
5 V: l/ A5 _! p6 B# `  s和palm和谐相处并不容易,但对于开发者来说,总有很多快乐的事可以做。5 y/ u( d1 a" c7 A/ t
' ^* Y& [0 p2 O; G4 N. g
一个避免锁定代码的技巧是把它拷入一些特征内存。这是操作系统可以识别需要留下来的正常内存。7 [$ H4 |1 f9 e, R* |6 A- B
这个技术被Daniel Grobe Sachs,可能还有其他人所采用。
+ t6 M$ {3 j8 k$ A/ d不幸的是,我不知道有什么办法能让你检查哪个程序运用了这个技术。
; g3 [. j* \: c* j: v- n
  R( e4 E0 s- z2 [2 S[ 本帖最后由 anil 于 2007-3-29 21:55 编辑 ]

评分

参与人数 1威望 +20 收起 理由
小洋葱 + 20 支持学习外国先进技术!

查看全部评分

发表于 2007-3-29 21:55 | 显示全部楼层
支持LZ,学习了
发表于 2007-3-29 21:56 | 显示全部楼层
又一个研究技术的人,哈哈。。。
发表于 2007-3-30 00:06 | 显示全部楼层
好多字。慢慢看。:1
 楼主| 发表于 2007-3-30 21:52 | 显示全部楼层
失望啊,没人讨论技术。白忙半天……
发表于 2007-3-30 23:07 | 显示全部楼层
我装reset doctor也就是为了方便查看log,不过现在懒的搞了。感觉650个体差异太大,好好的程序,指不定偏偏就认准我的机器重启。罢了,顺手再找个同类的软件代替解决
发表于 2007-3-30 23:08 | 显示全部楼层
其实这些根本无法决定机器的真正稳定性,就算你的dbcache再大,没有好的搭配和使用习惯,照样不行,所以根本就是要对机器了解,熟悉磨合机器,这些都比一门心思的研究dbcache更有用。
发表于 2007-3-31 07:17 | 显示全部楼层
好多字啊,看不懂。如果是zlauncher不稳定,你可以换换嘛。不用zlauncher。3 Z% `0 }' ^) C  k' x4 A* G7 ~
装清风的套件,我的经验是,先卸载zlauncher,然后自己重新安装一下zlauncher就好了。我也不知道为什么。
发表于 2007-3-31 12:04 | 显示全部楼层
下到650上慢慢看
" o3 L1 ~! g( n: o$ F
- V. `, u! I. q% h6 b我以前也用软件集成版,每天怎么也要启2-3次,也找不到问题在哪,dbcache也在10左右,最后决定自己装,虽然软件少点,但是真的稳定多了,色鱼斑竹说的对呀
 楼主| 发表于 2007-3-31 17:36 | 显示全部楼层
经过几天的摸索,基本上解决了我的650重启的问题,:11" /> :11" /> 再来看看帖子,似乎大家都还没有一致的明确的意见,我把我解决的方法写下来,希望大家验证和指导。: _& @& A$ {% s
1、2楼是翻译hobbyistsoftware上的一篇文章,看过之后,很受启发,不会再觉得重启很神秘,而且指明了查找问题的方向。建议大家看看(当然,翻译的很仓促,一些术语也没有统一的翻译,如果大家英文可以的话,建议直接看原文。不过,俺的译文也基本可以说明清楚问题的。
# Q1 {: y* M- L$ X: ~
, j& I8 C* ]5 x* a1 W3 Q% p2、用简短的几句话说明650重启的基本原因:
5 o; `+ F; u/ |4 n2 B$ A" O% b    1)NVFS:NVFS内存相当于机内的SD卡,palm不能在NVFS上运行程序(正如不能在SD上运行一样),但优点是a、断电后不会丢失数据 b、价格便宜)  q" W- B5 q5 E( s# L; N
    2)DBCache:650用来运行程序的正常的内存,约12M。运行程序时,650将NVFS上的软件拷入DBCache方能运行和写入数据;
9 j' H5 N3 u4 P7 {    3)两者的联系:2004年10月前的软件(”2004年10月“这个时间出自rlock的帮助文件),不了解NVFS内存特点,将用户可用的23M 用户NVFS内存当作正常内存来用,这时候,650运用自身的调用机制把数据在23M的NVFS和12M的DBCache中调进调出,以使程序正常运行;% j9 n' F0 f; ^  f8 F% i' h3 v0 E) m
    4)后台程序:一直在后台运行,代码放在内存中等待系统调用,如果被特定的条件激发(如butler的闹铃以时间为激发条件、callrec以“音量确认键”按下为激发条件),则系统会到该程序指定的内存地址位置调用该程序;0 A; Z! x9 G/ |$ e' n" U3 x" `6 C
    5)重启的原因:早期的后台程序没有对程序自身设定锁定和保护,当系统在NVFS和DBCache之间调进调出程序的时候,因DBCache小于NVFS内存量,难免会发生DBCache不足的情况,这时,palm会清理一部分DBCache中它认为无用的数据,而现在的后台程序都会对自己的内存中的代码和数据进行锁定和保护(即通知palm不得将其清理掉),早期的后台程序没有这样的机制,会被清理,这时,当激活条件发生时,palm去该程序指定的地址运行代码(这个代码已被清除,换成了你看的网页、图片或者其他代码了),机器就重启了。! }* y' i  C* ]9 K( E6 }0 f# d$ u
OK,原因就是这样,看来写的不够简短啊…… ) k  `2 D; b, I# T* u8 i

6 e* D7 ^( P1 g9 O# o: u- E/ ]0 N3、解决方案:
' ^+ \" t4 C+ B' P: q  X9 V很简单。
* J  l% m+ a+ z; N# o装上RLOCK(免费软件,大家可以在坛里找一下,resco的官网上好像也有),运行。找att列(属性列)中所有有“!”的程序(表示是后台程序),全部点选,然后点击lock。OK!' U# `; q0 q/ P, ~4 u$ ?+ `1 D
) d/ b3 A, N5 q! t2 }$ x1 O
4、一点说明:9 _) V' S& ^5 b2 K+ `( M
我在我的机器上已经试验成功,不知道是不是普遍现象,如果哪位朋友受重启的困扰,可以试一下,如果有效,不妨在帖子里写一下。如果有问题,也请指出,谢谢。) N. n- G2 z( @: v  z; R
ps:, C( B1 Q% H" b5 X1 }/ ?- D
我装的寂版的2.47.1,共锁了中文伴侣、unistall_manager、snappermail、pocketIME、KB Lightsoff、contactmate、callrec、bugme2004,(zlauncher太大了,没锁,但我自己没有用zlauncher),另外自己加装的软件中,锁定了adarian money、fieldplus。原来我的DBCache降低到只有1M多时,运行blazer必定重启,现在机器会提示内存不足,点击OK后,机器自动清理内存,然后blazer就能运行起来。退出blazer后,DBCache还能恢复很多。: Q$ |( @4 g+ c/ s* R1 u5 r: [/ w
7 B: x0 ?9 o: S  W! O* t( {+ g" }
最后,谢谢bob001tracey716 (色鱼)、xyz1937 (风林火山!) 、Seekitycatsaudi 的指导和回复!/ S+ x3 ~5 M, c4 W! e

" P) ^& |* |5 w8 w2 y9 y[ 本帖最后由 anil 于 2007-3-31 17:39 编辑 ]
发表于 2007-3-31 19:06 | 显示全部楼层
正在看....
# g6 ]8 m5 v* h1 Y
2 Z/ [; X5 _# V- P目前这边新手朋友太多了...就需要楼主这样爱琢磨的朋友...% K8 q! j  t4 I8 ?
" E2 D8 F1 P4 e3 `  Q  r
下来慢慢看看..看是不是有特别的原来没的留意的地方
发表于 2007-3-31 19:17 | 显示全部楼层
嗯...应该 说是PALM在把硬件换到目前的结构的时候,有很多地方没处理好,, V3 d# ]9 y/ `: H5 [& T  U9 w

8 q5 i# I# l$ `+ H- x" `首先PALM没有留上足够的DBCACHE/NVFS空间,尽管从硬件上讲这很便宜.但是PALM自己 出于商业的考虑,故意搞得很小..; i; _( V4 ^5 y0 j, y
' k# |9 G3 s+ }: M  I
其次PALM系统在NVFS的管理方面没有真正完善,尤其是原来的一些兼容性程序没有能很好地兼容于目前的管理方式,很容易造成DBCACHE清理时的冲突,从而引起崩溃...
1 N6 R$ ~3 I' H5 R$ Z. j# W3 u9 K
) w$ Z0 v4 y' X! O" ^: G用RLOCK的方式可以锁住最容易引起崩溃的程序,但是不建议把所有发现的程序都LOCK,因为如果那样的话系统也会出问题(DBCACHE太小了)...; w% b* |& v9 W8 h1 y
; g/ S5 i) e( G& d  U
楼主容易重启的原因其一是因为掌易的问题...掌易程序这两天更新了,应该会好很多..
发表于 2007-3-31 19:34 | 显示全部楼层

好东西

楼主的分享和钻研精神非常值得尊敬.
 楼主| 发表于 2007-3-31 21:32 | 显示全部楼层
原帖由 tracey716 于 2007-3-30 23:08 发表 % w0 ?+ H. D7 P) s3 U) g8 x
其实这些根本无法决定机器的真正稳定性,就算你的dbcache再大,没有好的搭配和使用习惯,照样不行,所以根本就是要对机器了解,熟悉磨合机器,这些都比一门心思的研究dbcache更有用。

8 q/ s9 n. h" L+ P4 {
5 a$ ]+ u9 n8 ~- ^' ~向色版小进一言,您的这些话,不利于大家研究的热情啊。
' O/ o  M1 F$ C6 y  N7 D
. X8 b: z  Q- X  z% P# Q——没有好的搭配和使用习惯,照样不行
/ a/ w9 R) `# W! N您没有看见别人怎么使用,可不能就认为别人用机器都是乱搭一气。虽然,我早就知道色版用过的各类手机可以论百计,不过,偶也是一路用着siemens 6688i/ipaq 1940/treo 600/N73/treo 650(才开始用,呵呵)过来的,而且长期从事软件工作,通过了系统分析师考试,不能说俺们就一根筋的在研究dbcache,不懂软件搭配吧。: G- N1 r- y1 Z# W' f/ I

4 ~/ [5 v( V" A. ?——这些都比一门心思的研究dbcache更有用
, ]1 s% [, x+ _7 K( d. d7 T4 b( K我不是一门心思要研究dbcache的大小,我是想解决系统崩溃的症结所在,而这个与dbcache有密切的关系。
' f6 T* w1 t2 F+ x( P( ^( S! X' |6 n' N3 W1 c
作为版主,应该高兴看见版里有探讨技术的帖子啊。
+ p3 f( j, ?( K; ~7 |6 t- n- O  q, W9 [  a
谢谢寂版加的威望,也谢谢你仔细看了我的帖子。(另外,说明一下,我用rlock锁住的10个,都是没有锁定属性的后台程序(除了adarian money,因为是账本,格外小心一点),总共锁了2M多一点。的确是偷懒了,没有一个一个去独立锁住尝试。)/ d8 x& s2 L& k) `1 O3 x& x& U7 Q' d& C
谢谢aswindasrain的鼓励。! u  A7 t8 b9 }
/ T* u% S% |& K( P, _' _5 X5 O
虽然有点小意见,还是要感谢色版不断的送给大家的各类大餐,问候一句:您辛苦了!/ ?8 l1 ~- Y/ G
2 W* d9 q  E' N* {& K( w2 F
[ 本帖最后由 anil 于 2007-3-31 21:39 编辑 ]
发表于 2007-4-1 22:09 | 显示全部楼层

果然有高手

希望坛子里学软件的人越多越好。想用好任何东西搞清楚原理是根本。
发表于 2007-4-1 22:11 | 显示全部楼层
我的就挺稳定的,虽然拿回来后没刷过
发表于 2007-4-1 23:00 | 显示全部楼层
色鱼 :1
发表于 2007-4-2 00:28 | 显示全部楼层
怕是遇到高手了 学习先。
发表于 2007-4-2 02:00 | 显示全部楼层
其实色鱼的看法与楼主并没有不同...
  _7 O0 j: ~+ h/ q
, G( d' {% f- {. o基本的方向都是:Treo 这个机器是需要花点时间和力气琢磨的..." A( M! _; d) k# ^- p+ K
' J2 |& z% V: G. d! B" A5 |+ u8 Z
从技术的角度上讲有一些方法可以提高稳定性,尤其是对于PALM系统基础上有很多改变的TREO650来说,很多人会非常奇怪为什么比600的稳定性下降那么多,技术上讲最简单的原因和方法就是楼主说的道理.* z8 U: _' e' z# t  {0 x# V# ]

; I% l: y5 D8 ~; V% Y7 R8 Z/ k& `但是由于TREO650设计上硬件的局限非常多,所以从使用的角度讲也有很多可以提升的..
% Y# ?" ^3 }: @* E* K: r
: _! q6 V- F# I, t6 h不过可能色鱼的话放在这个贴子里说出来可能会让大家觉得影响了讨论的气氛..所以我准备回头把鱼的贴子分割出来先
发表于 2007-4-2 08:54 | 显示全部楼层
8是把鱼的贴了分割出去,而是要把鱼的头分割下来烧点“鱼头汤”喝喝,大家在这儿讨论了这么久,口干叻……:1
发表于 2007-4-2 09:32 | 显示全部楼层
2楼翻译的文章不错啊!特别是对重启的原因介绍得很详细。1 W& L' Q; \% f6 l3 J& B& k0 Q; i* [

) ]! @4 N' v, _% `! A' w不过,文章中提到最根本的解决方法似乎是运行“Palm Internals”来找出风险程序,并不再运行它们。9 d" L! Q; p- s1 P; e1 J$ z

4 n4 i8 q6 [7 v: A+ J. C" UResco Locker也是列出风险程序的列表,并且比“Palm Internals”更进一步,可以锁定这些程序。6 s3 {4 y* Y7 d6 Z0 D1 I& [( B0 f) z
" Y. W  l! p2 z9 `6 |4 x2 |8 p
但Resco Locker的问题在于它的风险程序列表比较粗陋,它只能显示后台运行的程序,而并不知道哪些程序的数据库没有锁定。
: c- l( R* c0 x+ U2 t0 E6 Z( A% n7 B# z1 ]( `- L
我们常常会用它锁定一些不需要锁定的程序,而造成有限的DBcache空间的浪费。
发表于 2007-4-2 10:21 | 显示全部楼层
我现在的做法是基本不用Resco Locker。
, d! S/ [' `4 s$ A& a$ B9 L
4 w; V7 j6 ]* l软件环境:掌易+巨硬拼音码表+中文伴侣+callfilter1.32+Hi-Launcher3.3,系统非常稳定。
发表于 2007-4-2 13:05 | 显示全部楼层
学习了,7 I# q$ z2 W: |8 r1 K  n8 R. z
庆幸自己的机器比较稳定
发表于 2007-5-22 16:52 | 显示全部楼层
买新机的时候爱研究装软件,2 W, K8 P; b% n5 P9 I  x5 _
软件装完稳定使用了,
% M0 V  S4 ^% t; g) A
5 N3 [; T( T# V6 x再看见新软件也懒得装了。
$ c* D. w: _: G. d
+ n  S% {( j; [为了更得上潮流,0 G1 v! @# y; h" I) F8 ~
我还是得经常换换新机玩
发表于 2007-5-22 18:16 | 显示全部楼层
没有耐心看完,复制到手机里面,有空的时候看。呵
发表于 2007-5-23 08:27 | 显示全部楼层
和palm和谐相处并不容易啊!
发表于 2007-7-1 16:01 | 显示全部楼层
学习,这篇文章值得大家好好学习
发表于 2007-7-30 10:06 | 显示全部楼层
学习了,不错不错,俺机器因为试用的东西很多,经常重启。搞到后来不知道是什么软件造成的,连DB清理都重新启动,刚才把感叹号一口气全部锁定,好像DB清理不重启了,慢慢研究中,呵呵
发表于 2007-7-30 11:51 | 显示全部楼层
学习学习,前两天删除了rlock,因为不知该锁哪些东东,看了还是装上好。
发表于 2007-8-2 08:24 | 显示全部楼层
没用过lock,只是偶然performances.c崩溃,reset doctor的自动备份解救.
发表于 2007-8-2 10:46 | 显示全部楼层
呵呵,都挺钻研的啊
发表于 2007-8-2 10:56 | 显示全部楼层
配上几张MM图看起来会好点
发表于 2007-8-2 11:01 | 显示全部楼层
楼主赞一个!
发表于 2007-8-12 20:23 | 显示全部楼层
学习了,不得不佩服你
发表于 2007-8-12 21:40 | 显示全部楼层
不错,不错,支持搂住我也是最近刚加入到treo650,从一开始的515>tt1>tg50>tt2>tt3,期间因朋友接触过的机型也很多,最后tt3不幸丢失四年的感情~~555最后加入650,经过一个星期折腾,也装过寂寞版主的软件包,但最后没有用,主要是拿来熟悉650的功能,在此谢谢寂寞老大,让我在短时间内就体会到650的方便与快捷,其实对于系统稳定性而言,我更多的是在软件搭配试用结果上,而没有像搂主这样研究不稳定的过程,但是研究过程能让我们找到更好的结果,不是吗。0 M9 y- u  l; s/ D6 n; }$ R
5 ^5 k; J+ r4 U2 G! o0 {0 V/ |) ?
     我个人的使用经验是,不装破解或者少装破解软件,少装功能重复的软件,看个人需要了,比如我觉得系统自带的软件够用,我绝对不会去装一个比系统自带软件的功能多的,不追新,够用稳定就足够了,对于DA我只装一个,够用就可以,其实palm软件非常多,但重复功能太多,需要找到适合自己的稳定的,所以要折腾,其实很简单,估计这些凡是老胖熟悉的了,但希望对新人有用。* ]5 H+ f. n. z+ M( e' i

, {, e% l; ~" C1 n     之所以没有用寂寞老大的软件包,是我觉得重复功能太多,很多对我个人没必要,这里不是说寂寞老大的软件包不好,对于像没有时间折腾的胖友是很有帮助的,我也是因为寂寞老大的软件包才很块熟悉650的功能,查无的ROM我也刷了,因为个人觉得很适合我,在这之前我已经参考下的到的ROM,也花了点时间研究,我之前的机子,我都要刷的,主要也是一些个人觉得没用的,重复功能的,因为有现成的,就拿来用了,但是需要有一个适合稳定的系统,的确是需要折腾 ,开始使用palm的时候我有一个月天天都在折腾,一天要硬起n次,最后精简出自己需要稳定的一套来,这些估计也是废话了,呵呵( Z" U5 \$ a) v& s
5 `' e6 q7 j$ ?% p1 }; C  i2 e
    最后罗索几句,本人是专业潜水员,像我这类型还是比较多的,不要见怪。因为看了搂住的帖子,很值得佩服,因为650的不完美,所以我们要讨论,互相交流,所谓我为人人,人人为我,真体现了palm的精髓1 s/ `# O: _" Y% R# W1 h: j$ X0 U

6 n1 O- T+ e$ S$ O6 \( I[ 本帖最后由 smasher 于 2007-8-12 21:53 编辑 ]
发表于 2007-8-13 15:21 | 显示全部楼层
兄弟,那多的内容,你要他来这里要干什么呀,以后写的简单一点好不好
发表于 2007-8-13 16:10 | 显示全部楼层
慢慢嚼!
发表于 2007-8-14 22:12 | 显示全部楼层
嗯,很值得探讨。" N6 u/ K. b; b
rlock以前我也用了。那是在看了一片“四招打造最稳定650”(标题大概如此)的文章后装入了我的系统,但没见有什么好处。我的650本来较为稳定,装了后反而不稳,原因是我用了文中提到的DBCacheTool的清理DB的软件,设置了低于8M的DB空间后便自动清理,结果造成相当严重的后果:电话功能不稳定了,每每有电话冲进来就重启,害得我每次事后都向人解释:手机有问题。丢人,所以干脆把DBCacheTool和Rlck都删除了。
: s4 x/ c" o- y4 d7 r. Y! e8 Q' |
# l- g+ Q. O: b7 O, R现在回头想想,我锁的东西不少了(而且至今不明白该锁定哪些),但清理DB后电话功能总有问题,也许还有一个原因是我刷的rom是自己在查无版本的基础上再精减的,可能动了不该动的,造成了我的650清理DB后的问题。, \4 N) L8 [- D( ^. N4 l+ k
- j3 Q& A3 f+ F, q
部分同意色版的意见:就是每一部650可能都不一样,个体差异造成的问题千奇百怪,不具普遍性的问题确实难以找出病因,所以探讨起来有困难。这也是大家都把机子盘得稳定了就懒得再动的原因吧,并非大家都愿意闭门造车。
发表于 2007-8-15 15:20 | 显示全部楼层
我的650在刷了一个的简化版ROM——就是去掉了“欢迎”和“教程”这两个“浪费内存”的东东,结果到现在无法开启电话,一真提示“电力不足无法启动电话程序”
5 L" T; g3 J' x郁闷中!现在除打不开电话外,还直是很稳定!!!
您需要登录后才可以回帖 登录 | 加入我们

本版积分规则

QQ|Archiver|手机版|小黑屋|吹友吧 ( 京ICP备05078561号 )

GMT+8, 2024-11-3 04:12 , Processed in 0.372143 second(s), 21 queries .

Powered by Discuz! X3.5 Licensed

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表