Thursday, June 27, 2013

Vista - User Profile failed to login

Click Start, ->regedit 

Now in in regidit, HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\ProfileList

In the navigation pane, find folder that begins with S-1-5 (SID key) followed by a long number.

Click each S-1-5 folder, locate the ProfileImagePath entry in the details pane, and then double-click to make sure that this is the user account profile that has the error.

If you have two folders (ie one is duplicate) starting with S-1-5 followed by some long numbers and one of them ended with .bak, you have to rename the .bak folder.

Ie-  Right-click the folder without .bak, and then click Rename. Type .ba, and then press ENTER.

again right-click the folder that is named .bak, and then click Rename. Remove .bak at the end of the folder name, and then press ENTER.

now again right-click the folder that is named .ba, and then click Rename. Change the .ba to .bak at the end of the folder name, and then press ENTER.

Now Double-click the folder without .bak in the details pane, double-click RefCount, type 0, and then click OK.

Then Click the folder without .bak, in the details pane, double-click State, type 0, and then click OK.

Close Registry Editor and Restart

Wednesday, April 17, 2013

Make Symbols with Keyboard

Alt + 0153..... ™... trademark symbol
Alt + 0169.... ©.... copyright symbol
Alt + 0174..... ®....registered ­ trademark symbol
Alt + 0176 ...°......degre ­e symbol
Alt + 0177 ...±....plus-or ­-minus sign
Alt + 0182 ...¶.....paragr ­aph mark
Alt + 0190 ...¾....fractio ­n, three-fourths
Alt + 0215 ....×.....multi ­plication sign
Alt + 0162...¢....the ­ cent sign
Alt + 0161.....¡..... ­.upside down exclamation point
Alt + 0191.....¿..... ­upside down question mark
Alt + 1.......☺....sm ­iley face
Alt + 2 ......☻.....bla ­ck smiley face
Alt + 15.....☼.....su ­n
Alt + 12......♀.....f ­emale sign
Alt + 11.....♂......m ­ale sign
Alt + 6.......♠.....s ­pade
Alt + 5.......♣...... ­Club
Alt + 3.......♥...... ­Heart
Alt + 4.......♦...... ­Diamond
Alt + 13......♪.....e ­ighth note
Alt + 14......♫...... ­beamed eighth note
Alt + 8721.... ∑.... N-ary summation (auto sum)
Alt + 251.....√.....s ­quare root check mark
Alt + 8236.....∞..... ­infinity
Alt + 24.......↑..... ­up arrow
Alt + 25......↓...... ­down arrow
Alt + 26.....→.....ri ­ght arrow
Alt + 27......←.....l ­eft arrow
Alt + 18.....↕......u ­p/down arrow
Alt + 29......↔...lef ­t right arrow

Wednesday, April 10, 2013

Overriding rules in Java



  • Should be same method name and argument list in base class and derived class
  • Return type can be co-variant, meaning if super class return type is Map, subclass return type can be Hash Map.
  • Access specifier in the derived class should be broader/bigger than that in the base class;
    • ie; if base class method is protected, the derived class method can  be protected or public- but cannot be private or default
  • Exception in the subclass  should be same or subclass of base class
    • ie:-if base class exception is IOException, subclass can be FilenotFoundException-but cannot be Exception.

Saturday, March 9, 2013

Get the source code from an APK


First Download

  • dex2jar -> https://code.google.com/p/dex2jar/
  • Java Decompiler –> http://java.decompiler.free.fr/?q=jdgui
  • android-apktool and apktool- -> https://code.google.com/p/android-apktool/
For Source code

Rename the apk file to zip file. Extract the files in the same folder
Extract dex2jar into the same folder, or copy classes.dex from the extracted apk to the dex2jar extracted folder.

Give the command 
#dex2jar classes.dex
You can now see class_dex2jar in your folder( a executable jar file )

Now you run jd-gui.exe downloaded with the java decompiler.
Open the class_dex2jar folder  in decompiler(jd-gui), now you can see all source codes
File-> Save all sources
Now you have the java source in zip file named classes_dex2jar.src.

For XML

Create a new folder for xml, and put the apk file in that folder.

Now extract the downloaded apktool and apktool-install-window.

Put your xxx.apk in it then run the command 

     apktool if xxx.apk

after that run the command 

     apktool d xxx.apk

A new folder with the xml files will be created.

So All the source code is ready -- enjoy :)

Please Note: Do not misuse this tutorial, just sharing my knowledge for learning purpous


Tuesday, February 19, 2013

Aggregation


Aggregation means HAS –A relationship

Eg: Employee has Address
ie-
class Employee{
int id;
String name,salary;
Address address;//Address is a class
}
employee -> name, id, salary also has Address -> which itself has different attribute like pincode, city, country etc.
When there is no IS-A relationship(ie: inheritance), best way of code reuse is aggregation.
Inheritance should be used only if the –IS-A relationship is maintained in the life time of the object, otherwise aggregation is the best choice.

Android Version and Name

Version
Name
1.5
Cupcake
1.6
Donut
2.1
Éclair
2.2
Froyo
2.3
Gingerbread
3.1,3.2
Honeycomb
4.0
Ice cream sandwitch
4.1
Jelly Bean

Thursday, February 7, 2013

ERROR 2006 (HY000): MySQL server has gone away

Issue:


mysql -u root -proot123 mydb < /root/db-2013-01-30.sql
ERROR 2006 (HY000): MySQL server has gone away
No connection. Trying to reconnect...

Analysis:-

Actually dump file having large INSERT queries, and also “max_allowed_packet” size was set to very low value.

So, when the mysql client or the mysqld server receives a packet,which is bigger than max_allowed_packet bytes, it will throw error and close the connection.

Solution:-

In /etc/my.cnf , I updated the entry
max_allowed_packet=1M
to
max_allowed_packet=64M

now run the query for restore again:-
mysql -u root -proot123 mydb < /root/db-2013-01-30.sql

It worked!!

Saturday, January 26, 2013

Interior Design of HashMap


HashMap works on principle of hashing.

We have put () and get () method for storing and retrieving data from hashMap.

When we pass an object to put () method to store it on hashMap, hashMap implementation calls hashcode() method hashMap key object and by applying that hashcode on its own hashing funtion it identifies a bucket location for storing value object.

HashMap stores both key+value in bucket.

Map internally used two data structures:
  1. Array
  2. LinkedList



  • Each index of array is a bucket
  • To identify the bucket for any <key,value>, Hash map use key.hashCode() and perform some operation:
  • It means, two keys with different hashCode can fall under same bucket.
  • If a bucket is empty then the Entry object is simply inserted at ith position
  • The latest entry resides on the top of the bucket.
  • If a key already exists in a map, then it just replace the value and return the old value
  • In case of new key,  map add the <key, value> (a new Entry object with key value) and return null
  • Entry.hash is not the hashCode of key, but HashMap use its own hash algorithm to create hash based on key.hashCode().


Collision  : If different objects have same hashcode ?

Since hashcode () is same, bucket location would be same and collision occurs in hashMap, 

Since HashMap use a linked list to store in bucket, value object will be stored in next node of linked list.

How to retrieve if two different objects have same hashcode?

We will call get() method and then HashMap uses keys hashcode to find out bucket location.

Since two objects are stored in same bucket, it will traverse through the linked list until find the value object.

After finding bucket location, we will call keys.equals() method to identify correct node in linked list and return associated value object for that key in Java Hash Map





ArrayList vs LinkedList


  • Both ArrayList and Vector use array to store the elements
  • ArrayList implements the RandomAccess interface, and LinkedList does not. The commonly used ArrayList implementation uses array for internal storage. Therefore an ArrayList is much faster than a LinkedList for random access, that is, when accessing arbitrary list elements using the get method.
  • Adding and deleting at the start and middle of the ArrayList is slow, because all the later elements have to be copied forward or backward using System.arrayCopy(). But Linked lists are faster for inserts and deletes anywhere in the list, since all you do is update a few next and previous pointers of a node.
  • When an element is inserted into the middle of the list the elements that follow the insertion point must be shifted to make room for the new element. The LinkedList is implemented using a doubly linked list, an insertion requires only the updating of the links at the point of insertion. So, the LinkedList allows for fast insertions and deletions.
    • Ie:- LinkedList is made up of a chain of nodes. Each node stores an element and the pointer to the next node. A singly linked list only has pointers to next. A doubly linked list has a pointer to the next and the previous element. This makes walking the list backward easier
  • Each element of a linked list (especially a doubly linked list) uses a bit more memory than its equivalent in array list, due to the need for next and previous pointers.

Friday, January 25, 2013

Why Map interface not extend Collection?


Answer from Sun's FAQ Page:-

This was by design. 

We feel that mappings are not collections and collections are not mappings. Thus, it makes little sense for Map to extend the Collection interface (or vice versa).

If a Map is a Collection, what are the elements?
The only reasonable answer is "Key-value pairs", but this provides a very limited (and not particularly useful) Map abstraction. You can't ask what value a given key maps to, nor can you delete the entry for a given key without knowing what value it maps to. Collection could be made to extend Map,

But this raises the question: what are the keys?
There's no really satisfactory answer, and forcing one leads to an unnatural interface. Maps can be viewed as Collections (of keys, values, or pairs), and this fact is reflected in the three "Collection view operations" on Maps (keySet, entrySet, and values). While it is, in principle, possible to view a List as a Map mapping indices to elements, this has the nasty property that deleting an element from the List changes the Key associated with every element before the deleted element.

So, That's why we don't have a map view operation on Lists.

Hashcode and equals



Java.lang.Object has two methods:-
-          Public Boolean equals(Object o)
-          Public int hashCode()

  • These are heavily used with Collections.
  • Whenever it is invoked on the same object more than once during an execution, the hashCode() method must consistently return the same integer. This integer need not remain consistent from one execution of an application to another execution of the same application.
  • If two objects are equal according to the equals() method, then calling the hashCode() method on each of the two objects should return the same integer.
  • Also It is not mandatory that if two objects are not equal according to the equals(java.lang.Object) method, then calling the hashCode() method on each of the two objects return distinct integer results.
  • It is necessary to override the hashCode() method whenever equals() method is overridden, so as to maintain the general contract for the hashCode method, which states that equal objects must have equal hash codes.
  • Sets use equals() to enforce non-duplicates, and HashSet uses hashCode() as a first-cut test for equality. Technically hashCode() isn't necessary then since equals() will always be used in the end, but providing a meaningful hashCode() will improve performance for very large sets or objects that take a long time to compare using equals().



HashTable V/s HashMap


HashTable -> synchronized – is a legacy class , Enumeration in the Hash table is not fail-fast
-            
HashMap -> not synchronized, Itrator in the hashmap is fail-fast
                        We can make the hashmap synchronized when ever required using Collections.SynchronizedMap(map)
                        Does not garentee the order of the keyvalue pair in the entered order, but the subclass of hashmap, which is LinkedHashMap we can achieve this.

Synchronized means only one thread can modify a hash table at one point of time. Basically, it means that any thread before performing an update on a hashtable will have to acquire a lock on the object while others will wait for lock to be released.

Fail-fast
A fail-fast system is designed to immediately report any failure or condition that is likely to lead to failure. Fail-fast systems are usually designed to stop normal operation rather than attempt to continue a possibly-flawed process. When a problem occurs, a fail-fast system fails immediately and visibly. It will sounds like making your software more fragile, but it actually makes it more robust. Bugs are easier to find and fix, so fewer go into production

When to use what?
Whenever there is a possibility of multiple threads accessing the same instance, we should use Hashtable. While if not multiple threads are going to access the same instance then use HashMap. Non synchronized data structure will give better performance than the synchronized one.
Again , may be later point of time - there can be a scenario when you may require to retain the order of objects in the Collection with key-value pair then HashMap can be a good choice. As one of HashMap's subclasses is LinkedHashMap, so in the event that you'd want predictable iteration order (which is insertion order by default), you can easily swap out the HashMap for a LinkedHashMap. This wouldn't be as easy if you were using Hashtable.
Also if you have multiple thread accessing you HashMap then Collections.synchronizedMap() method can be leveraged.

Verdict:-Overall HashMap is better in all aspects.

HashMap Sample Program:-

class HashMap
{
public static void main(String args[]) {
// Create a hash map
HashMap hm = new HashMap();

// Put elements to the map
hm.put("Sujith", new Double(71.5));
hm.put("Manjusha", new Double(53.6));
hm.put("Sukhesh", new Double(78.5));
hm.put("Ranjith", new Double(81.1));

// Get a set of the entries
Set set = hm.entrySet();

// Get an iterator
Iterator i = set.iterator();

// Display elements
while(i.hasNext())
{
Map.Entry me = (Map.Entry)i.next();
System.out.print(me.getKey() + ": ");
System.out.println(me.getValue());
}
}
}


mysqlbinlog : Enable binary logs in mysql and extract from bin file

MySQL Server generate binary log files for every db transaction, provided administrator does not disable. The binary log files are written in binary format. It will be stored in /var/lib/mysql directory. It cannot be read directly, as it is in binary format. So we need to use mysqlbinlog command to read in text file.

Check enabled?


SELECT * from information_schema.GLOBAL_VARIABLES WHERE VARIABLE_NAME = 'LOG_BIN';
 Or
SELECT @@log_bin;
Or
SHOW VARIABLES LIKE 'log_bin';
If not enabled:-enable binary logs in mysql

Add this to /etc/my.cnf:

log-bin=mysql-bin

[root@rhel6 ~]# /etc/init.d/mysqld restart --log-bin
Stopping mysqld: [ OK ]
Starting mysqld: [ OK ]
[root@rhel6 ~]# mysql -u root -p
Enter password:

mysql> show binary logs;
ERROR 1381 (HY000): You are not using binary logging
[root@rhel6 ~]# updatedb
[root@rhel6 ~]# locate mysql-bin

Mysql - To extract from bin file:

mysqlbinlog  is a tool to analyze and view the binlogs  from mysql, which are stored in binary format. This will converts them to plaintext, so that  it can be readable.

--start-datetime and --stop-datetime , both will accept DATETIME or TIMESTAMP entries, and which together set the start/stop of what kind of information we’re interested in.
Ex:-
mysqlbinlog --start-datetime="2012-09-05 00:00:00" --stop-datetime="2012-12-31 14:00:00" mysql-bin.000019 --result-file=05Sept_31Dec.txt

mysqlbinlog --start-datetime="2012-12-31 01:00:00" mysql-bin.000019 --result-file=31dec.txt

Monday, January 14, 2013

REST and SOAP Web Services


REST Web Service

  • REST => Representational State Transfer,  means  each unique URL is a representing some object. You can get the contents of that object using an HTTP GET, also you can use a POST, PUT, or DELETE to modify the object.
  • It is Light weight ,  not a lot of extra xml markup, Human Readable Results,  Easy to build
  • REST has no WSDL interface definition
  • REST is over HTTP, REST is stateless
  • REST can be  plain text, JSON, HTML etc which can transfer over HTTP
  • REST services are easily cacheable.
  • In REST, For transport security we can use https and for authentication, basic auth
  • REST is much simpler and easy to interop in many languages.
  • REST is a better choice for integration between websites, with public API, on the TOP of layer (VIEW, ie, javascripts taking calls to URIs).

SOAP Web Service:

  • SOAP is a protocol.
  • SOAP was designed to give access to Objects as in Object Oriented Programming Objects; i.e., data plus methods
  • SOAP can be over any transport protocols such HTTP, FTP, STMP, JMS
  • SOAP is using soap envelope
  • From any given WSDL, we can generate
  • The problem with SOAP is its complexity when the other WS-* specifications come in and there are countless interop issues if you stray into the wrong parts of WSDL, XSDs, SOAP, WS-Addressing etc.
  • SOAP is a XML-based protocol that tunnels inside an HTTP request/response, so even if you use SOAP, you are using REST too
  • SOAP is a better choice for integration between legacy/critical systems and a web/web-service system, on the foundation layer, where WS-* make sense (security, policy, etc.).