首页 > 系统相关 >进程和线程

进程和线程

时间:2023-09-21 18:05:01浏览次数:36  
标签:Runnable run Thread 接口 线程 进程 public

1.并行和并发

并发:指两个或多个事件在同一个时间段内发生(交替执行)
并行:指两个或多个事件在同一个时刻发生(同时发生)

2.进程的概念

进程和线程_类对象

3.线程的概念(一个进程包括多个线程)

进程和线程_java_02

4.线程调用

分时调度:所有线程轮流使用cpu的使用权,平均分配每个线程占用cpu的时间
抢占式调用:优先让优先级高的线程使用cpu,如果线程的优先级相同,那么会随机选择一个(线程随机性),java使用的为抢占式调度

5.主线程

进程和线程_类对象_03

6.创建多线程程序的第一种方式,创建thread的子类

public class Demo01Thread {
    /*
    创建多线程程序的第一种方式:创建Thread类的子类
    java.lang.Thread类:是描述线程的类,我们想要实现多线程程序,就必须继承Thread类
    实现步骤:
        1.创建一个Thread类的子类
        2.在Thread类的子类中重写Thread类中的run方法,设置线程任务(开启线程要做什么?)
        3.创建Thread类的子类对象
        4.调用Thread类中的方法start方法,开启新的线程,执行run方法
        void start() 使用该线程开始执行;java虚拟机调用该线程的run方法
        结果是两个多线程并发地执行;当前线程(main线程)和另一个线程(创建的新线程,执行其run方法)。
        多次启动一个线程是非法的。特别是当前线程已经结束执行后,不能载重新启动
     java程序属于抢占式调度,哪个线程的优先级高,哪个线程优先执行;同一个优先级,随机选择一个执行。*/
    public static void main(String[] args) {
        MyThread mt = new MyThread();
        mt.start();
        for (int i = 0; i < 20; i++) {
            System.out.println("main:"+i);
        }
    }
}

public class MyThread extends Thread{
    @Override
    public void run(){
        for (int i = 0; i < 20; i++) {
            System.out.println("run:"+i);
        }
    }
}

7.多线程原理

进程和线程_java_04

8.多线程内存图解

进程和线程_多线程_05

9.Thread类获取线程的方法

获取线程的名称:
    1.使用Thread类中的方法getName()
    String getName()返回该线程的名称

    2.可以先获取到当前正在执行的线程,使用线程中的方法getName()获取线程的名称
    static thread currentThread() 返回对当前正在执行的线程对象的引用*/

//定义一个Thread类的子类
public class MyThread extends Thread{
    //重写Thread类的run方法,设置线程任务
    @Override
    public void run(){
        //获取线程名称
        String name = getName();
        System.out.println(name);//Thread-0
        //获取线程名称
        Thread t = Thread.currentThread();
        System.out.println(t);//Thread[Thread-0,5,main]
        String name1 = t.getName();
        System.out.println(name1);//Thread-0
        System.out.println("--------------");
        System.out.println(Thread.currentThread().getName());//Thread-0
    }
}
public class Demo01GetThreadName {
    public static void main(String[] args) {
        //创建Thread类的子类对象
        MyThread mt = new MyThread();
        //调用start方法,开启新线程,执行run方法
        mt.start();

//        new MyThread().start();
//        new MyThread().start();
        //链式编程
        System.out.println(Thread.currentThread().getName());  //主线程名称
    }

}

10.设置线程名称

进程和线程_多线程_06


进程和线程_多线程_07

11.sleep方法

public class ThreadSleep {
    /*public static void sleep(long millis):使用当前正在执行的线程以指定的毫秒数暂停,毫秒数结束之后,线程继续执行*/
    public static void main(String[] args) {
        for (int i = 0; i < 60; i++) {
            System.out.println(i);
            //使用Thread类的sleep方法让程序睡眠1秒钟
            try{
                Thread.sleep(1000);
            }catch (InterruptedException e){
                e.printStackTrace();
            }
        }
    }
}
#### 15.实现Runnable接口
```java
//创建一个Runnable接口的实现类
public class RunnableImpl implements Runnable{
    //在实现类中重写Runnable接口的run方法,设置线程任务。
    @Override
    public void run() {
        for (int i = 0; i < 20; i++) {
            System.out.println(Thread.currentThread().getName()+"------>"+i);
        }
    }
}
/*
创建多线程程序的第二种方式:实现Runnable接口
java.lang.Runnable
    Runnable 接口应该由那些打算通过某一线程执行其实例的类来实现。类必须定义一个称之为run的无参数方法
java.lang.Thread类的构造方法:
    Thread(Runnable target) 分配新的Thread对象
    Thread(Runnable target) 分配新的Thread对象
实现步骤:
1.创建一个Runnable接口的实现类
2.在实现类中重写Runnable接口的run方法,设置线程任务
3.创建一个Runnable接口的实现类对象
4.创建Thread类对象,构造方法中传递Runnable接口的实现类对象
5.调用Thread类中的start方法,开启新的线程执行run方法
*/

/*实现Runnable接口创建多线程程序的好处(继承Thread类和实现runnable接口的区别):
* 1.一个类只能继承一个类,类继承了Thread类就不能继承其他的类,
*   实现Runnable接口,还可以继承其他的类,实现其他的接口
* 2.增强了程序的扩展性,降低类程序的耦合性(解耦)
*   实现Runnable接口的方式,把设置线程任务和开启新线程进行了分离()解耦
*   实现类中,重写了run方法:用来设置线程任务
*   创建Thread类对象,调用start方法:用来开启新线程。*/
public class Demo01Runnable {
    public static void main(String[] args) {
        //创建一个Runnable接口的实现类对象
        RunnableImpl run = new RunnableImpl();
        //创建Thread类对象,构造方法中传递Runnable接口的实现类对象
        Thread t = new Thread(run);
        //调用Thread类中的start方法,开启新的线程执行run方法
        t.start();
        for (int i = 0; i < 10; i++) {
            System.out.println(Thread.currentThread().getName()+"----->"+i);
        }


    }
}

16.匿名内部类实现线程的创建

/*
        匿名内部类方式实现线程的创建
        匿名:没有名字
        内部类:写在其他类内部的类
        
        匿名内部类的作用:简化代码
            把子类继承父类,重写父类的方法,创建子类对象合一布完成
            把实现类实现类接口,重写接口中的方法,创建实现类对象合成一步完成
        匿名内部类的最终产物:子类/实现类对象,而这个类没有名字
        格式:
        new 父类/接口(){
            重写父类};*/
public class Demo01InnerClassThread {
    public static void main(String[] args) {
        //线程的父类是Thread
//        new MyThread().start();
        new Thread(){
            //重写run方法,设置线程任务
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName()+"----"+"黑马");
            }
        }.start();

        //线程的接口Runnable
        RunnableImpl run = new RunnableImpl(){
            @Override
            public void run() {
                for (int i = 0; i < 5; i++) {
                    System.out.println(Thread.currentThread().getName()+"----"+"程序");
                }

            }
        };
        new Thread(run).start();
        //简化接口的方式:
        new Thread(new RunnableImpl(){
            //重写run方法,设置线程任务
            @Override
            public void run() {
                for (int i = 0; i < 5; i++) {
                    System.out.println(Thread.currentThread().getName()+"----"+"简化代码");
                }

            }
        }).start();

    }
}



标签:Runnable,run,Thread,接口,线程,进程,public
From: https://blog.51cto.com/u_16082673/7555757

相关文章

  • 线程安全和通信
    1.线程安全问题概述2.模拟卖票代码//创建一个Runnable接口的实现类publicclassRunnableImplimplementsRunnable{//在实现类中重写Runnable接口的run方法,设置线程任务。//定义一个多线程共享的资源privateintticket=100;//创建一个锁对象Object......
  • 《探索C++多线程》:condition_variable源码(一)
    https://blog.csdn.net/hujingshuang/article/details/70596630    现在接着学习关于多线程编程的特征,在这一节,将会了解到多线程中的condition_variable(条件变量)的相关知识。     在头文件<condition_variable>中有两种条件变量的类声明与定义:condition_varia......
  • 查看mysql资源占用高的线程及其详细信息
    结合操作系统线程查看mysql中的sql资源 消耗 ( 5.7 才可以,5.7时   performance_schema.threads表 才加入的  thread_os_id 系统线程字段 1--1、top-H查看具体线程的CPU消耗2[root@hostmysql80mysql]#top-H345--2、iotop-umysql查看具体......
  • 进程注入之Portable Executable Injection,PE注入的核心是创建远程线程,注意重定位表修
     PE(Portable Executable)注入是一种常见的代码注入技术,主要用于在目标进程中执行恶意代码。以下是PE注入的基本流程:1. 获取当前PE映像的基地址:使用GetModuleHandle(NULL)函数获取当前PE映像(即要注入的代码)的基地址。2. 复制PE映像:使用VirtualAlloc函数在当前进程中分配一块新......
  • windows下进程注入的各种技术汇总、代码示例和检测思考
    注入类型                 C++代码实现链接和检测思考         检测优先级           备注PortableExecutableInjection-PE注入 https://www.cnblogs.com/bonelee/p/17719649.html 高 已实现检测,核......
  • 26线程
    消息队列#由于目前的知识储备还不够直接学习消息队列所以先学习内置队列"""队列:先进先出(使用频率很高)堆栈:先进后出(特定常见下用)"""#以后我们会直接使用别人封装好的消息队列实现各种数据传输frommultiprocessingimportQueueq=Queue(5)#自定义队列的......
  • 线程间共享数据-各种锁(总结)
    std::mutex#include<mutex>#include<list>std::mutexsome_mutex;std::list<int>mylist;voidfunc(intvalue){some_mutex.lock();//加锁mylist.push_back(value);some_mutex.unlock();//解锁}std::lock_guard......
  • 03_渲染进程调用node
      我们先创建一个文件夹及文件,并且在html引入JS文件。  在render.js里面输入以下内容:letfs=require('fs')//let是在当前代码块有效console.log(fs)//将fs对象的内容打印到控制台供调试和查看  fs模块:对文件系统进行操作,在Node.js环境下进行常见的文......
  • 在 Python 中,可以使用线程池(ThreadPoolExecutor)和 wait 方法来等待线程池中的所有任务
    importconcurrent.futures#创建一个线程池withconcurrent.futures.ThreadPoolExecutor()asexecutor:#提交任务给线程池task1=executor.submit(func1,arg1)task2=executor.submit(func2,arg2)task3=executor.submit(func3,arg3)#使......
  • Python-多线程调用计算请求时间
    使用多线程调用某个方法(请求),计算每个线程消耗时间importthreadingimporttimeimportrequestsimportjsonimportconcurrent.futuresdefinput_req():url="https://xxxxxxxxxxxx"approval_content="nullain"payload=json.dumps({&quo......