import java.util.date;
import net.rim.device.api.system.eventlogger;
/**
* 日志类
* @author 2010-09-04
*
*/
public class logger {
private static final string separator = " ";
private static final long guid = 0x4c9d3452d880a2f1l;
private static final string app_name = "xxxc ";
private logger() {
eventlogger.register(guid, app_name, eventlogger.viewer_string);
}
private static logger logger = new logger();
public static logger getlogger() {
return logger;
}
/**
* log the information.
*
* @param message
* the message you will log
*/
public void info(string message) {
if (message == null || message.trim().equals(""))
return;
string log = "info: " new date().tostring() separator message;
try {
log = new string(log.getbytes(), "utf-8");
byte[] msg_bytes = log.getbytes();
eventlogger.logevent(guid, msg_bytes, eventlogger.always_log);
} catch (exception ex) {
system.err.println(ex);
}
}
public void error(exception e) {
stringbuffer log = new stringbuffer();
log.append("error: " new date().tostring() separator);
log.append(e.getmessage() " \r\n ");
try {
byte[] msg_bytes = new string(log.tostring().getbytes(), "utf-8").getbytes();
eventlogger.logevent(guid, msg_bytes);
} catch (exception ex) {
system.err.println(ex);
}
}
public void error(string message, exception e) {
stringbuffer log = new stringbuffer();
log.append("error: " new date().tostring() separator);
if (message != null || !message.trim().equals("")) {
log.append("message: " message " \r\n ");
}
log.append("error: " e.getmessage() " \r\n ");
try {
byte[] msg_bytes = new string(log.tostring().getbytes(), "utf-8").getbytes();
eventlogger.logevent(guid, msg_bytes);
} catch (exception ex) {
system.err.println(ex);
}
}
}
不管是在模拟器还是真机,日志还是必须的......如果该文对你有用,为了表示对作者的支持,麻烦你单击一下下面的广告,谢谢
locate(substr,str)
locate也是返回字符串的位置,但locate函数,子字符串在前面。activity
intent receiver
service
content provider
当我们明确了我们的应用需要哪些构造块后,我们就需要在androidmanifest.xml中登记这些构造块的清单。这是一个xml配置文件,这个配置文件用于定义我们的应用程序的组件、组件的功能及必要条件等。这个配置文件是每个android应用必需的。对于androidmainfest.xml的schema,参考sdk包附带的文档。以下,我们对四种构造块做一些说明:
一、activity
activity是android构造块中最基本的一种,在应用中,一个activity通常就是一个单独的屏幕。每一个activity都被实现为一个独立的类,并且继承于activity这个基类。这个activity类将会显示由几个views控件组成的用户接口,并对事件做出响应。大部份的应用都会包含多个的屏幕。例如,一个短消息应用程序将会有一个屏幕用于显示联系人列表,第二个屏幕用于写短消息,同时还会有用于浏览旧短消息及进行系统设置的屏幕。每一个这样的屏幕,就是一个activity。从一个屏幕导航到另一个屏幕是很简单的。在一些应用中,一个屏幕甚至会返回值给前一个屏幕。
当一个新的屏幕打开后,前一个屏幕将会暂停,并保存在历史堆栈中。用户可以返回到历史堆栈中的前一个屏幕。当屏幕不再使用时,还可以从历史堆栈中删除。默认情况下,android将会保留从主屏幕到每一个应用的运行屏幕。
android使用了intent这个特殊类,实现在屏幕与屏幕之间移动。intent类用于描述一个应用将会做什么事。在intent的描述结构中,有两个最重要的部分:动作和动作对应的数据。典型的动作类型有:main(activity的门户)、view、pick、edit等。而动作对应的数据则以uri的形式进行表示。例如:要查看一个人的凯发天生赢家一触即发官网的联系方式,你需要创建一个动作类型为view的intent,以及一个表示这个人的uri。
与之有关系的一个类叫intentfilter。相对于intent是一个有效的做某事的请求,一个intent filter则用于描述一个activity(或者intent receiver)能够操作哪些intent。一个activity如果要显示一个人的凯发天生赢家一触即发官网的联系方式时,需要声明一个intentfilter,这个intentfilter要知道怎么去处理view动作和表示一个人的uri。intentfilter需要在androidmanifest.xml中定义。
通过解析各种intent,从一个屏幕导航到另一个屏幕是很简单的。当向前导航时,activity将会调用startactivity(intent myintent)方法。然后,系统会在所有安装的应用程序中定义的intentfilter中查找,找到最匹配myintent的intent对应的activity。新的activity接收到myintent的通知后,开始运行。当startactivity方法被调用将触发解析myintent的动作,这个机制提供了两个关键好处:
a、activities能够重复利用从其它组件中以intent的形式产生的一个请求;
b、activities可以在任何时候被一个具有相同intentfilter的新的activity取代。
二、intent receiver
当你希望你的应用能够对一个外部的事件(如当电话呼入时,或者数据网络可用时,或者到了晚上时)做出响应,你可以使用一个intent receiver。虽然intent receiver在感兴趣的事件发生时,会使用notificationmanager通知用户,但它并不能生成一个ui。intent receiver在androidmanifest.xml中注册,但也可以在代码中使用context.registerreceiver()进行注册。当一个intent receiver被触发时,你的应用不必对请求调用intent receiver,系统会在需要的时候启动你的应用。各种应用还可以通过使用context.broadcastintent()将它们自己的intent receiver广播给其它应用程序。
三、service
一个service是一段长生命周期的,没有用户界面的程序。比较好的一个例子就是一个正在从播放列表中播放歌曲的媒体播放器。在一个媒体播放器的应用中,应该会有多个activity,让使用者可以选择歌曲并播放歌曲。然而,音乐重放这个功能并没有对应的activity,因为使用者当然会认为在导航到其它屏幕时音乐应该还在播放的。在这个例子中,媒体播放器这个activity会使用context.startservice()来启动一个service,从而可以在后台保持音乐的播放。同时,系统也将保持这个service一直执行,直到这个service运行结束。另外,我们还可以通过使用context.bindservice()方法,连接到一个service上(如果这个service还没有运行将启动它)。当连接到一个service之后,我们还可以service提供的接口与它进行通讯。拿媒体播放器这个例子来说,我们还可以进行暂停、重播等操作。
四、content provider
应用程序能够将它们的数据保存到文件中、sql数据库中,甚至是任何有效的设备中。当你想将你的应用数据与其它的应用共享时,content provider将会很有用。一个content provider类实现了一组标准的方法,从而能够让其它的应用保存或读取此content provider处理的各种数据类型。
更详细的content provider资料,可以参考附带文档中的accessing content providers。
五、intent类
intent负责对应用中一次操作的动作、动作涉及数据、附加数据进行描述,android则根据此intent的描述,负责找到对应的组件,将 intent传递给调用的组件,并完成组件的调用。因此,intent在这里起着一个媒体中介的作用,专门提供组件互相调用的相关信息,实现调用者与被调 用者之间的解耦。