Java Doc for Utils.java in  » Library » Apache-beehive-1.0.2-src » org » apache » beehive » netui » util » internal » concurrent » Java Source Code / Java DocumentationJava Source Code and Java Documentation

Java Source Code / Java Documentation
1. 6.0 JDK Core
2. 6.0 JDK Modules
3. 6.0 JDK Modules com.sun
4. 6.0 JDK Modules com.sun.java
5. 6.0 JDK Modules sun
6. 6.0 JDK Platform
7. Ajax
8. Apache Harmony Java SE
9. Aspect oriented
10. Authentication Authorization
11. Blogger System
12. Build
13. Byte Code
14. Cache
15. Chart
16. Chat
17. Code Analyzer
18. Collaboration
19. Content Management System
20. Database Client
21. Database DBMS
22. Database JDBC Connection Pool
23. Database ORM
24. Development
25. EJB Server geronimo
26. EJB Server GlassFish
27. EJB Server JBoss 4.2.1
28. EJB Server resin 3.1.5
29. ERP CRM Financial
30. ESB
31. Forum
32. GIS
33. Graphic Library
34. Groupware
35. HTML Parser
36. IDE
37. IDE Eclipse
38. IDE Netbeans
39. Installer
40. Internationalization Localization
41. Inversion of Control
42. Issue Tracking
43. J2EE
44. JBoss
45. JMS
46. JMX
47. Library
48. Mail Clients
49. Net
50. Parser
51. PDF
52. Portal
53. Profiler
54. Project Management
55. Report
56. RSS RDF
57. Rule Engine
58. Science
59. Scripting
60. Search Engine
61. Security
62. Sevlet Container
63. Source Control
64. Swing Library
65. Template Engine
66. Test Coverage
67. Testing
68. UML
69. Web Crawler
70. Web Framework
71. Web Mail
72. Web Server
73. Web Services
74. Web Services apache cxf 2.0.1
75. Web Services AXIS2
76. Wiki Engine
77. Workflow Engines
78. XML
79. XML UI
Java
Java Tutorial
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
Photoshop Tutorials
Maya Tutorials
Flash Tutorials
3ds-Max Tutorials
Illustrator Tutorials
GIMP Tutorials
C# / C Sharp
C# / CSharp Tutorial
C# / CSharp Open Source
ASP.Net
ASP.NET Tutorial
JavaScript DHTML
JavaScript Tutorial
JavaScript Reference
HTML / CSS
HTML CSS Reference
C / ANSI-C
C Tutorial
C++
C++ Tutorial
Ruby
PHP
Python
Python Tutorial
Python Open Source
SQL Server / T-SQL
SQL Server / T-SQL Tutorial
Oracle PL / SQL
Oracle PL/SQL Tutorial
PostgreSQL
SQL / MySQL
MySQL Tutorial
VB.Net
VB.Net Tutorial
Flash / Flex / ActionScript
VBA / Excel / Access / Word
XML
XML Tutorial
Microsoft Office PowerPoint 2007 Tutorial
Microsoft Office Excel 2007 Tutorial
Microsoft Office Word 2007 Tutorial
Java Source Code / Java Documentation » Library » Apache beehive 1.0.2 src » org.apache.beehive.netui.util.internal.concurrent 
Source Cross Reference  Class Diagram Java Document (Java Doc) 


java.lang.Object
   org.apache.beehive.netui.util.internal.concurrent.Utils

Utils
final class Utils (Code)

This class groups together the functionality of java.util.concurrent that cannot be fully and reliably implemented in backport, but for which some form of emulation is possible.

Currently, this class contains methods related to nanosecond-precision timing, particularly via the Utils.nanoTime method. To measure time accurately, this method by default uses java.sun.Perf on JDK1.4.2 and it falls back to System.currentTimeMillis on earlier JDKs.
author:
   Dawid Kurzyniec
version:
   1.0





Method Summary
public static  longawaitNanos(Condition cond, long nanosTimeout)
     Causes the current thread to wait until it is signalled or interrupted, or the specified waiting time elapses.
public static  longnanoTime()
     Returns the current value of the most precise available system timer, in nanoseconds.



Method Detail
awaitNanos
public static long awaitNanos(Condition cond, long nanosTimeout) throws InterruptedException(Code)
Causes the current thread to wait until it is signalled or interrupted, or the specified waiting time elapses. This method originally appears in the Condition interface, but it was moved to here since it can only be emulated, with very little accuracy guarantees: the efficient implementation requires accurate nanosecond timer and native support for nanosecond-precision wait queues, which are not usually present in JVMs prior to 1.5. Loss of precision may cause total waiting times to be systematically shorter than specified when re-waits occur.

The lock associated with this condition is atomically released and the current thread becomes disabled for thread scheduling purposes and lies dormant until one of five things happens:

  • Some other thread invokes the org.apache.beehive.netui.util.concurrent.locks.Condition.signal method for this Condition and the current thread happens to be chosen as the thread to be awakened; or
  • Some other thread invokes the org.apache.beehive.netui.util.concurrent.locks.Condition.signalAll method for this Condition; or
  • Some other thread Thread.interrupt interrupts the current thread, and interruption of thread suspension is supported; or
  • The specified waiting time elapses; or
  • A "spurious wakeup" occurs.

In all cases, before this method can return the current thread must re-acquire the lock associated with this condition. When the thread returns it is guaranteed to hold this lock.

If the current thread:

  • has its interrupted status set on entry to this method; or
  • is Thread.interrupt interrupted while waiting and interruption of thread suspension is supported,
then InterruptedException is thrown and the current thread's interrupted status is cleared. It is not specified, in the first case, whether or not the test for interruption occurs before the lock is released.

The method returns an estimate of the number of nanoseconds remaining to wait given the supplied nanosTimeout value upon return, or a value less than or equal to zero if it timed out. Accuracy of this estimate is directly dependent on the accuracy of Utils.nanoTime . This value can be used to determine whether and how long to re-wait in cases where the wait returns but an awaited condition still does not hold. Typical uses of this method take the following form:

 synchronized boolean aMethod(long timeout, TimeUnit unit) {
 long nanosTimeout = unit.toNanos(timeout);
 while (!conditionBeingWaitedFor) {
 if (nanosTimeout > 0)
 nanosTimeout = theCondition.awaitNanos(nanosTimeout);
 else
 return false;
 }
 // ...
 }
 

Implementation Considerations

The current thread is assumed to hold the lock associated with this Condition when this method is called. It is up to the implementation to determine if this is the case and if not, how to respond. Typically, an exception will be thrown (such as IllegalMonitorStateException ) and the implementation must document that fact.

A condition implementation can favor responding to an interrupt over normal method return in response to a signal, or over indicating the elapse of the specified waiting time. In either case the implementation must ensure that the signal is redirected to another waiting thread, if there is one.
Parameters:
  cond - the condition to wait for
Parameters:
  nanosTimeout - the maximum time to wait, in nanoseconds A value less than or equal to zero if the wait hastimed out; otherwise an estimate, thatis strictly less than the nanosTimeout argument,of the time still remaining when this method returned.
throws:
  InterruptedException - if the current thread is interrupted (andinterruption of thread suspension is supported).




nanoTime
public static long nanoTime()(Code)
Returns the current value of the most precise available system timer, in nanoseconds. This method can only be used to measure elapsed time and is not related to any other notion of system or wall-clock time. The value returned represents nanoseconds since some fixed but arbitrary time (perhaps in the future, so values may be negative). This method provides nanosecond precision, but not necessarily nanosecond accuracy. No guarantees are made about how frequently values change. Differences in successive calls that span greater than approximately 292 years (263 nanoseconds) will not accurately compute elapsed time due to numerical overflow.

Implementation note:By default, this method uses sun.misc.Perf on Java 1.4.2, and falls back to System.currentTimeMillis() emulation on earlier JDKs. Custom timer can be provided via the system property org.apache.beehive.netui.util.concurrent.NanoTimerProvider. The value of the property should name a class implementing NanoTimer interface.

Note: on JDK 1.4.2, sun.misc.Perf timer seems to have resolution of the order of 1 microsecond, measured on Linux. The current value of the system timer, in nanoseconds.




Methods inherited from java.lang.Object
native protected Object clone() throws CloneNotSupportedException(Code)(Java Doc)
public boolean equals(Object obj)(Code)(Java Doc)
protected void finalize() throws Throwable(Code)(Java Doc)
final native public Class getClass()(Code)(Java Doc)
native public int hashCode()(Code)(Java Doc)
final native public void notify()(Code)(Java Doc)
final native public void notifyAll()(Code)(Java Doc)
public String toString()(Code)(Java Doc)
final native public void wait(long timeout) throws InterruptedException(Code)(Java Doc)
final public void wait(long timeout, int nanos) throws InterruptedException(Code)(Java Doc)
final public void wait() throws InterruptedException(Code)(Java Doc)

w_w__w_.___j___av_a_2_s___.__c___o___m | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.