Ir al contenido principal

Android Architecture ( Synchronization and Scheduling )

Java Classes

  • ReentrantLock
    • A reentrant mutual exclusion lock that extends the built-in-monitor lock capabilities
  • ReentrantReadWriteLock
    • Improves performance when resources are read much more often than written
  • Semaphore
    • A non-negative integer that controls the access of multiple threads to a limited number of shared resources
  • ConditionObject
    • Block thread(s) until some condition(s) becomes true
  • CountDownLatch
    • Allows one or more threads to wait until a set of operations being performed in other threads complete
Considerations
  • ReentrantLock have lower overhead than ReentrantReadWriteLock
  • ReentrantReadWriteLock may enable more concurrency on multi-core or multi-processor hardware
  • ConditionObject & Semaphore have higher overhead than ReentrantLock & ReentrantReadWriteLock
  • ConditionObject & Semaphore are more expressive & more flexible
  • ConditionObject can be used to lock a thread to keep other threads out of a critical section or keep in the critical section

ReentrantLock

Use mutual exclusion
Example: The bathroom in an airplane, only one person can use it at time

In Android implements the lock Interface and uses the Ganga four bridge pattern

Methods

  • lock()
  • lockInterruptibly()
    • acquires the lock unless thread is interrupted
  • unlock()

Readers-Witer Locks

  • Is a synchonization mechanism often used in context with many concurrent threads
  • Allow access to a shared resource
    • Where multiple threads have read-only access OR
    • one thread has write access
  • Human Example 
    • Formal Political debates: Many people listen the debate but only one person talk

RentrantReadWriteLock


Comentarios

Entradas populares de este blog

C# Using tabs

To use tabs in C# use the TabContainer element from AjaxControlToolkit Include AjaxControlToolkit  Include in the Web.config file, inside the tag <system.web> the following code  <pages>       <controls>         <add tagPrefix="ajaxCTK" namespace="AjaxControlToolkit" assembly="AjaxControlToolkit"/>       </controls>     </pages>   Include TabContainer element First  include TabContainer element that is the section where all the tabs will be displayed. <ajaxCTK:TabContainer ID="TabContainerUpdate" runat="server"                 Height="800"                 CssClass="ajax__tab_style"> </ajaxCTK:TabContainer> Second per each tab include the following code corresponding to each ...

Rails - Basic Steps III

pValidations Validations are a type of ActiveRecord Validations are defined in our models Implement Validations Go to   root_app/app/models Open files  *.rb for each model Mandatory field validates_presence_of   :field Ex:   validates_presence_of    :title Classes The basic syntax is class MyClass        @global_variable                def my_method              @method_variable        end end Create an instance myInstance = MyClass.new Invoke a mehod mc.my_method class() method returns the type of the object In Ruby, last character of method define the behavior If ends with a question -> return a boolean value If ends with an exclamation -> change the state of the object Getter / Setter method def global_variable       return @global_variable end ...

Python create package

Create a root folder Create a sub-folder "example_pkg" that contains the funtionallity packaging_tutorial/ example_pkg/ __init__.py In the root folder create the following structure  packaging_tutorial/ example_pkg/ __init__.py tests/ setup.py LICENSE README.md in the setup.py contains the configuration of the packages your package is found by find_packages() import setuptools with open ( "README.md" , "r" ) as fh : long_description = fh . read () setuptools . setup ( name = "example-pkg-YOUR-USERNAME-HERE" , # Replace with your own username version = "0.0.1" , author = "Example Author" , author_email = "author@example.com" , description = "A small example package" , long_description = long_description , long_description_content_type = "text/markdown" , url = "https://github.com/pypa/sam...