CMS专题

问答题多线程有几种实现方法,线程间同步有几种实现方法,都是什么?

题目
问答题
多线程有几种实现方法,线程间同步有几种实现方法,都是什么?
如果没有搜索结果,请直接 联系老师 获取答案。
如果没有搜索结果,请直接 联系老师 获取答案。
相似问题和答案

第1题:

多线程有几种实现方法?同步有几种实现方法?


正确答案:

 

多线程有两种实现方法,分别是继承Thread 类与实现Runnable 接口

同步的实现方面有两种,分别是synchronized,wait 与notify

wait():使一个线程处于等待状态,并且释放所持有的对象的lock。

sleep():使一个正在运行的线程处于睡眠状态,是一个静态方法,调用此方法要捕捉

InterruptedException 异常。

notify():唤醒一个处于等待状态的线程,注意的是在调用此方法的时候,并不能确切的唤

醒某一个等待状态的线程,而是由JVM 确定唤醒哪个线程,而且不是按优先级。

Allnotity():唤醒所有处入等待状态的线程,注意并不是给所有唤醒线程一个对象的锁,

而是让它们竞争。

第2题:

实现一个线程的执行有几种方法? ( )

A.1种

B.2种

C.3种

D.4种


正确答案:C
解析:实现一个线程的执行有3种方法。

第3题:

Python中有哪些实现多线程方法()?

A.multiprocess.dummy

B.threading.Thread

C.process

D.PyMongoDB


参考答案:AB

第4题:

线程的常见方法有哪些,你是如何处理多线程的,多线程同步问题你了解么?


正确答案: 线程创建的几种方式,线程的加锁,休眠,唤醒,解锁,退出,多线程要考虑同步问题,解决同步问题的方式就是对某一资源加锁,当一个线程操作本资源时,其他线程不能操作。
系统自带线程池(NSOpertionQueuE.的作用(凡是需要启动多个线程的地方都可以使用NSOpertionQueue,加入到NSOpertionQueue中的对象都需要继承NSOpertion。NSOpertionQueue会在系统内部启动一个独立线程去执行这个被加入对象的main方法。常用的地方是用nsoprationqueue下载图片,文件。如果是自己创建一个线程池,无非就是启动多个线程的时候,把这些线程对象放到一个大数组中,如果需要启动线程的时候,先从数组中找空闲线程来使用。自己管理线程池最大的难题是不好处理当启动多个线程后,用户在多个界面的跳转的时候,对线程方法的回调管理。而NSOpertionQueue可以很好的处理他。

第5题:

网络管理有几种实现方法?


正确答案:网络管理的实现主要体现在管理的形式上,分为集中式网络管理、分布式网络管理和分层式网络管理。

第6题:

多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么?


正确答案:

1第一种解答:多线程有两种实现方法,分别是继承Thread类与实现Runnable接口
同步的实现方面有两种,分别是synchronized,wait与notify

2第二种解答:有人提出也可以这样:多线程 1. 继承 Thread 类 2. 实现 Runnable 接口再 new Thread(YourRunnableOjbect) 推荐 线程同步 1. 用 synchronized 修饰需要同步的方法 2. 用 synchronized 块包围需要同步的语句 3. 使用 java.util.concurrent 包中的各种同步锁

第7题:

多线程模型有哪几种类型?多对一模型有何优缺点?


答案:多对一模型、一对一模型和多对多模型。多对一模型的主要缺点在于,如果一个线程在访问内核时发生阻塞,则整个进程都会被阻塞;此外,在任一时刻,只有一个线程能够访问内核,多个线程不能同时在多个处理机上运行。

第8题:

java 中有几种方法可以实现一个线程?用什么关键字修

饰同步方法? stop()和suspend()方法为何不推荐使用?


正确答案:

 

有两种实现方法,分别使用new Thread()和new Thread(runnable)形式,第一种直接调用

thread 的run 方法,所以,我们往往使用Thread 子类,即new SubThread()。第二种调

用runnable 的run 方法。

有两种实现方法,分别是继承Thread 类与实现Runnable 接口

用synchronized 关键字修饰同步方法

反对使用stop(),是因为它不安全。它会解除由线程获取的所有锁定,而且如果对象处

于一种不连贯状态,那么其他线程能在那种状态下检查和修改它们。结果很难检查出

真正的问题所在。suspend()方法容易发生死锁。调用suspend()的时候,目标线程会停

下来,但却仍然持有在这之前获得的锁定。此时,其他任何线程都不能访问锁定的资

源,除非被"挂起"的线程恢复运行。对任何线程来说,如果它们想恢复目标线程,同

时又试图使用任何一个锁定的资源,就会造成死锁。所以不应该使用suspend(),而应

在自己的Thread 类中置入一个标志,指出线程应该活动还是挂起。若标志指出线程应

该挂起,便用wait()命其进入等待状态。若标志指出线程应当恢复,则用一个notify()

重新启动线程。

第9题:

在JAVA中创建线程有几种方法


正确答案: 一种是继承java.lang包下的Thread类,重写Thread类的run()方法, 另一种就是实现Runnable接口,Sleep()和wait()有什么区别
调用sleep()方法,正在执行的线程主动让出CPU去执行其他线程,在sleep()方法指定的时间过后,CPU才会回到这个线程上继续往下执行,如果当前线程进入了同步锁,sleep()方法并不会释放锁,即使当前线程使用sleep()方法让出了CPU,但其它被同步锁挡住了的线程也无法得到执行。wait()在一个已经进入了同步锁的线程内进行调用,让当前线程暂时让出同步锁,以便其它正在等待此锁的线程可以得到同步锁并运行。当其它线程调用了notify()方法后,调用wait()方法的线程就会解除wait状态,当再次获得同步锁后,程序可以继续向下执行。

第10题:

Linux系统中线程的同步方式有互斥量、信号量和条件变量等。假设现在需要设计一个多线程的应用程序,试分析一下以上几种同步方式分别可在什么场合下使用。


正确答案: Mutex互斥量,用于操作某个临界资源时对该资源上锁,以实现互斥地对独占资源的使用
Semophore信号灯,信号灯内有一计数器,可以用于对多个同类资源的分配。当资源用完时,申请资源的线程会在信号量上睡眠,有线程释放资源时,再将该线程唤醒继续运行。
Condition条件变量,条件变量用于等待信号。当一个线程需要等待某个信号时,就可到条件变量上等待,当信号具备时,系统会唤醒该线程继续运行。

更多相关问题