• 201521123067 《Java程序设计》第11周学习总结


    201521123067 《Java程序设计》第11周学习总结


    1. 本周学习总结

    1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容。


    2. 书面作业

    本次PTA作业题集多线程

    Q1.互斥访问与同步访问

    完成题集4-4(互斥访问)与4-5(同步访问)

    1.1 除了使用synchronized修饰方法实现互斥同步访问,还有什么办法实现互斥同步访问(请出现相关代码)?

    答:除了使用synchronized修饰方法实现互斥同步访问,还可以使用同步代码块实现互斥同步访问。代码如下:
    
    synchronized(this){
    	public void deposit(int money){
    		this.balance=this.balance+money;
    	}
    	public void withdraw(int money){
    		this.balance=this.balance-money;
    	}
    }
    

    1.2 同步代码块与同步方法有何区别?

    答:●首先,在写法上两者就不同了。
      ●其次,同步代码块需要注明锁定的对象,而同步方法就默认锁定this。
    

    1.3 实现互斥访问的原理是什么?请使用对象锁概念并结合相应的代码块进行说明。当程序执行synchronized同步代码块或者同步方法时,线程的状态是怎么变化的?

    答:在同步代码块中,只要哪个对象拿到这把锁,它就可以运行那段代码,这就是互斥访问的原理。当一个线程正在访问一个对象的synchronized方法,那么其他线程不能访问该对象的其他synchronized方法,但是其他线程能访问该对象的非synchronized方法。因为一个对象只有一把锁,当一个线程获取了该对象的锁之后,其他线程无法获取该对象的锁,所以无法访问该对象的其他synchronized方法;而访问非synchronized方法不需要获得该对象的锁,因为如果一个方法没用synchronized关键字修饰,说明它不会使用到临界资源,那么其他线程是可以访问这个方法的。
    
    借用老师PPT上的图片来展现线程的状态变化:

    1.4 Java多线程中使用什么关键字实现线程之间的通信,进而实现线程的协同工作?为什么同步访问一般都要放到synchronized方法或者代码块中?

    答:●Java多线程中使用synchronized关键字这种方式来实现线程间的通信。
      ●因为notify()/notifyAll()方法和wait()方法都只能在synchronized的方法或代码段中调用。
    

    Q2.交替执行

    实验总结(不管有没有做出来)

    ●PTA4-6的实验总结:本题的难点在于把传递进来的字符串以空格的形式分解为多个不同的任务,查阅了资料之后,我发现需要使用split()将其分成多个不同的任务,然后定义好Worker1与Worker2两个类代表两个交替完成的任务,但是不知道为什么在PTA上显示编译错误。

    Q3.互斥访问

    3.1 修改TestUnSynchronizedThread.java源代码使其可以同步访问。(关键代码截图,需出现学号)

    3.2 进一步使用执行器改进相应代码(关键代码截图,需出现学号)

    Q4.线程间的合作:生产者消费者问题

    4.1 运行MyProducerConsumerTest.java。正常运行结果应该是仓库还剩0个货物。多运行几次,观察结果,并回答:结果正常吗?哪里不正常?为什么?

    以下是运行结果:

    答:结果不正常,本该出现的最后结果是仓库还剩0个货物,但实际出现的结果却是非0的数字。问题出在于多线程的冲突,因为在代码中出现了多个线程,而线程发生互斥访问,所以出现了问题。
    

    4.2 使用synchronized, wait, notify解决该问题(关键代码截图,需出现学号)

    Q5.查询资料回答:什么是线程安全?(用自己的话与代码总结,写自己看的懂的作业)

    答:线程安全问题主要出现在访问临界资源的时候,也就是访问同一个对象的时候,可能会出现无法补救的状况,所以线程安全就显得比较重要了。在java中要想保证线程的安全就要对共同使用的对象进行加锁。“加锁”通俗点说就是我使用的时候,你就必须等待,等我用完之后你才可以用,这样也就避免了不必要的冲突。以下是保证线程安全的一些方法:
    

    ●可以使用synchronized修饰方法实现互斥同步访问,例如:

    public class example1{  
      public synchronized void print(String str){  
       for(int i = 0;i < str.length(); i++){  
        System.out.print(str.charAt(i));  
       }  
       System.out.println();  
      }  
     }
    

    ●使用同步代码块的形式,例如:

    public class example2{  
      public void print(String str){  
       synchronized (this) {  
        for(int i = 0;i < str.length(); i++){  
         System.out.print(str.charAt(i));  
        }  
        System.out.println();  
       }  
      }  
     } 
    

    Q6.选做:实验总结

    6.1 4-8(CountDownLatch)实验总结

    ●PTA4-8实验总结:做这道题之前首先得明白什么是固定线程数线程池和CountDownLatch,所以我查了很多资料去理解这两个新知识,接着我明白了要先创建一个固定线程数的线程池,然后根据题目的要求来完善,这道题就可以完成了。

    6.2 4-9(集合同步问题)实验总结

    ●PTA4-9实验总结:我查了JDK文档后得知,使用synchronizedList()方法可以返回指定列表支持的同步(线程安全的)列表,所以这道题就不难了。

    3. 码云上代码提交记录

    题目集:多线程(4-4到4-10)

    3.1. 码云代码提交记录

    在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图

    3.2 截图多线程PTA提交列表

  • 相关阅读:
    Java服务停止与开启
    跨域,php后端处理
    Mac 504 gateway timeout nginx
    Tp3.2 多数据库链接
    Redis 设置密码
    Redis 如何对外访问 lnmp安装
    tensorflow gpu安装
    ngx_http_upstream_check_module
    Nginx负载均衡+监控状态检测
    springboot+log4j2+slf4j控制台打印带sql日志
  • 原文地址:https://www.cnblogs.com/yjliao/p/6804332.html
Copyright © 2020-2023  润新知