多线程p1

程序?进程?线程?

程序:是由指令和数据的有序集合,其本身并没有任何运行的含义,是一个静态的概念。

进程:程序跑起来称之为进程,是一个动态的概念,是系统资源分配的单位。

线程:一个进程至少有一个线程(主线程),线程是cpu调度和执行的单位

进程就好比是工厂的车间,线程是车间的工人,车间的空间由工人共享,这象征着一个进程的内存空间是共享的,每个线程都可以使用这些共享内容。

注意:很多多线程都是模拟出来的,真正的多线程是指具有多个cpu,例如:服务器、超级计算机和一些特殊需求的计算机系统中。如果是一个模拟的多线程,即在一个cpu的情况下,在同一时间,cpu只能执行一个代码,因为切换得很快,就有了同时执行的错觉

核心概念:

        1.在一个进程中,如果开辟了多线程,多线程的执行是由cpu调度,cpu又与操作系统相关联,先后顺序不能人为干预的

        2.对同一份资源操作时,会存在资源抢夺问题,需要加入并发控制。

package src.com.huanxi;
/*
*   本节为介绍线程内容
* 创建线程方式一:继承Thread类,重写run()方法,调用start()开启线程
*
* 总结: 注意,线程开启不一定立即执行,由cpu调度执行
* */

public class TestThread extends Thread{
    @Override
    public void run() {
        //run()方法线程体
        // 重写run方法
        for (int i = 0; i < 20; i++) {
            System.out.println("我在看代码"+ i);
        }
    }

    public static void main(String[] args) {
        //main线程,主线程

        //实例化TestThread类
        TestThread testThread = new TestThread();
//        testThread.run();   //当调用run方法时,主线程执行run()方法,run()方法执行完后才会继续向下执行。此时只有主线程一条执行路径
        testThread.start(); //当调用start()方法时子线程执行run()方法,多条执行路径,主线程和子线程并行交替执行


        for (int i = 0; i < 200; i++) {
            System.out.println("我在学习主线程"+ i);
        }
    }
}
  • 8
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值