# The Left Shift

By: aathishankaran Emailed: 1768 times Printed: 2515 times

 By: rohit kumar - how this program is work By: Kirti - Hi..thx for the hadoop in By: Spijker - I have altered the code a By: ali mohammed - why we use the java in ne By: ali mohammed - why we use the java in ne By: mizhelle - when I exported the data By: raul - no output as well, i'm ge By: Rajesh - thanx very much... By: Suindu De - Suppose we are executing

The left shift

The left shift operator, <<, shifts all of the bits in a value to the left a specified number of times. It has this general form:

Value << num

Here, num specifies the number of positions to left-shift the value in value. That is, the << moves all of the bits in the specified value to the left by the number of bit positions specified by num. For each shift left, the high-order bit is shifted out (and lost), and a zero is brought in on the right. This means that when a left shift is applied to an in operand, bits are lost once they are shifted past bit position 31. if the operand is a long, then bits are lost after bit position 63.

Java’s automatic type promotions produce unexpected results when you are shifting byte and short values.

//Left shifting a byte value.

class ByteShift {

public static void main (String args[]) {

byte a = 64, b;

int d;

d = a << 2;

b = (byte) (a<<2);

System.out.println(“Original value of a: ” + a);

System.out.println(“ d and b: “ + d + “ “ +b);

}

}

The output generated by this program is shown here:

Original value of a: 64

d and b : 256 0

Since a is promoted to int for the purposes of evaluation, left-shifting the value 64 (0100 0000) twice results in d containing the value 256 (1 0000 0000). However, the value in b contains 0 because after the shift, the low-order position (bit 31 or 63), the value will become negative. The following program illustrates this point:

//Left Shifting as a quick way to multiply by 2.

class MultByTwo {

public static void main(String args[]) {

int count;

int num = 0Xffffffe;

for (count =0; count<4 ; count++) {

num = num << 1;

System.out.println(num);

}

}

}

The program generates the following output:

536870908

1073741816

2147483632

-32

The starting value was carefully chosen so that after being shifted left 4 bit positions, it would produce –32. As you can see, when a 1 bit is shifted into bit 31, the number is interpreted as negative.

Be the first one to add a comment

Your email(required, will not be shown to the public):

More Tutorials by aathishankaran
 Web Security Issues The Web User's Perspective Server-side plug-Ins The best way to avoid security vulnerabilities with new server JavaScript Security Window Object Working with Status Bar Messages Retrieving a Portion of a String Referencing Windows Math Object Frame Object Document Object Closing Windows Built-in Object in Javascript Textarea Object

More Tutorials in Java
 Update contents of a file within a jar file Tomcat and httpd configured in port 8080 and 80 Java File Java String Count number of vowels, consonants and digits in a String in Java Reverse a number in Java Student marks calculation program in Java Handling Fractions in Java Calculate gross salary in Java Calculate average sale of the week in Java Vector in Java - Sample Program MultiLevel Inheritance sample in Java Multiple Inheritance sample in Java Java program using Method Overriding Java program to check if user input is an even number

More Latest News
Most Viewed Articles (in Java )
 InetAddress Example program in Java Read from a COM port using Java program Stack example in Java - push(), pop(), empty(), search() How to use ArrayList in Java The Basic Structure of a Simple Java program Using StringTokenizer in Java FileReader and FileWriter example program in Java Transient vs Volatile modifiers in Java Vector example in Java Method Overriding in Java Method Overloading (function overloading) in Java instanceof sample program in Java append() in Java Student marks calculation program in Java Reading from a file and writing to a file using Java program
Most Emailed Articles (in Java)
 Text to Speech conversion program in Java inheritance in Java How to initialize an Array and how to copy the array Using Charts in JasperReports What is Unicode? Operator Precedence in Java Of Object, equals (), == and hashCode () DateFormat sample program in Java A Simple whois program in Java PushbackReader sample program in Java CharArrayReader example program in Java ByteArrayOutputStream - sample program in Java Vector example in Java Arrays example in Java - asList(), binarySearch(), fill(), sort(), equals() HashSet Sample program in Java