スレッド
日本語 | 筋道 |
英語 | thread |
ふりがな | すれっど |
フリガナ | スレッド |
プログラムの「流れ」。
実行されたプログラムは、main()メソッドから始まり、上から下へと順番に実行されていく。この流れが「スレッド」である。
スレッドは、最初に呼び出されたメソッドから抜けると終了する。
スレッドは、実行当初は1つのみだが、Threadクラスを使用することで新たなスレッドを作ることができる。これを「マルチスレッド」という。
プログラムは、全てのスレッドが終了して初めて終了する。たとえば、新たにスレッドを作り、そのスレッドが終了する前に最初のスレッドがmain()メソッドから抜けて終了しても、プログラムは終了せず、全てのスレッドが終了して初めてプログラムが終了する。
実行されたプログラムは、main()メソッドから始まり、上から下へと順番に実行されていく。この流れが「スレッド」である。
スレッドは、最初に呼び出されたメソッドから抜けると終了する。
スレッドは、実行当初は1つのみだが、Threadクラスを使用することで新たなスレッドを作ることができる。これを「マルチスレッド」という。
プログラムは、全てのスレッドが終了して初めて終了する。たとえば、新たにスレッドを作り、そのスレッドが終了する前に最初のスレッドがmain()メソッドから抜けて終了しても、プログラムは終了せず、全てのスレッドが終了して初めてプログラムが終了する。
参考サイト
// Sample.java
public class Sample
{
public static void main( String[] args )
{
// ↓最初に作られたスレッド(スレッドA)の流れ。
System.out.println( 1 );
System.out.println( 2 );
System.out.println( 3 );
// ↓と、実行されていきます。
// 1
// 2
// 3
OtherThread thread = new OtherThread();
// もうひとつスレッド(スレッドB)を作ります。
thread.start();
// スレッドAからtwoRunner()メソッドを呼び出します。
twoRunner( "スレッドA" );
// スレッドA : 1
// スレッドB : 1
// スレッドA : 2
// スレッドB : 2
// スレッドA : 3
// スレッドA : 終了
// スレッドB : 3
// スレッドB : 終了
// スレッド全部が終了するまで
// 終了しません。なので、スレッドAが
// 先に終わっても、スレッドBの方が
// 中断されることはありません。
}
/**
* スレッドAとスレッドBの両方から呼び出されます。
*/
public static void twoRunner( String name )
{
try
{
// カウンター。
int counter = 0;
// ローカル変数はスレッドで共有されることは
// ありません。再帰呼び出しを考えれば
// 当然ですが。
System.out.println( name + " : " + ++counter );
// スレッドを5秒止めます。
Thread.sleep( 5 * 1000 );
System.out.println( name + " : " + ++counter );
// スレッドAを5秒止めます。
Thread.sleep( 5 * 1000 );
System.out.println( name + " : " + ++counter );
System.out.println( name + " : 終了" );
}
catch( InterruptedException e )
{
// sleep()メソッドが途中で中断されると
// InterruptedException例外が投げられます。
// 滅多にないですが。
e.printStackTrace();
}
}
}
/**
* 別スレッドとして実行するためのクラス。
*/
class OtherThread extends Thread
{
/**
* Threadクラスのrun()メソッドを
* オーバーライドしたメソッド。このメソッドが
* 別スレッドとして呼び出されます。
*/
public void run()
{
try
{
// 最初に2秒待ちます。
sleep( 2 * 1000 );
// SampleクラスのtwoRunner()メソッドを呼び出します。
Sample.twoRunner( "スレッドB" );
}
catch( InterruptedException e )
{
// sleep()メソッドが途中で中断されると
// InterruptedException例外が投げられます。
// 滅多にないですが。
e.printStackTrace();
}
}
}
public class Sample
{
public static void main( String[] args )
{
// ↓最初に作られたスレッド(スレッドA)の流れ。
System.out.println( 1 );
System.out.println( 2 );
System.out.println( 3 );
// ↓と、実行されていきます。
// 1
// 2
// 3
OtherThread thread = new OtherThread();
// もうひとつスレッド(スレッドB)を作ります。
thread.start();
// スレッドAからtwoRunner()メソッドを呼び出します。
twoRunner( "スレッドA" );
// スレッドA : 1
// スレッドB : 1
// スレッドA : 2
// スレッドB : 2
// スレッドA : 3
// スレッドA : 終了
// スレッドB : 3
// スレッドB : 終了
// スレッド全部が終了するまで
// 終了しません。なので、スレッドAが
// 先に終わっても、スレッドBの方が
// 中断されることはありません。
}
/**
* スレッドAとスレッドBの両方から呼び出されます。
*/
public static void twoRunner( String name )
{
try
{
// カウンター。
int counter = 0;
// ローカル変数はスレッドで共有されることは
// ありません。再帰呼び出しを考えれば
// 当然ですが。
System.out.println( name + " : " + ++counter );
// スレッドを5秒止めます。
Thread.sleep( 5 * 1000 );
System.out.println( name + " : " + ++counter );
// スレッドAを5秒止めます。
Thread.sleep( 5 * 1000 );
System.out.println( name + " : " + ++counter );
System.out.println( name + " : 終了" );
}
catch( InterruptedException e )
{
// sleep()メソッドが途中で中断されると
// InterruptedException例外が投げられます。
// 滅多にないですが。
e.printStackTrace();
}
}
}
/**
* 別スレッドとして実行するためのクラス。
*/
class OtherThread extends Thread
{
/**
* Threadクラスのrun()メソッドを
* オーバーライドしたメソッド。このメソッドが
* 別スレッドとして呼び出されます。
*/
public void run()
{
try
{
// 最初に2秒待ちます。
sleep( 2 * 1000 );
// SampleクラスのtwoRunner()メソッドを呼び出します。
Sample.twoRunner( "スレッドB" );
}
catch( InterruptedException e )
{
// sleep()メソッドが途中で中断されると
// InterruptedException例外が投げられます。
// 滅多にないですが。
e.printStackTrace();
}
}
}
// Sample.java public class Sample { public static void main( String[] args ) { // ↓最初に作られたスレッド(スレッドA)の流れ。 System.out.println( 1 ); System.out.println( 2 ); System.out.println( 3 ); // ↓と、実行されていきます。 // 1 // 2 // 3 OtherThread thread = new OtherThread(); // もうひとつスレッド(スレッドB)を作ります。 thread.start(); // スレッドAからtwoRunner()メソッドを呼び出します。 twoRunner( "スレッドA" ); // スレッドA : 1 // スレッドB : 1 // スレッドA : 2 // スレッドB : 2 // スレッドA : 3 // スレッドA : 終了 // スレッドB : 3 // スレッドB : 終了 // スレッド全部が終了するまで // 終了しません。なので、スレッドAが // 先に終わっても、スレッドBの方が // 中断されることはありません。 } /** * スレッドAとスレッドBの両方から呼び出されます。 */ public static void twoRunner( String name ) { try { // カウンター。 int counter = 0; // ローカル変数はスレッドで共有されることは // ありません。再帰呼び出しを考えれば // 当然ですが。 System.out.println( name + " : " + ++counter ); // スレッドを5秒止めます。 Thread.sleep( 5 * 1000 ); System.out.println( name + " : " + ++counter ); // スレッドAを5秒止めます。 Thread.sleep( 5 * 1000 ); System.out.println( name + " : " + ++counter ); System.out.println( name + " : 終了" ); } catch( InterruptedException e ) { // sleep()メソッドが途中で中断されると // InterruptedException例外が投げられます。 // 滅多にないですが。 e.printStackTrace(); } } } /** * 別スレッドとして実行するためのクラス。 */ class OtherThread extends Thread { /** * Threadクラスのrun()メソッドを * オーバーライドしたメソッド。このメソッドが * 別スレッドとして呼び出されます。 */ public void run() { try { // 最初に2秒待ちます。 sleep( 2 * 1000 ); // SampleクラスのtwoRunner()メソッドを呼び出します。 Sample.twoRunner( "スレッドB" ); } catch( InterruptedException e ) { // sleep()メソッドが途中で中断されると // InterruptedException例外が投げられます。 // 滅多にないですが。 e.printStackTrace(); } } }