多线程(一)

1) 什么是线程?

线程是操作系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位。程序员可以通过它进行多处理器编程,你可以使用多线程对运算密集型任务提速。比如,如果一个线程完成一个任务要100毫秒,那么用十个线程完成改任务只需10毫秒

2) 线程和进程有什么区别?

进程是一个独立的具有一定功能的程序,关于某个集合的一次执行过程。线程是进程的子集,是进程中的一个独立执行单元。一个进程可以有很多线程,每条线程并行执行不同的任务。

区别:

拥有资源:进程是资源的拥有者、管理者,线程是任务的执行者,一个进程中的多个线程之间共享进程资源。

开销大小:进程开销大用于管理资源和线程;线程开销小是任务的执行单元

并发性:进程之间可以并发执行,一个进程中的多个线程之间也可以并发执行

每个进程拥有自己独立的地址空间;每个线程拥有自己独立的栈空间。

3) 如何在Java中实现线程?
在语言层面有两种方式。java.lang.Thread类的实例就是一个线程但是它需要调用java.lang.Runnable接口来执行,
由于线程类本身就是调用的Runnable接口所以你可以继承java.lang.Thread 类或者直接调用Runnable接口来重写run()方法实现线程。

4) 用Runnable还是Thread?
通过继承Thread类或者调用Runnable接口来实现线程,问题是,那个方法更好呢?什么情况下使用它?这个问题很容易回答,如果你知道Java不支持类的多重继承,但允许你调用多个接口。所以如果你要继承其他类,当然是调用Runnable接口好了

5) Thread类中的start()和run()方法有什么区别?
start()方法被用来启动新创建的线程,而且start()内部调用了run()方法,这和直接调用run()方法的效果不一样。
当你调用run()方法的时候,只会是在原来的线程中调用,没有新的线程启动,start()方法才会启动新线程

6) Java中Runnable和Callable有什么不同?
Runnable和Callable都代表那些要在不同的线程中执行的任务。Runnable从JDK1.0开始就有了,Callable是在JDK1.5增加的。
它们的主要区别是Callable的 call() 方法可以返回值和抛出异常,而Runnable的run()方法没有这些功能。Callable可以返回装载有计算结果的Future对象

7) Java内存模型是什么?
Java内存模型规定和指引Java程序在不同的内存架构、CPU和操作系统间有确定性地行为。它在多线程的情况下尤其重要。Java内存模型对一个线程所做的变动能被其它线程可见提供了保证,它们之间是先行发生关系。这个关系定义了一些规则让程序员在并发编程时思路更清晰。比如,先行发生关系确保了:
线程内的代码能够按先后顺序执行,这被称为程序次序规则。
对于同一个锁,一个解锁操作一定要发生在时间上后发生的另一个锁定操作之前,也叫做管程锁定规则。
前一个对volatile的写操作在后一个volatile的读操作之前,也叫volatile变量规则。
一个线程内的任何操作必需在这个线程的start()调用之后,也叫作线程启动规则。
一个线程的所有操作都会在线程终止之前,线程终止规则。
一个对象的终结操作必需在这个对象构造完成之后,也叫对象终结规则。
可传递性

java的内存模型包括两个部分:主存和本地栈。线程在处理数据时,将数据从主存load到本地栈,数据处理完毕之后再将数据从本地栈save到主存中。

8) Java中的volatile变量是什么?
volatile用于修饰成员变量,volatile就是告诉VM从内存中读取该变量的值。
在Java并发程序缺少同步类的情况下,多线程对成员变量的操作对其它线程是透明的。
volatile变量可以保证下一个读取操作会在前一个写操作之后发生,就是上一题的volatile变量规则

9) 什么是线程安全?Vector是一个线程安全类吗?
如果你的代码所在的进程中有多个线程在同时运行,而这些线程可能会同时运行这段代码。
如果每次运行结果和单线程运行的结果是一样的,而且其他的变量的值也和预期的是一样的,就是线程安全的。或者是在同一时刻,对某一共享资源的访问最多只能有一个线程。
一个线程安全的计数器类的同一个实例对象在被多个线程使用的情况下也不会出现计算失误。
Vector是用同步方法来实现线程安全的, 而和它相似的ArrayList/LinkedList不是线程安全的。

10) Java中什么是竞态条件? 举个例子说明。
竞态条件会导致程序在并发情况下出现一些bugs。多线程对一些资源的竞争的时候就会产生竞态条件,
如果首先要执行的程序竞争失败排到后面执行了,那么整个程序就会出现一些不确定的bugs。
这种bugs很难发现而且会重复出现,因为线程间的随机竞争。
多线程并发执行时,对某一共享资源的竞争,导致先要执行的线程因为竞争失败排到了后面执行而引起一系列莫名其妙的问题。
例子就是:无序处理。


11) Java中如何停止一个线程?
Java提供了很丰富的API但没有为停止线程提供API。
JDK 1.0本来有一些像stop(), suspend()和 resume()的控制方法但是由于潜在的死锁威胁因此在后续的JDK版本中他们被弃用了,
之后Java API的设计者就没有提供一个兼容且线程安全的方法来停止一个线程。当run()或者call()方法执行完的时候线程会自动结束。
如果要手动结束一个线程,你可以用volatile布尔变量来退出run()方法的循环或者是取消任务来中断线程,或者是用Cancel()方法退出循环。

12) 一个线程运行时发生异常会怎样?
如果异常没有被捕获该线程将会停止执行。Thread.UncaughtExceptionHandler是用于处理未捕获异常造成线程突然中断情况的一个内嵌接口。当一个未捕获异常将造成线程中断的时候JVM会使用Thread.getUncaughtExceptionHandler()来查询线程的UncaughtExceptionHandler并将线程和异常作为参数传递给handler的uncaughtException()方法进行处理。


13) 如何在两个线程间共享数据?
采用共享对象的方法来共享数据,使用wait()/notify()/notifyall()对共享数据进行等待和唤醒,或者使用阻塞队列这样并发的数据结构实现数据共享。


14) Java中notify 和 notifyAll有什么区别?
(1)、notify()方法:唤醒一个处于等待状态的线程,是异步的,jvm决定唤醒哪一个线程,对于一个线程是有意义的。不能唤醒某个具体的线程,所以只有一个线程在等待的时候它才有用武之地。
(2)、notifyAll()唤醒所有的线程,并允许他们争夺锁确保了至少有一个线程能继续运行。


15) 为什么wait, notify 和 notifyAll这些方法不在thread类里面?
由于wait(),notify()和notifyAll()都是对锁的操作,并且锁是属于对象的,每个对象都可以进行加锁和解锁,所以把他们定义在Object类中。
因为JAVA提供的锁是对象级的而不是线程级的,每个对象都有锁,通过线程获得。如果线程需要等待某些锁那么调用对象中的wait()方法就有意义了。


16) 什么是ThreadLocal变量?
(1)、ThreadLocal为每个使用该变量的线程提供独立的变量副本,所以每一个线程都可以独立地改变自己的副本,而不会影响其它线程所对应的副本。
(2)、它是为创建代价高昂的对象获取线程安全的好方法,但是会消耗大量的内存资源。
(3)、在ThreadLocal类中有一个Map,用于存储每一个线程的变量副本,Map中元素的key为线程对象,而value对应线程的变量副本。
(4)、ThreadLocal解决多线程的并发访问,ThreadLocal提供了线程安全的共享对象,在编写多线程代码时,可以把不安全的变量封装进ThreadLocal。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/464633.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DiscoveryService.getRemoteAdvertisements是否会获得本地通告?

从该方法名称上来说,应该是不能获得本地通告,本着探究的精神,首先做个小测试,再从源代码中寻找答案。----------------------------------------------------------------------------- 测试结果:本地通告确实取不到&a…

java ssh 和mvc_JAVA三大框架SSH和MVC

Java—SSH(MVC)JAVA三大框架的各自作用hibernate是底层基于jdbc的orm(对象关系映射)持久化框架,即:表与类的映射,字段与属性的映射,记录与对象的映射 数据库模型 也就是Model;struts提供的丰富标签是用于显示层View;同时struts也充…

Linux的bc命令计算π的值预估系统算力

这是今天突然想到的一个事情,几年前我和一个朋友做一个开发板,然后我们需要完成的这个开发板有算力的要求,当时我们测试的时候就用了一个shell脚本来分析系统的算力。今天我突然想不起这个命令,然后就想写篇文章记录下&#xff0c…

hotmail在outlook2007中的设置

在姓名中输入你的名字(用户可自定义),在电子邮件地址中输入你要设置OutLook的电子邮件地址,账户类型设为POP3,接收邮件服务器为pop3.live.com,发送邮件服务器为smtp.live.com。在用户名中输入你的邮箱用户名…

第九章 图形用户界面的并行化(待续)

为什么GUI是单线程的转载于:https://www.cnblogs.com/hzzjj/p/9825864.html

SQL版DNN的安装心得

最重要的是,DNN必须在WEB HOST 的根目录。中国RainBow提醒的。这是装成的关键!另外的主要两个问题,一是CONNECTIONSTRING中的PWD有&符号,出错。通过SQL 的企业管理器登陆REMOTE SQL SERVER修改PASSWORD。(应该试一试 Integrated Security…

面向对象的思想是什么?

我同事的回答,我觉得这句话可以读十遍说下我自己的理解你不是人,你是猪。解释一下我们在编写面向对象的代码时,一定要有抽象的思想,什么是抽象,抽象是一种概念的东西,不是实实在在的,看不见摸不…

java 数组正则表达式_java正则表达式实现提取需要的字符并放入数组【ArrayList数组去重复功能】...

本文实例讲述了java正则表达式实现提取需要的字符并放入数组。分享给大家供大家参考,具体如下:这里演示java正则表达式提取需要的字符并放入数组,即arraylist数组去重复功能。具体代码如下:package com.test.tool;import java.uti…

多线程(三)

38) 如何在Java中创建Immutable对象?要创建不可变类,要实现下面几个步骤:(1)、通过构造方法初始化所有成员;(2)、对变量不要提供set方法;(3)、将所有的成员声明为私有的,这样就不允许直接访问这些成员&…

安装SQL2005只有配置工具或 错误码是29506 解决方案

在windows7下安装SQL2005时会提示不兼容,需要安装SQL2005 SP3或更高的版本,不用管它,一路安装下去,等装完在开始菜单没有SQL Server Management Studio。 没关系,只要下载微软的“SQL Server Management Studio Expres…

第37课 thinkphp5添加商品基本信息及通过前置钩子上传商品主图 模型事件(勾子函数)...

目录 手册地址:before_insert(新增之前的操作)要实现的功能思路触发条件:1. 控制器里必须要调用模型的save()方式保存数据,用insert()触发不了勾子函数的2. 模型初使化init()里使用 Goods::beforeInsert手册地址: https://www.kancloud.cn/manual/thinkphp5/135195 before_inse…

python编程格式化输出_Python的三种格式化输出

今天刚学了python的三种格式化输出,以前没接触过这么有趣的输出方式,现在来分享一下。#!/user/bin/env python#coding:utf-8#三种格式化输出#第一种格式化输出nameinput("name:")ageinput("age:")jobinput("job:")salaryi…

年轻,可以不气盛?

昨天和我一个好友电话,因为到了年末,我们互相说一些自己工作上的情况,本来是在微信聊着。我然后说了句,我想跟自己的领导提下建议,因为感觉在这边工作了一段时间,想把自己对工作上的一些看法和领导分享&…

加深昨天的話題,把一些模糊的概念統一一下 日期:2004-05-19。

加深昨天的話題&#xff0c;把一些模糊的概念統一一下 日期:2004-05-19。 <Code 1>unit dmOrderTimeModule; interface uses SysUtils, Variants, Classes, dmBaseModuleImp, hmStrTools, hmSqlTools, hmDateTools, hmTimeTools; type TdmOrderTime class(TBaseDataMo…

多线程的异常捕捉

为什么要单独讲多线程的异常捕捉呢&#xff1f;先看个例子&#xff1a; public class ThreadException implements Runnable{Overridepublic void run() {throw new RuntimeException();}//现象&#xff1a;控制台打印出异常信息&#xff0c;并运行一段时间后才停止public stat…

Linux 安装配置JDK 、 MySQL 、nginx

今天我来讲一下在Linux下各环境的搭建&#xff0c;主要就讲一下jdk、MySQL、和一个代理服务器nginx 1、 jdk的安装配置 1)卸载自带openjdk 当我们拿到一个全新的ECS的时候上面有的会自带一个openjdk&#xff0c;但是我们一般不会用这个&#xff0c;所以在这里我们会先卸载这个自…

Flex与javascript通信

首先列出代码部分&#xff0c;我们可以先尝试的感受一下效果&#xff1a; 1.Flex代码部分&#xff1a;文件名为Flex_Javascript.mxml <?xml version"1.0" encoding"utf-8"?><s:Application xmlns:fx"http://ns.adobe.com/mxml/2009" …

wat java_并发工具优于wati、notify(69)

现在几乎没有理由在使用wait 和 notify&#xff0c;使用高级工具代替java.util.concurrent 包并发工具分三类&#xff1a;Executor 框架并发集合(concurrent Collection)同步器(synchronizer)并发集合对标准集合接口(List、Map、Queue)封装了高性能的并发实现为了提高并发性&am…

一道关于 fork 的笔试题

题目阅读下面的代码&#xff0c;显示终端会打印出几个 hello world&#xff1f;#include <sys/types.h> #include <unistd.h> #include <stdio.h> #include <stdlib.h>int main() {fork();fork();fork();printf("hello world\n");exit(0); }…

最新招聘公司网站 以及学校的宣讲会

http://campusys.chinahr.com/E/unilever/ 联合利华http://www.mckinsey.com/ 麦肯锡http://www.asap.net.cn/ 信杰 http://guangzhouhonda.51job.com/grad.php 广州本田汽车http://www.hanagroup.com/http://www.augmentum.com/http://www.tetrapak.com.cn/welcome2.htm …