您的位置:首页 > 编程语言 > Java开发

Threads and Anonymous Classes in JAVA

2016-02-05 20:26 549 查看
As we all know,a thread is a separate process on your computer.you can run multiple threads all at the same time.

multi-threaded code has the disadvantage of becoming quite complex very quickly,although java has some great classes for dealing

with multithreading and simplifying it.

Today we will just look at creating threads,along with using anonymous classes to simplify(or some would say,complexify)your code.

there are two methods to Creating Threads in Java

the first way is to extend the Thread class, override the run() method with the code you want to execute,

then create a new object from your class and call start().

the second method is to pass an implementation of the Runnable interface to the constructor of Thread,

then call start().

we will look at both of the method in turn.

1.Extending the Thread Class

the sample code ad bellow:

public class Worker extends Thread {

@Override
public void run() {

// Loop for ten iterations.

for(int i=0; i<10; i++) {
System.out.println(i + " looping ...");

// Sleep for a while
try {
Thread.sleep(200);
} catch (InterruptedException e) {
// Interrupted exception will occur if
// the Worker object's interrupt() method
// is called. interrupt() is inherited
// from the Thread class.
break;
}
}
}

}


As shown above, we have create a Worker class that extends Thread. And override the run() Method and put some code

in it. The code just loops repeatedly and outputs a method.

we've also used a static method of the thread class,sleep().

note:if you use sleep,you should have to catch InterruptedException.

In the code below,we create two worker class and call their inherited start() methods, both run at the same time,not one after the other

public class Application {

public static void main(String[] args) {
Worker worker1 = new Worker();
worker1.start();

Worker worker2 = new Worker();
worker2.start();

// You can call interrupt() if you want
// to interrupt a thread. The thread itself
// decides how to handle interrupts.
// worker1.interrupt();
}

}


screenshot as below:

0 looping ...
0 looping ...
1 looping ...
1 looping ...
2 looping ...
2 looping ...
3 looping ...
3 looping ...
4 looping ...
4 looping ...
5 looping ...
5 looping ...
6 looping ...
6 looping ...
7 looping ...
7 looping ...
8 looping ...
8 looping ...
9 looping ...
9 looping ...

the start() method, inherited from the parent Thread class, creates a new thread and runs whatever code is in run() in the new thread.

if not use the threads:

public class Application {

public static void main(String[] args) {

Worker worker1 = new Worker();
worker1.run();

Worker worker2 = new Worker();
worker2.run();

// You can call interrupt() if you want
// to interrupt a thread. The thread itself
// decides how to handle interrupts.
// worker1.interrupt();
}

}


result as below:

0 looping ...
1 looping ...
2 looping ...
3 looping ...
4 looping ...
5 looping ...
6 looping ...
7 looping ...
8 looping ...
9 looping ...
0 looping ...
1 looping ...
2 looping ...
3 looping ...
4 looping ...
5 looping ...
6 looping ...
7 looping ...
8 looping ...
9 looping ...

above code doesn't use multithreading, take twice as long to run.

2.passing code to Thread Directly

the second method of starting a thread is to put the code you want to run in the run method of a class that implements the Runnable interface, then pass it to

the constructor of a thread class

the code below does exactly that;we've put the code all in one file to make it easier to follow.

class CodeRunner implements Runnable {

@Override
public void run() {
// Loop for ten iterations.

for(int i=0; i<10; i++) {
System.out.println(i + " looping ...");

// Sleep for a while
try {
Thread.sleep(200);
} catch (InterruptedException e) {
break;
}
}
}

}

public class Application {

public static void main(String[] args) {

CodeRunner runner = new CodeRunner();

Thread thread = new Thread(runner);
thread.start();
}

}


result:

0 looping ...
1 looping ...
2 looping ...
3 looping ...
4 looping ...
5 looping ...
6 looping ...
7 looping ...
8 looping ...
9 looping ...

we can simplify this code by calling new directly on our coderunner class,right where we create the thread.

Thread thread = new Thread(new CodeRunner());
thread.start();


3.Quick and Dirty Thread using Anonymous Class

in fact we can make this code even terser by creating a new intance of Runnable,sortof,directly in the Thread constructor.

Actually,we can't create a new intance of Runnable because it's an interface; so we can't do the follow:

// Won't work
Thread thread = new Thread(new Runnable());
thread.start();


but we can get this to work if we add in some curly brackets and implement the missing run() method in them.

// This works
Thread thread = new Thread(new Runnable() {

@Override
public void run() {

}

});

thread.start();


of course, to get this code to do anything, we have to add some actual code to run.

Thread thread = new Thread(new Runnable() {

@Override
public void run() {
for(int i=0; i<10; i++) {
System.out.println(i + " looping ...");
}
}

});

thread.start();


0 looping ...
1 looping ...
2 looping ...
3 looping ...
4 looping ...
5 looping ...
6 looping ...
7 looping ...
8 looping ...
9 looping ...

finally,we can make the code ecen more terse, if a little more cryptic,by not bothering to declare a variable to hold the thread class, and then

just calling the stat() method on it directly.

new Thread(new Runnable() {

@Override
public void run() {
for(int i=0; i<10; i++) {
System.out.println(i + " looping ...");
}
}

}).start();


here just to make the code a bit clearer.

if you are also interest in linux and android embed system,please connection with us in QQ group:139761394
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: