J2ME系列学习(四)
2005-10-07 20:36
369 查看
1 系统参数的提取MIDlet在运作时,必须通过java.lang.System.getProperty()函数在取得系统属性。我们可以通过一些系统属性了解MIDlet身处的环境相关信息,如下:① microedition.profiles:取得系统支持的所有Profile信息。② microedition.configuration:取得系统所支持的Configuration信息。③ microedition.locale:取得系统目前所使用的地区信息。④ microedition.platform:MIDlet所在平台(或机器)的名称或型号。⑤ microedition.encoding:取得系统缺省使用的语言编码信息。 2 字符串的转换通过上述方法所取得的清单文件或描述文件之中属性的属性值都视为字符串,如果我们要做运算则要转换一下才行。字符串转换成数值:用java.lang中的Byte、Short、Integer、Long四个类中的parseXXX()方法。CLDC1.0不支持浮点数,CLDC1.1开始支持浮点数。
3 随机数Java.util包中有个Random类,负责用来产生随机数(只能是int或long类型的随机数)。可以使用Random rnd = new Random(seedvalue) 或者也可以用Random rdm = new Random() ;这个构造函数会在内部调用this(System.currentTimeMillis());它会根据当时的时间设定随机数种子。任何时候我们都可以调用setSeed()来设定随机数种子。
我们还可以利用其nextInt()来产生int类型的随机数,nextLong()来产生long类型的随机数。
4 执行时间的测量
当MIDlet运作时,随时都可以利用System.currentTimeMillis()来取得目前时间与1970年1月1日零时 UTC时间(协调世界时)的差距,传回值为long类型,而且以毫秒(Millisecond,千分之一秒)来表示。程序任何两个地方调用System.currentTimeMillis()之后,将所得的结果相减,就是所经过的毫秒数。
5 日期处理
java.util包之中,Calendar、Date、TimeZone是三个用来处理与日期相关功能的类。TimeZone类所代表的是时区,全球的统一时间称做UTC(协调世界时),也就是说,在全世界任何时间点上,时间的表示都一样,美国UTC时间10点就是台湾UTC时间10点整。全世界以格林尼治时间(GMT)为主,所以GMT与UTC是没有时间差的。其它时区都会和GMT或UTC有个时间差。所以如果以时区来分的话,每个时区相同的时间有可能是不同的UTC。
Date类负责记录与1970年1月1日零时 UTC时间(协调世界时<
da7d
/span>)的差距,一般我们可以使用Date date = new Date(time) ;来产生,time就是与1970年1月1日零时 UTC时间(协调世界时)的差距,以毫秒来计。如果使用Date date = new Date() 来产生Date类,就如同调用了Date date = new Date(System.currentTimeMillis()) ;也就是Date会封装进行new操作时的时间。Date类本身除了以毫秒存放与1970年1月1日零时 UTC时间(协调世界时)的差距外,本身没有其它功能了。要从Date类解析出正确的年、月、日、星期几、几点、几分、几秒的信息,就必须依靠Calendar类才行。
Calendar无法用new产生,只能通过Calendar.getInstance()取得使用系统缺省时区与地区所建立的Calendar,或使用Calendar.getInstance(TimeZone tz),指定我们要使用的时区来产生Calendar。所以调用Calendar.getInstance(),实际上等同于调用Calendar.getInstance(TimeZone.getDefault())。
有了Calendar的实体之后,我们就可以利用其setTime()给定一个Date对象的实体,或是setTimeMillis()给定一个long类型的数值来设定Calendar的内容。
6 Theard的注意事项
(1)Thread的建立有两种方法,第一是直接继承Thread类,并实现其run()方法,这是上述范例所使用的方式。第二种是实现Runnable接口,并实现其run()方法。这两种方法请参阅一般讲解Java程序语言的书,都会有详尽的说明。一般建议使用第二种方法,但是第一种方法比较简单。
(2)启动Thread时,请调用其start()方法。切莫因为实现run()方法就直接调用run(),否则无法达到多线程执行的效果。
(3)要结束一个Thread的执行,请利用自己定义的旗标(flag)。当外头设定此旗标时,Thread自动离开run()方法,此时就会造成Thread结束。虽然在J2SE之中的Thread类有stop()方法可以结束Thread的执行,但是这个方法也已经被列为不建议使用(deprecated)的方法。
7 Timer与TimerTask
java.util包之中有两个类与工作排程非常有关系,它们分别是Timer与TimerTask。其中,Timer是一个定时器,可以设定成特定时间或特定时间周期产生信号。不过,只有Timer是没有用的,必须配合TimerTask才有作用。Timer一旦与某个TimerTask产生关联,就会在产生信号的同时,连带执行TimerTask所定义的工作。
TimerTask的制作非常容易,任何一个类只要继承TimerTask类,并实现其run()方法即可。Run()方法就是我们自行定义的工作,一旦Timer在特定时间或特定时间周期产生信号,run()方法就会被执行。我们会通过Timer的schedule()方法来设定特定时间或特定时间周期,并将它与某个TimerTask联系(进行TimerTask的排程)。最后,可以使用Timer的cancel()方法来停止Timer,调用cancel()之后,Timer就会和TimerTask脱离关系。TimerTask本身也有cancel()方法。
3 随机数Java.util包中有个Random类,负责用来产生随机数(只能是int或long类型的随机数)。可以使用Random rnd = new Random(seedvalue) 或者也可以用Random rdm = new Random() ;这个构造函数会在内部调用this(System.currentTimeMillis());它会根据当时的时间设定随机数种子。任何时候我们都可以调用setSeed()来设定随机数种子。
我们还可以利用其nextInt()来产生int类型的随机数,nextLong()来产生long类型的随机数。
4 执行时间的测量
当MIDlet运作时,随时都可以利用System.currentTimeMillis()来取得目前时间与1970年1月1日零时 UTC时间(协调世界时)的差距,传回值为long类型,而且以毫秒(Millisecond,千分之一秒)来表示。程序任何两个地方调用System.currentTimeMillis()之后,将所得的结果相减,就是所经过的毫秒数。
5 日期处理
java.util包之中,Calendar、Date、TimeZone是三个用来处理与日期相关功能的类。TimeZone类所代表的是时区,全球的统一时间称做UTC(协调世界时),也就是说,在全世界任何时间点上,时间的表示都一样,美国UTC时间10点就是台湾UTC时间10点整。全世界以格林尼治时间(GMT)为主,所以GMT与UTC是没有时间差的。其它时区都会和GMT或UTC有个时间差。所以如果以时区来分的话,每个时区相同的时间有可能是不同的UTC。
Date类负责记录与1970年1月1日零时 UTC时间(协调世界时<
da7d
/span>)的差距,一般我们可以使用Date date = new Date(time) ;来产生,time就是与1970年1月1日零时 UTC时间(协调世界时)的差距,以毫秒来计。如果使用Date date = new Date() 来产生Date类,就如同调用了Date date = new Date(System.currentTimeMillis()) ;也就是Date会封装进行new操作时的时间。Date类本身除了以毫秒存放与1970年1月1日零时 UTC时间(协调世界时)的差距外,本身没有其它功能了。要从Date类解析出正确的年、月、日、星期几、几点、几分、几秒的信息,就必须依靠Calendar类才行。
Calendar无法用new产生,只能通过Calendar.getInstance()取得使用系统缺省时区与地区所建立的Calendar,或使用Calendar.getInstance(TimeZone tz),指定我们要使用的时区来产生Calendar。所以调用Calendar.getInstance(),实际上等同于调用Calendar.getInstance(TimeZone.getDefault())。
有了Calendar的实体之后,我们就可以利用其setTime()给定一个Date对象的实体,或是setTimeMillis()给定一个long类型的数值来设定Calendar的内容。
6 Theard的注意事项
(1)Thread的建立有两种方法,第一是直接继承Thread类,并实现其run()方法,这是上述范例所使用的方式。第二种是实现Runnable接口,并实现其run()方法。这两种方法请参阅一般讲解Java程序语言的书,都会有详尽的说明。一般建议使用第二种方法,但是第一种方法比较简单。
(2)启动Thread时,请调用其start()方法。切莫因为实现run()方法就直接调用run(),否则无法达到多线程执行的效果。
(3)要结束一个Thread的执行,请利用自己定义的旗标(flag)。当外头设定此旗标时,Thread自动离开run()方法,此时就会造成Thread结束。虽然在J2SE之中的Thread类有stop()方法可以结束Thread的执行,但是这个方法也已经被列为不建议使用(deprecated)的方法。
7 Timer与TimerTask
java.util包之中有两个类与工作排程非常有关系,它们分别是Timer与TimerTask。其中,Timer是一个定时器,可以设定成特定时间或特定时间周期产生信号。不过,只有Timer是没有用的,必须配合TimerTask才有作用。Timer一旦与某个TimerTask产生关联,就会在产生信号的同时,连带执行TimerTask所定义的工作。
TimerTask的制作非常容易,任何一个类只要继承TimerTask类,并实现其run()方法即可。Run()方法就是我们自行定义的工作,一旦Timer在特定时间或特定时间周期产生信号,run()方法就会被执行。我们会通过Timer的schedule()方法来设定特定时间或特定时间周期,并将它与某个TimerTask联系(进行TimerTask的排程)。最后,可以使用Timer的cancel()方法来停止Timer,调用cancel()之后,Timer就会和TimerTask脱离关系。TimerTask本身也有cancel()方法。
相关文章推荐
- 【J2me3D系列学习文章之三】(立即模式)对立方体进行变换操作-旋转、缩放、平移
- 【J2me 2D 游戏开发系列】Himi游戏开发J零基础学习历程
- J2ME学习之Nokia系列手机介绍—S40、S60和S90系列J2ME学习之Nokia系列手机介绍—S40、S60和S90系列
- J2ME系列学习(三)
- 【J2me3D系列学习文章之二】(立即模式)构造我们3D世界中的第一个立方体!
- 【J2me3D系列学习文章之二】(立即模式)构造我们3D世界中的第一个立方体!
- 【J2me3D系列学习文章之二】(立即模式)构造我们3D世界中的第一个立方体!
- 【J2me3D系列学习文章之一】J2me3D开发技术和基础知识
- 【J2me3D系列学习文章之一】J2me3D开发技术和基础知识
- J2ME系列学习(二)
- 【J2me3D系列学习文章之一】J2me3D开发技术和基础知识
- 【J2me3D系列学习文章之三】(立即模式)对立方体进行变换操作-旋转、缩放、平移
- 【J2me 2D 游戏开发系列】◣Himi游戏开发启蒙教程◢Java零基础学习J2me游戏开发全过程!
- J2ME学习之Nokia系列手机介绍—S40、S60和S90系列
- 【J2me3D系列学习文章之三】(立即模式)对立方体进行变换操作-旋转、缩放、平移
- J2ME系列学习(一)
- ios开发学习--cocos2d(cocos2d)效果源码分享--系列教程
- MEF学习系列笔记系列(1)
- 【从零学习经典算法系列】分治策略实例——归并排序(Mergesort)
- 深度学习与计算机视觉系列(1)_基础介绍