当前位置:  编程技术>移动开发
本页文章导读:
    ▪Handler对象的Message运用        Handler对象的Message应用 知识点      接受子线程发送的消息数据,并用此消息数据配合主线程更新UI。      根据消息数据中的标识msg.what,分类处理相应的操作。   范例程序     为了让.........
    ▪ 兑现TextView在内容过多时自动滚动        实现TextView在内容过多时自动滚动 mTextView.setMovementMethod(ScrollingMovementMethod.getInstance());    <TextView android:text="TextView"     android:id="@+id/textView1"     android:layout_width="fill_parent"     android.........
    ▪ JAVA中String与StringBuffer 、StringBuilder的差别       JAVA中String与StringBuffer 、StringBuilder的区别 http://zbj2658.blog.163.com/blog/static/400952542010080834698/  String和StringBuffer的区别,网上资料可以说是数不胜数,但是看到这篇文章,感觉里面做的小例子很.........

[1]Handler对象的Message运用
    来源: 互联网  发布时间: 2014-02-18
Handler对象的Message应用

知识点

     接受子线程发送的消息数据,并用此消息数据配合主线程更新UI。

     根据消息数据中的标识msg.what,分类处理相应的操作。

 

范例程序

    为了让线程对象Runnable运行过程中,可以不断地将信息往Activity传递,所以用了Android.os.Handler对象及Android.os.Message对象,且在类成员变量中声明了两个整数:STOP_NOTIFIER与RUNNING_NOTIFIER,这两个整数将作为信息传递出来时的信号标识,前者为线程对象Runnable需要喊停的标识,后者为线程对象Runnable正在运行的标识。

    本范例中,摆放一个按钮和一个进度条控件。按钮用于复位参数和启动线程对象Runnable。

具体代码如下:

 

view plaincopy to clipboardprint?
  • package com.lyg.progressbarhandler;  
  •   
  • import android.app.Activity;  
  • import android.os.Bundle;  
  • import android.os.Handler;  
  • import android.os.Message;  
  • import android.util.Log;  
  • import android.view.View;  
  • import android.view.View.OnClickListener;  
  • import android.view.Window;  
  • import android.view.WindowManager;  
  • import android.widget.Button;  
  • import android.widget.ProgressBar;  
  •   
  • public class progressBarHandler extends Activity {  
  •     /** Called when the activity is first created. */  
  •     /* 自定义Handler信息代码,作为标识事件处理 */  
  •     protected static final int STOP_NOTIFIER = 0x108;//停止标识  
  •     protected static final int RUNNING_NOTIFIER = 0x109;//运行标识  
  •   
  •     private Button bnStart;  
  •     private ProgressBar progBar;  
  •       
  •     @Override  
  •     public void onCreate(Bundle savedInstanceState) {  
  •         super.onCreate(savedInstanceState);  
  •           
  •         //全屏显示  
  •         // 注:以下两行不可放在setContentView之后,否则报错。  
  •         requestWindowFeature(Window.FEATURE_NO_TITLE);  
  •         getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,  
  •                 WindowManager.LayoutParams.FLAG_FULLSCREEN);  
  •   
  •         setContentView(R.layout.main);  
  •   
  •         progBar = (ProgressBar) findViewById(R.id.progressbar);  
  •         bnStart = (Button) findViewById(R.id.bnstart);  
  •         bnStart.setOnClickListener(new bnStartOnClickListener());  
  •   
  •         // 初始化进度条控件  
  •         progBar.setProgress(0);  
  •   
  •     }  
  •       
  •     class bnStartOnClickListener implements OnClickListener{  
  •   
  •         @Override  
  •         public void onClick(View arg0) {  
  •             // TODO Auto-generated method stub  
  •             //线程调用跟踪  
  •             Log.d("lyg", "onClick-->id="+Thread.currentThread().getId()+" name="+Thread.currentThread().getName());  
  •               
  •             progBar.setProgress(0);//设置进度控件当前进度为0  
  •               
  •             //将线程对象runable放到消息队列中  
  •             handler.post(runable);  
  •         }  
  •     }  
  •       
  •     //Handler构建之后,会监听传来的消息  
  •     Handler handler=new Handler(){  
  •         @Override  
  •         public void handleMessage(Message msg) {  
  •             // TODO Auto-generated method stub  
  •             super.handleMessage(msg);  
  •             System.out.println("Handler handleMessage");  
  •             switch(msg.what)  
  •             {  
  •                 case STOP_NOTIFIER:  
  •                 {  
  •                     progBar.setProgress(msg.arg1);//设置进度控件的当前进度为msg.arg1  
  •                     handler.removeCallbacks(runable);//清除队列中的未执行的runable  
  •                 }  
  •                 break;  
  •                 case RUNNING_NOTIFIER:  
  •                 {  
  •                     progBar.setProgress(msg.arg1);//设置进度控件的当前进度为msg.arg1li
  • 相关
    • 1 Message跟handler传递对象
    • 2 pageContext对象的运用
    • 3 XMLHttpRequest对象的运用
    • 4 NotificationManager与Notification对象的运用
    • 5 handler处置message
    移动开发-热门移动开发-最新移动开发-其它
    • 1 十分难缠的signal 11 (SIGSEGV)
    • 2 Can't create handler inside thread that has not called Looper.prepare() 错误有关问题
    • 3 Dex Loader Unable to execute Multiple dex files define解决办法
    • 4 解决 Google Play下载施用 "Google Play Store 已停止运行&quot
    • 5 WAP网页获得用户的手机号码
    • 6 如何判断Activity是否在运行
    • 7 SlidingMenu+ViewPager兑现侧滑菜单效果
    • 8 makeKeyAndVisible的功用
    • 9 关于Unable to execute dex: Java heap space 解决方法
    • 10 RelativeLayout设置居中对齐有关问题
    • 1 播发声音文件AVAudioPlayer
    • 2 改变银屏显示方式已经加载图片
    • 3 2013-十-31 TCP/IP 协议簇
    • 4 Java I/零 总体框架图
    • 5 拿碗的铠甲勇者
    • 6 女友可能出轨 想知道在QQ和别人的聊天记录
    • 7 objective C中的字符串(3)
    • 8 java.lang.ClassNotFoundException: Didn't find class "Activity" on path: /da
    • 9 LG Optimus G Pro 相干
    • 10 怎么创建对话框
    • 1 视图切换的形式
    • 2 Tiledmap编辑操作技巧
    • 3 power键跟音量键组合实现截图功能
    • 4 Andriod耗时操作的处置(音乐播放器欢迎界面)
    • 5 用 lipo 下令裁剪出需要的 architecture
    • 6 疑惑为什么报错了
    • 7 深入viewgroup.onintercepttouchevent1点
    • 8 BroadcastReceiver要领
    • 9 实现默认文字统制的textview
    • 10 MGTemplateEngine模版发动机
    • 上一篇: 快活老/虎/机 海贼王版
    • 下一篇: 兑现TextView在内容过多时自动滚动


        
    [2] 兑现TextView在内容过多时自动滚动
        来源: 互联网  发布时间: 2014-02-18
    实现TextView在内容过多时自动滚动
    mTextView.setMovementMethod(ScrollingMovementMethod.getInstance());

        <TextView android:text="TextView"
        android:id="@+id/textView1"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:textSize="25dip"
        android:scrollbars="vertical"
        android:focusable="true"
        android:singleLine="false"
        android:clickable="true"
        android:textColor="#000000">
        </TextView>
     

        
    [3] JAVA中String与StringBuffer 、StringBuilder的差别
        来源: 互联网  发布时间: 2014-02-18
    JAVA中String与StringBuffer 、StringBuilder的区别

    http://zbj2658.blog.163.com/blog/static/400952542010080834698/ 

    String和StringBuffer的区别,网上资料可以说是数不胜数,但是看到这篇文章,感觉里面做的小例子很有代表性,所以转一下,并自己做了一点总结。

    在java中有3个类来负责字符的操作。

    1.Character 是进行单个字符操作的,

    2.String 对一串字符进行操作。不可变类。

    3.StringBuffer 也是对一串字符进行操作,但是可变类。

    String:
    是对象不是原始类型.
    为不可变对象,一旦被创建,就不能修改它的值.
    对于已经存在的String对象的修改都是重新创建一个新的对象,然后把新的值保存进去.
    String 是final类,即不能被继承.

    StringBuffer:
    是一个可变对象,当对他进行修改的时候不会像String那样重新建立对象
    它只能通过构造函数来建立,
    StringBuffer sb = new StringBuffer();
    note:不能通过付值符号对他进行付值.
    sb = "welcome to here!";//error
    对象被建立以后,在内存中就会分配内存空间,并初始保存一个null.向StringBuffer
    中付值的时候可以通过它的append方法.
    sb.append("hello");

    字符串连接操作中StringBuffer的效率要比String高:

    String str = new String("welcome to ");
    str += "here";
    的处理步骤实际上是通过建立一个StringBuffer,让侯调用append(),最后
    再将StringBuffer toSting();
    这样的话String的连接操作就比StringBuffer多出了一些附加操作,当然效率上要打折扣.

    并且由于String 对象是不可变对象,每次操作Sting 都会重新建立新的对象来保存新的值.
    这样原来的对象就没用了,就要被垃圾回收.这也是要影响性能的.

    看看以下代码:
    将26个英文字母重复加了5000次,

            String tempstr = "abcdefghijklmnopqrstuvwxyz";
            int times = 5000;
            long lstart1 = System.currentTimeMillis();
            String str = "";
            for (int i = 0; i < times; i++) {
                str += tempstr;
            }
            long lend1 = System.currentTimeMillis();
            long time = (lend1 - lstart1);
            System.out.println(time);
    可惜我的计算机不是超级计算机,得到的结果每次不一定一样一般为 46687左右。
    也就是46秒。
    我们再看看以下代码

            String tempstr = "abcdefghijklmnopqrstuvwxyz";
            int times = 5000;
            long lstart2 = System.currentTimeMillis();
            StringBuffer sb = new StringBuffer();
            for (int i = 0; i < times; i++) {
                sb.append(tempstr);
            }
            long lend2 = System.currentTimeMillis();
            long time2 = (lend2 - lstart2);
            System.out.println(time2);
    得到的结果为 16 有时还是 0
    所以结论很明显,StringBuffer 的速度几乎是String 上万倍。当然这个数据不是很准确。因为循环的次数在100000次的时候,差异更大。不信你试试。

    根据上面所说:

    str += "here";
    的处理步骤实际上是通过建立一个StringBuffer,让侯调用append(),最后
    再将StringBuffer toSting();

    所以str += "here";可以等同于

    StringBuffer sb = new StringBuffer(str);

    sb.append("here");

    str = sb.toString();

    所以上面直接利用"+"来连接String的代码可以基本等同于以下代码

            String tempstr = "abcdefghijklmnopqrstuvwxyz";
            int times = 5000;
            long lstart2 = System.currentTimeMillis();
            String str = "";
            for (int i = 0; i < times; i++) {
                StringBuffer sb = new StringBuffer(str);
                sb.append(tempstr);
                str = sb.toString();
            }
            long lend2 = System.currentTimeMillis();
            long time2 = (lend2 - lstart2);
            System.out.println(time2);
    平均执行时间为46922左右,也就是46秒。

    本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/yirentianran/archive/2008/09/03/2871417.aspx

    StringBuffer维护了一个大小固定的字符串缓冲区,当字符串长度超过StringBuffer大小时会自动增加,主要使用Insert和append方法,对于运行期要进行字符串的组装操作推荐使用,

             StringBuilder: jdk5以后有个和StringBuffer等价的StringBuider,区别在于StringBuffer是线程安全的,StringBuilder是单线程的,不提供同步,理论上效率更高。

            String是系统内置类型,而且是final的,定义一个字符串会产生一个实例和一个对该实例地址的引用。

            如果在编译期间定义的字符串,例如 :

                      String a = "name";
                      a += "is";
                      a += "good";

           尽管这种方法是不被推荐的,但在编译期,编译器会对该代码进行优化,所以还是可以理解为:String a = "name is good";而如果在此时采用StringBuffer,反而会推迟到运行期才会被处理,相比之下,反而会比StringBuffer效率更高,灵活运用。

    String 字符串常量
    StringBuffer 字符串变量(线程安全)
    StringBuilder 字符串变量(非线程安全)
     简要的说, String 类型和 StringBuffer 类型的主要性能区别其实在于 String 是不可变的对象, 因此在每次对 String 类型进行改变的时候其实都等同于生成了一个新的 String 对象,然后将指针指向新的 String 对象,所以经常改变内容的字符串最好不要用 String ,因为每次生成对象都会对系统性能产生影响,特别当内存中无引用对象多了以后, JVM 的 GC 就会开始工作,那速度是一定会相当慢的。
     而如果是使用 StringBuffer 类则结果就不一样了,每次结果都会对 StringBuffer 对象本身进行操作,而不是生成新的对象,再改变对象引用。所以在一般情况下我们推荐使用 StringBuffer ,特别是字符串对象经常改变的情况下。而在某些特别情况下, String 对象的字符串拼接其实是被 JVM 解释成了 StringBuffer 对象的拼接,所以这些时候 String 对象的速度并不会比 StringBuffer 对象慢,而特别是以下的字符串对象生成中, String 效率是远要比 StringBuffer 快的:
     String S1 = “This is only a” + “ simple” + “ test”;
     StringBuffer Sb = new StringBuilder(“This is only a”).append(“ simple”).append(“ test”);
     你会很惊讶的发现,生成 String S1 对象的速度简直太快了,而这个时候 StringBuffer 居然速度上根本一点都不占优势。其实这是 JVM 的一个把戏,在 JVM 眼里,这个
     String S1 = “This is only a” + “ simple” + “test”; 其实就是:
     String S1 = “This is only a simple test”; 所以当然不需要太多的时间了。但大家这里要注意的是,如果你的字符串是来自另外的 String 对象的话,速度就没那么快了,譬如:
    String S2 = “This is only a”;
    String S3 = “ simple”;
    String S4 = “ test”;
    String S1 = S2 +S3 + S4;
    这时候 JVM 会规规矩矩的按照原来的方式去做

    在大部分情况下 StringBuffer > String
    StringBuffer
    Java.lang.StringBuffer线程安全的可变字符序列。一个类似于 String 的字符串缓冲区,但不能修改。虽然在任意时间点上它都包含某种特定的字符序列,但通过某些方法调用可以改变该序列的长度和内容。
    可将字符串缓冲区安全地用于多个线程。可以在必要时对这些方法进行同步,因此任意特定实例上的所有操作就好像是以串行顺序发生的,该顺序与所涉及的每个线程进行的方法调用顺序一致。
    StringBuffer 上的主要操作是 append 和 insert 方法,可重载这些方法,以接受任意类型的数据。每个方法都能有效地将给定的数据转换成字符串,然后将该字符串的字符追加或插入到字符串缓冲区中。 append 方法始终将这些字符添加到缓冲区的末端;而 insert 方法则在指定的点添加字符。
    例如,如果 z 引用一个当前内容是“start”的字符串缓冲区对象,则此方法调用 z.append("le") 会使字符串缓冲区包含“startle”,而 z.insert(4, "le") 将更改字符串缓冲区,使之包含“starlet”。
    在大部分情况下 StringBuilder > StringBuffer
    java.lang.StringBuilde
    java.lang.StringBuilder 一个可变的字符序列是5.0新增的。此类提供一个与 StringBuffer 兼容的 API,但不保证同步。该类被设计用作 StringBuffer 的一个简易替换,用在字符串缓冲区被单个线程使用的时候(这种情况很普遍)。如果可能,建议优先采用该类,因为在大多数实现中,它比 StringBuffer 要快。两者的方法基本相同。
    通过非官方试验测试,StringBuilder和StringBuffer的测试总结如下:

    1.  为了获得更好的性能,在构造 StirngBuffer 或 StirngBuilder 时应尽可能指定它的容量。当然,如果你操作的字符串长度不超过 16 个字符就不用了。

    2.  相同情况下使用 StirngBuilder 相比使用 StringBuffer 仅能获得 10%~15% 左右的性能提升,但却要冒多线程不安全的风险。而在现实的模块化编程中,负责某一模块的程序员不一定能清晰地判断该模块是否会放入多线程的环境中运行,因此:除非你能确定你的系统的瓶颈是在 StringBuffer 上,并且确定你的模块不会运行在多线程模式下,否则还是用 StringBuffer 吧 J

    3.  用好现有的类比引入新的类更重要。很多程序员在使用 StringBuffer 时是不指定其容量的(至少我见到的情况是这样),如果这样的习惯带入 StringBuilder 的使用中,你将只能获得 10 %左右的性能提升(不要忘了,你可要冒多线程的风险噢);但如果你使用指定容量的 StringBuffer ,你将马上获得 45% 左右的性能提升,甚至比不使用指定容量的 StirngBuilder 都快 30% 左右。


        
    最新技术文章:
    ▪Android开发之登录验证实例教程
    ▪Android开发之注册登录方法示例
    ▪Android获取手机SIM卡运营商信息的方法
    ▪Android实现将已发送的短信写入短信数据库的...
    ▪Android发送短信功能代码
    ▪Android根据电话号码获得联系人头像实例代码
    ▪Android中GPS定位的用法实例
    ▪Android实现退出时关闭所有Activity的方法
    ▪Android实现文件的分割和组装
    ▪Android录音应用实例教程
    ▪Android双击返回键退出程序的实现方法
    ▪Android实现侦听电池状态显示、电量及充电动...
    ▪Android获取当前已连接的wifi信号强度的方法
    ▪Android实现动态显示或隐藏密码输入框的内容
    ▪根据USER-AGENT判断手机类型并跳转到相应的app...
    ▪Android Touch事件分发过程详解
    ▪Android中实现为TextView添加多个可点击的文本
    ▪Android程序设计之AIDL实例详解
    ▪Android显式启动与隐式启动Activity的区别介绍
    ▪Android按钮单击事件的四种常用写法总结
    ▪Android消息处理机制Looper和Handler详解
    ▪Android实现Back功能代码片段总结
    ▪Android实用的代码片段 常用代码总结
    ▪Android实现弹出键盘的方法
    ▪Android中通过view方式获取当前Activity的屏幕截...
    ▪Android提高之自定义Menu(TabMenu)实现方法
    ▪Android提高之多方向抽屉实现方法
    ▪Android提高之MediaPlayer播放网络音频的实现方法...
    ▪Android提高之MediaPlayer播放网络视频的实现方法...
    ▪Android提高之手游转电视游戏的模拟操控
     


    站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3