当前位置:  编程技术>移动开发
本页文章导读:
    ▪htc one v root 课程        htc one v root 教程 1 ,下载 Primo-superboot.zip 解压并启动 cmd 进入该目录 2 ,进入 fastboot 模式 以调试模式连接手机 使手机进入 fastboot 模式 adb reboot-bootloader 或者按音量 - 和电源键 3 ,用 supe.........
    ▪ java核心技术小结八-多线程        java核心技术总结八--多线程 1、多线程程序在较低的层次上扩展了多任务的概念: 一个程序同时执行多个任务。通常,每一个任务称为一个线程,它是线程控制的简称。可以同时运行一个以.........
    ▪ 模拟鼠标事件(二)       模拟鼠标事件(2) 这周继续一下那个模拟鼠标的那个问题。(这周不是什么经验总结,而是问题的描述,希望知道原因的人请回答哈 )   现象描述:   step1:创建一个activity(TestActivity) s.........

[1]htc one v root 课程
    来源: 互联网  发布时间: 2014-02-18
htc one v root 教程

1 ,下载 Primo-superboot.zip

解压并启动 cmd 进入该目录

2 ,进入 fastboot 模式

以调试模式连接手机

使手机进入 fastboot 模式

adb reboot-bootloader

或者按音量 - 和电源键

3 ,用 superboot 启动手机

Superboot 是开启 root 功能的系统镜像,以该系统镜像启动后手机以 root 模式运行,该操作不会刷写手机 flash, 只会下载到内存,下次启动就正常了

fastboot-windows.exe boot boot.superboot.img

这个superboot只是root的时候临时启动一次并不影响以后使用,该内核并不能完美支持one v正常运行,网上流传一键root用的应该也是superboot,所有很多问题

4 , root 手机

打开 supersu 并更新 SU binary

5 ,安装 supersu

重启手机

安装 supersu的apk包


    
[2] java核心技术小结八-多线程
    来源: 互联网  发布时间: 2014-02-18
java核心技术总结八--多线程

1、多线程程序在较低的层次上扩展了多任务的概念: 一个程序同时执行多个任务。通常,每一个任务称为一个线程,它是线程控制的简称。可以同时运行一个以上线程的程序称为多线程程序。

2、 每个进程拥有自己的 一整套变量,而线程则共享数据。共享变量使线程之间的通信比进程之间的通信更有效,更容易。

3、sleep方法是Thread类的静态方法,用于暂停当前线程的活动,调用Thread.sleep()方法不会创建一个新线程。

4、并行运行多个任务的操作:

1)、将任务代码移到实现了Runnable接口的类的run方法中

2)、创建一个类对象

3)、由Runnable创建一个Thread对象

4)、启动线程

5、interrupt 、interrupted 和isInterrunpted的区别:

interrupt方法是向线程发送中断请求,线程的中断状态将被设置为true;

interrupted方法是一个静态方法,它检测当前的线程是否被中断,而且调用interrupted方法会清除该线程的中断状态.它将当前线程的中断状态重置为false;

isInterrupted方法是一个实例方法,可以用来检验是否有线程被中断,调用这个方法不会改变中断状态

6、线程状态:

new(新生)  用new thread()创建一个新线程

runnable(可运行) 一旦调用start()方法,线程就处于runnable状态

blocked(被阻塞)

waiting(等待)

Timed waiting(计时等待)

当线程处于被阻塞或者等待状态时,它暂时不活动,它不运行任何代码且消耗最少的资源,直到线程调度器重新激活它。

当一个线程试图获取一个内部的对象锁,而该锁被其他线程持有,则该线程进入阻塞状态;

当线程等待另一个线程通知调度器一个条件时,它自己进入等待状态。

有几个方法有一个超时参数,调用它们导致线程进入计时等待状态。这一状态将一直保持直到超时期满或者接受到适当的通知。带有超时参数的方法有:Thread.sleep,Object.wait,Thread.join,Lock.tryLock,Condition.await


Terminated(被终止)

线程被终止的原因:

1)、因为run方法正常退出而自然死亡

2)、因为一个没有捕获的异常终止了run方法而意外死亡

7、线程属性:

1)、线程优先级:优先级顺序是从1到10;

2)、守护线程: 其唯一的好处是为其他线程提供服务;

3)、线程组:

线程组类实现Thread.UncaughtExceptionHandler接口。它的uncaughtException方法做如下操作:

(1)、如果该线程组有父线程,则父线程组的uncaughtException方法被调用;

(2)、否则,如果Thread.getDefaultExceptionHandler方法返回一个非空的处理器,则调用该处理器;

(3)、否则,如果Throwable是ThreadDeath的一个实例,什么都不做;

(4)、否则,线程的名字以及Throwable的栈踪迹被输出到System.err上;

4)、处理未捕获异常的处理器

8、同步

8.1、锁对象:ReentrantLock类对象。

     每一个对象有自己的ReentrantLock对象,如果两个线程试图访问同一个对象,那么锁以串行的方式提供服务。

     锁是可重入的,因为线程可以重复的获得已经持有的锁。锁保持一个持有技术来跟踪 对lock方法的嵌套调用。线程在每一个调用lock都要调用unlock来释放锁。

8.2、条件对象:通常线程进入临界区,却发现在某一条件满足之后它才能执行,要使用一个条件对象来管理那些已经获得了一个锁但是却不能做有用工作的线程。条件对象经常被称为条件变量。

    一个锁对象可以有一个或多个相关的条件对象,可以用newCondition方法获得一个条件对象。当方法的条件不能满足时,当前线程被阻塞,并放弃了锁。等待获得锁的线程和调用await方法的线程存在本质上的区别。一旦一个线程调用await方法,它进入该条件的等待集。当锁可用时,该线程不能马上解除阻塞。相反,它处于阻塞状态,直到另一个线程调用同一个条件上的signalAll方法时为止。

   当一个线程调用await时,它没有办法重新激活自身。在对象的状态有利于等待线程的方向改变时调用signalAll。signalAll不会立即激活一个等待线程,它仅仅解除等待线程的阻塞。

  当一个线程拥有某个条件的锁时,它仅仅可以在该条件上调用await,signalAll 或signal方法。

9、锁和条件的关键之处:

1)、锁用来保护代码片段,任何时刻只能有一个线程执行被保护的代码

2)、锁可以管理试图进入被保护代码段的线程

3)、锁可以拥有一个或多个相关的条件对象

4)、每个条件对象管理那些已经进入被保护的代码段但还不能运行的线程。

10、synchronized关键字

      如果一个方法用synchronized关键字声明,那么对象的锁将保护整个方法。这个锁也被称为内部对象锁,它只有一个相关条件。wait方法添加一个线程到等待集中,notify/notifyAll方法解除等待线程的阻塞状态。

   wait、notifyAll以及notify方法是Object类的final方法,它和Condition类的方法await、signalAll和signal功能类似。

   内部锁和条件存在一些局限性:

   1)、不能中断一个正在试图获得锁的线程;

   2)、试图获得锁时不能设定超时;

   3)、每个锁仅有单一的条件,可能是不够的。

11、 使用synchronized和 lock/condition的建议:

1、最好既不用用lock/condition也不要使用synchronized关键字。在许多情况下可以使用java.util.concurrent包中的一种机制,它会处理所有的加锁。

2、如果synchronized关键字适合你的程序,则尽量使用它,这样可以减少编写的代码数量,减少出错的几率。

3、如果特别需要lock/condition结构提供的独有特性时,才使用lock/condition.

12、同步阻塞

同步阻塞是另外一种获得锁的方式。

有时程序员使用一个对象的锁来实现额外的原子操作,实际上称为客户端锁定。客户端锁定是非常脆弱的,通常不推荐使用。

13、监视器

1、监视器具有的特性有:

    监视器是只包含私有域的类

    每个监视器类的对象有一个相关的锁

    使用该锁对所有的方法进行加锁

    该锁可以有任意多个相关条件

2、java对象不同于监视器的方面:

     域不要求必须是private

    方法不要求必须是synchronized

    内部锁对客户是可用的

14、同步格言:

如果向一个变量写入值,而这个变量接下来可能会被另外一个线程读取,或者,从一个变量读取,而这个变量可能是之前被另一个线程写入的,此时必须使用同步。

15、volatile

volatile关键字为实例域的同步访问提供了一种免锁机制,如果声明一个域为volatile,则编译器和虚拟机就知道该域是可能被另外一个线程并发更新的。

volatile变量不能提供原子性

16、域的并发访问是安全的条件:

    域是final,并且在构造器调用完成之后被访问

    对域的访问由公有的锁进行保护

    域是volatile的

17、锁测试和超时

tryLock方法试图申请一个锁,在成功获得锁后返回true。否则返回false。tryLock允许程序打破死锁。

18、读写锁

使用读/写锁的必要步骤:

构造一个ReentrantReadWriteLock对象;

抽取读锁和写锁;

对所有的访问者加读锁;

对所有的修改者加写锁;写者线程必须是互斥访问的。

19、stop和suspend方法被弃用的原因

    stop方法天生就不安全,该方法会终止所有未结束的方法,包括run方法。当线程被终止,立即释放它锁住的所有对象的锁。

suspend不会破坏对象,但是很容易造成死锁。但是如果用suspend挂起一个持有一个锁的线程,则该锁在恢复之前是不可用的。如果调用suspend方法的线程试图获得同一个锁,则程序死锁。被挂起的线程等着被恢复,而将其挂起的线程等待获得锁。

20、阻塞队列

阻塞队列的几个变种:

LinkedBlockingQueue: 容量没有上边界,但是可以选择指定最大容量。它是一个双端的版本。

ArrayBlockingQueue:在构造时需要指定容量,并且有一个可选的参数来指定是否需要公平性。

PriorityBlockingQueue: 它是一个带优先级的队列,而不是先进先出队列。元素按照它们的优先级顺序被移出。该队列的容量没有上界。

DelayQueue

阻塞队列的方法:

add         添加一个元素。                      如果队列满,则抛出异常

element  返回队列的头元素。                 如果队列空,抛出NoSuchElementException异常

offer        添加一个元素并返回true。       如果队列满,返回false

peek       返回队列的头元素。                 如果队列空,则返回null

poll         移出并返回队列的头元素。        如果队列空,则返回null

put         添加一个元素。                       如果队列满,则阻塞

remove   移出并返回头元素。                如果队列空,则抛出异常

take        移出并返回头元素。                如果队列空,则阻塞


poll和peek方法返回空来指示失败,因此向这些队列中插入null值是非法的。

21、线程安全的集合

java.util.concurrent包提供了映像、有序集和队列的高效实现: ConcurrentHashMap、ConcurrentSkipListMap、

ConcurrentLinkedQueue 。这些集合使用复杂的算法,通过允许并发的访问数据结构不同的部分来使竞争极小化。集合返回弱一致性的迭代器。

并发的散列映像表,可高效的支持大量的读者和一定数量的写者。默认情况下,假定可以有多达16个写者线程同时执行。

ConcurrentHashMap和ConcurrentSkipListMap类有相应的方法用于原子性的关联插入以及关联删除。putIfAbsent方法自动地添加新的关联,前提是原来没有这一关联。

22、写数据的拷贝

CopyOnWriteArrayList和CopyOnWriteArraySet是线程安全的集合,其中所有的修改线程对底层数组进行复制。

23、旧的线程安全的集合

Vector和Hashtable类提供了线程安全的动态数组和散列表的实现。在java1.2中,这些类被弃用了,取而代之的是ArrayList和HashMap类。这些类不是线程安全的,而集合库中提供了不同的机制。任何集合类通过使用同步包装器变成线程安全的。

24、执行器

使用线程池的理由:

1、构建一个新的线程是有一定代价的,因为涉及与操作系统的交互。如果程序中创建了大量的生命期很短的线程,应该使用线程池。一个线程池中包含许多准备运行的空闲线程。当Runnable对象交给线程池,就会有一个线程调用run方法。当run方法退出时,线程不会死亡,而是在池中准备为下一个请求提供服务。

2、减少并发线程的数目

25、执行者工厂方法

方法                                             描述

newCachedThreadPool       必要时创建新线程,空闲线程会被保留60秒

newFixedThreadPool   该池包含固定数量的线程,空闲线程会一直被保留

newSingleThreadExecutor  只有一个线程的"池",该线程顺序执行每一个提交的任务

newScheduledThreadPool   用于预定执行而构建的固定线程池,替代java.util.Timer

newSingleThreadScheduledExecutor   用于预定执行而构建的单线程"池"

26、在使用线程池时应该做的事情:

1)、调用Executors类中静态的方法newCachedThreadPool或newFixedThreadPool

2)、调用submit提交Runnable或callable对象

3)、如果想要取消一个任务,或如果提交Callable对象,那就要保存好返回的Future对象

4)、当不再提交任何任务时,调用shutdown。

27、同步器

1)、fly信号量

2)、倒计时门栓

3)、障栅

4)、交换器。当两个线程在同一个数据缓冲区的两个实例上工作的时候,就可以使用交换器。典型的情况是:一个线程向缓冲区填入数据,另一个线程消耗这些数据。当它们都完成以后,相互交换缓冲区。

5)、同步队列。它是一种将生产者与消费者线程配对的机制。当一个线程调用SynchronousQueue的put方法时,它会阻塞直到另一个线程调用take方法为止。







    
[3] 模拟鼠标事件(二)
    来源: 互联网  发布时间: 2014-02-18
模拟鼠标事件(2)

这周继续一下那个模拟鼠标的那个问题。(这周不是什么经验总结,而是问题的描述,希望知道原因的人请回答哈 )

 

现象描述:

 

step1:创建一个activity(TestActivity)

step2:创建一个Dialog(TestDialog)

 

在Dialog里获取WindowManager,添加一个ImageView在Window上

 

testManager = getWindow().getWindowManager();
testImageView = new ImageView(getContext());
testImageView.setBackgroundResource(R.drawable.test);
testParams = new WindowManager.LayoutParams(100, 100,
				WindowManager.LayoutParams.TYPE_TOAST,
				WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE
						| WindowManager.LayoutParams.FLAG_NOT_TOUCHABLE,
				PixelFormat.TRANSLUCENT);
testParams.gravity = Gravity.CENTER;
testManager.addView(testImageView, testParams);
 

 

step3:在TestActivity里显示TestDialog

 

testDialog=new TestDialog();
testDialog.show(); 

 

在sdk2.2的基础上:

只显示ImageView

 

在sdk4.0的基础上:

显示Dialog和ImageView

 

 

以上就是问题的描述,目前还不知原因是什么,知道者请告知哈,小女子先谢过了!!!

如果觉得问题描述的还不是很清楚的,可以问我咱们继续讨论哈。

1 楼 nanapoleon 2012-06-05  
你是说show的时候吧,具体要看代码,不过,从你实现的例子上来看,你的代码,如果加在Dialog里面的话,只是说在显示dialog的同时还要显示你这个imageview。如果你只是想在activity中显示你这个view,没必要集成在dialog里面嘛。

    
最新技术文章:
▪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