线程和简单并发问题

2021-06-09 00:06

阅读:570

标签:cpu   自己   结果   public   void   http   操作系统   nts   art   

线程的一些概念

? 很多多线程是模拟出来的,真整的多线程是指有多个cpu,即多核,如服务器。如果是模拟出来的多线程,在一个cpu的情况下,同一个时间点,cpu只能执行一个代码,因为切换的快,所以就有同时执行的错觉。

? @线程是独立的执行路径

? @在程序运行时,即使自己没有创建线程,后台也会有多个线程,如主线程,gc线程

? @在一个进程中,如果开辟了多个线程,线程的运行由调度器安排调度,调度器是与操作系统紧密相关的,先后顺序不能人为干预

? @线程会带来额外的开销,如cpu调度时间,并发控制开销

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

? @每个线程在自己的工作内存交互,内存控制不当会造成数据不一致

Java中线程的创建

1 . 继承Thread类
//创建线程方式一:继承Thread类,重写run()方法,调用start()开启线程
public class TestThread extends Thread {
    @Override
    public void run() {
        for (int i = 0; i 

? 技术图片

这是上述代码的执行结果,可以看出线程与主线程是交替运行的。

? 线程开启不一定立即执行,而是等待CPU调度执行

2.实现Runnable接口

?

//创建线程方式2: 实现runnable接口,重写run方法,执行线程需要丢入runnable接口实现类,调用start()方法
public class ThreadTest_02 implements Runnable{
    @Override
    public void run() {
        for(int i  = 0 ;i

? 推荐使用实现Runnable接口的方式,可以避免单继承局限性,灵活方便,方便同一个对象被多个对象使用

3.实现Callable接口

并发问题

//多个线程操作一个对象实例
//买火车票
//多个线程操作同一个资源的情况下,数据不安全
public class ThreadTest_03 implements Runnable{
    private int ticketNums = 15;
	@Override
    public void run() {
        while(true){
            if(ticketNums 

线程和简单并发问题

标签:cpu   自己   结果   public   void   http   操作系统   nts   art   

原文地址:https://www.cnblogs.com/wsl975/p/14501855.html


评论


亲,登录后才可以留言!