[java网络编程]线程与进程
2015-02-07 10:08
344 查看
作者:sundroid
个人站点:sundroid.cn
邮箱: hfutsnjc@163.com
微博:http://weibo.com/Sundroid
线程和进程我们在参加公司面试或多或少都接触过类似的提问,在我们日常编程中,我们经常说多线程,却很少说多进程,这又是为什么?线程和进程之间到底是什么关系?
先简要来个国际惯例然后开始我个人对此的理解!
上面的程序特别简单,输出结果为Hello Thread!呼之欲出进程指的是正在运行的程序,进程的任务就是执行程序中的代码,他可以在任意一台安装JDK的机器上运行,程序入口main开始新建一个JVM(Java virtual machine,java虚拟机)进程,并从main开始执行程序。
线程和进程之间的关系
进程(process)是一个具有独立运行程序关于某个数据集合的一次运行活动。进程是分时系统的基本单位,进程是一个执行中的程序,没有生命体,只有处理器让程序执行时,他才会成为一个活动的实体,我们称之为进程。通常一个进程可以拥有多个线程。
线程(thread)是程序执行流中最小单元,线程不拥有系统资源,只有在运行过程中拥有一点必不可少的资源。一个程序可以有多个线程组成。
线程的生命周期
java中的线程操作(创建与启动)
方法一.Thread子类覆盖的run方法中编写运行代码。
方法二.在传递给Thread对象的Runnable对象的run方法中编写代码。
简单实例 (定时器)
这个定时器实现了什么功能了,请自行运行!
个人站点:sundroid.cn
邮箱: hfutsnjc@163.com
微博:http://weibo.com/Sundroid
线程和进程我们在参加公司面试或多或少都接触过类似的提问,在我们日常编程中,我们经常说多线程,却很少说多进程,这又是为什么?线程和进程之间到底是什么关系?
先简要来个国际惯例然后开始我个人对此的理解!
package cn.sundroid.thread; public class HelloThread { public static void main(String[] args) { System.out.println("Hello Thread!"); } }
上面的程序特别简单,输出结果为Hello Thread!呼之欲出进程指的是正在运行的程序,进程的任务就是执行程序中的代码,他可以在任意一台安装JDK的机器上运行,程序入口main开始新建一个JVM(Java virtual machine,java虚拟机)进程,并从main开始执行程序。
线程和进程之间的关系
进程(process)是一个具有独立运行程序关于某个数据集合的一次运行活动。进程是分时系统的基本单位,进程是一个执行中的程序,没有生命体,只有处理器让程序执行时,他才会成为一个活动的实体,我们称之为进程。通常一个进程可以拥有多个线程。
线程(thread)是程序执行流中最小单元,线程不拥有系统资源,只有在运行过程中拥有一点必不可少的资源。一个程序可以有多个线程组成。
线程的生命周期
// 开始线程 publicvoid start( ); publicvoid run( ); // 挂起和唤醒线程 publicvoid resume( ); // 不建议使用 publicvoid suspend( ); // 不建议使用 publicstaticvoid sleep(long millis); publicstaticvoid sleep(long millis, int nanos); // 终止线程 publicvoid stop( ); // 不建议使用 publicvoid interrupt( ); // 得到线程状态 publicboolean isAlive( ); publicboolean isInterrupted( ); publicstaticboolean interrupted( ); // join方法 publicvoid join( ) throws InterruptedException;
java中的线程操作(创建与启动)
方法一.Thread子类覆盖的run方法中编写运行代码。
public class MyThread extends Thread{ @Override public void run() { // TODO Auto-generated method stub System.out.println("我是方法一"); } }
方法二.在传递给Thread对象的Runnable对象的run方法中编写代码。
public static void main(String[] args) { new Thread(new Runnable() { @Override public void run() { System.out.println("我是方法二"); } }).start(); }
简单实例 (定时器)
import java.util.Date; import java.util.Timer; import java.util.TimerTask; public class TimerTest { @SuppressWarnings("deprecation") public static void main(String[] args) { new Timer().schedule(new TimerTask() { @Override public void run() { System.out.println("attend class"); } }, 10000); } }
这个定时器实现了什么功能了,请自行运行!
相关文章推荐
- 网络编程——第一篇 基础之进程线程
- 网络编程-(1)进程和线程
- [java网络编程]线程的互斥
- Java并发编程:进程和线程之由来
- Java网络编程:从线程返回信息。
- RMI网络编程开发之一 JAVA“进程间”通信方式
- java网络编程(一)单线程网络编程
- JAVA 并发编程-线程与进程的由来(一)
- Java并发编程:进程和线程之由来__进程让操作系统的并发性成为可能,而线程让进程的内部并发成为可能
- Java并发编程:进程和线程之由来
- Java 多线程编程之一 进程与线程,并发和并行的区别
- iOS 各种网络编程总结--进程、线程、Socket、HTTP、TCP/IP、TCP和UDP
- iOS 各种网络编程总结--进程、线程、Socket、HTTP、TCP/IP、TCP和UDP
- Java 并发编程 1 进程和线程
- 实训 Java基础知识---流,线程,网络编程
- C#网络编程基础之进程和线程详解
- Java并发编程:线程和进程的创建(转)
- (转)iOS 各种网络编程总结--进程、线程、Socket、HTTP、TCP/IP、TCP和UDP
- Java并发编程:进程和线程的由来(转)
- Java并发编程:进程和线程之由来