JAVA学习第二十一课(多线程(一)) - (初步了解)
放假在家,歇了好几天了,也没学习,今天学习一下多线程。找找感觉。后天就要回学校了。sad。。。
PS:包 没有什么技术含量,会用就可以,日后开发就必需要会用啦,所以打算先放一放,先来多线程
一、多线程概述
什么是进程?
通俗的说。能够理解为正在进行中的程序,进程实际上是相应的一个应用程序在内存中所属空间。
进程不直接运行的,进程仅仅是分配该应用程序须要的内存空间。线程来负责运行,线程负责进程中内容运行的一个控制单元。也称之为运行路径。也称之为运行情景
什么是线程?
线程就是进程中一个负责程序运行的控制单元(运行路径)
一个进程中能够有多个运行路径。叫做多线程
比方说:360中电脑体检在跑的同一时候垃圾清理也在跑
一个进程其中,至少要有一个线程
开启多个线程是为了同一时候执行多个部分的代码
每个线程都有自己执行的内容。这个内容就能够称为线程要执行的任务
二、多线程的长处与弊端
看似多线程技术。高效,可是存在弊端。
Windows本身就是一个多任务同一时候执行的操作系统,比方Win在执行QQ和360,看似一边在聊QQ,360一边在扫描,他们是同一时候进行,实际上不是,CPU在负责程序的执行。在某一时刻,CPU正在控制QQ的执行。这时360就不会执行,CPU的切换速度很快。所以感觉他们是在同一时候执行,实际上在某一个时刻,仅仅有一个程序在执行,也就是仅仅有一个路径在执行,所以当应用程序开的比較多的时候,就会比較卡。单个程序获取CPU的执行频率就少(PS:CPU的切换是随机的。依赖于时间片)
优点:解决多部分同一时候执行的问题
弊端:线程太多,就会导致效率的减少
所以,多线程技术尽管能够解决多程序同一时候执行的问题,可是程序开多了就会效率低下。甚至死机
当然即便CPU非常强大,可是内存空间不足。相同做不到高速的切换动作
三、JVM中的多线程
虚拟机的启动。本身就依赖着多线程
JVM的启动就启动了多线程,至少有两个线程
1.运行main函数的线程(主线程)
该线程的任务代码都定义在main函数中
2.负责垃圾回收的线程(垃圾回收线程)
主线程在控制main的运行时,堆内存中存在多个垃圾,就会有还有一线程去控制回收垃圾。
举例|:堆内存会产生非常多对象,每一个对象都存在被回收的可能,每一个对象都不一样,有使用底层资源,有不是使用的,对象怎么被回收的仅仅有对象自己清楚,所以每一个对象都具备着能被回收的方法,那么每一个对象都具备的方法就定义在Objectt类中,叫finalize,作用:当垃圾回收器确定不存在对该对象的很多其它引用时,由对象的垃圾回收器调用此方法。
子类重写finalize
方法。以配置系统资源或运行其它清除。
class Demo extends Object
{
public void finalize()
{
System.out.println("Demo.finalize");
}
}
public class Main
{
public static void main(String[] args)
{
new Demo();
new Demo();
System.gc();//启动垃圾回收器
System.out.println("hello word");
}
}
PS:主线程运行到启动垃圾回收器时,垃圾回收线程启动,主线程会继续向下运行,所以先打印helloword,主线程结束,可是其它线程还在继续运行
四、主线程执行实例
对于堆内存并非一产生垃圾就会回收,由于那样会与主线程争夺CPU的运行权。所以在某一时刻谁拿到运行权,谁运行
主线程->aDemo.show()进栈->运行完出栈->bDemo.show()进栈->运行完出栈->return
假设是下述代码
class Demo
{
private String name;
public Demo(String name)
{
// TODO Auto-generated constructor stub
this.name = name;
}
public void show()
{
for(int i = 0;i<10;i++)
{
for(int j = -9999999;j<9999999;j++){}
System.out.println(name+"i = "+i);
}
}
}
public class Main
{
public static void main(String[] args)
{
Demo aDemo = new Demo("A");
Demo bDemo = new Demo("B");
aDemo.show();
bDemo.show();
System.out.println("hello word");
}
}
这样程序会及其慢,并且A不运行完B就无法运行,那么怎样实现A和B同一时候运行。那么就须要实现A在一个路径中,B在一个路径中,CPU进行切换。就能够实现A和B同一时候运行
就样就涉及到了多线程的创建。
JAVA学习第二十一课(多线程(一)) - (初步了解)的更多相关文章
- JAVA学习第二十七课(多线程(六))- 多生产者多消费者问题(JDK1.5新特性)
多生产者多消费者问题 以生产馒头 消费馒头为例. class Resource { private String name; private int count = 1; private boolea ...
- Python学习第二十一课——Mysql 对数据库的基本操作
数据库操作(DDL) 在数据库下创建表(create_table) 创建表代码块: CREATE TABLE employee( id TINYINT PRIMARY KEY auto_increme ...
- 风炫安全WEB安全学习第二十一节课 存储型XSS讲解
风炫安全WEB安全学习第二十一节课 存储型XSS讲解 存储型XSS演示 存储型XSS,持久化,代码是存储在服务器中的,如在个人信息或发表文章等地方,加入代码,如果没有过滤或过滤不严,那么这些代码将储存 ...
- 201671010140. 2016-2017-2 《Java程序设计》java学习第十一周
java学习第十一周 本周,进行了java集合方面的知识,在博客园的帮助下,我的课前预习更有条理性,重点明确,本周的课堂反应明显更好了,首先,梳理一下本周知识点. Collection ...
- “全栈2019”Java异常第二十一章:finally不被执行的情况
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java异 ...
- NeHe OpenGL教程 第二十一课:线的游戏
转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...
- 风炫安全WEB安全学习第二十二节课 DOM型XSS讲解
风炫安全WEB安全学习第二十二节课 DOM型XSS讲解 Dom型XSS演示 通过Javascript,可以重构整个HTML文档,你可以添加.移除.改变或重排页面上的项目 要改变页面的某个东西,Java ...
- 201671010140. 2016-2017-2 《Java程序设计》java学习第二周
学习第二周(Java基本程序设计结构) 这一周,着重学习了Java的简单程序设计实现及运行,通过自己操作,发现Java的程序语法大面 ...
- 2017年1月1日 java学习第二天复习
今天是新年的第一天,以前学习没有总结习惯,学习效率和成果都很不好. 学习的过程就是反复的复习和不断学习的过程,开始今天的学习总结 学习java的第二天. 今天学习了java最基础的一些内容,照着 ...
随机推荐
- Sublime——基本操作
基本安装 程序下载地址:https://www.sublimetext.com/ package control安装 View -> Show Console打开控制台或者用快捷键ctrl+~打 ...
- grunt 全局使用
grunt 不同地方使用时需要将插件下载的当前文件夹,这是因为查找模块时是当前路径,这会造成多个工程使用时会需要下载多次,而这些东西又不应该存在于工程之中,所以应该将所有模块全局安装,然后在工程下面只 ...
- HTML 5 <aside> 标签
定义和用法 <aside> 标签定义 article 以外的内容.aside 的内容应该与 article 的内容相关. 实例 <p>Me and my family visi ...
- RabbitMQ系列(四)--消息如何保证可靠性传输以及幂等性
一.消息如何保证可靠性传输 1.1.可能出现消息丢失的情况 1.Producer在把Message发送Broker的过程中,因为网络问题等发生丢失,或者Message到了Broker,但是出了问题,没 ...
- 「 Luogu P1850 」 换教室
解题思路 很明显的是个期望 $dp$. 先前想到 $dp[i][j]$ 表示第决策到第 $i$ 个时间段,已经进行了 $j$ 次申请,然后就没有然后了,因为这根本就没法转移啊,你又不知道前 $i-1$ ...
- Java 十二周总结
- 【Codeforces 675D】Tree Construction
[链接] 我是链接,点我呀:) [题意] 依次序将数字插入到排序二叉树当中 问你每个数字它的父亲节点上的数字是啥 [题解] 按次序处理每一个数字 对于数字x 找到最小的大于x的数字所在的位置i 显然, ...
- Wow! Such Sequence! (线段树) hdu4893
http://acm.hdu.edu.cn/showproblem.php?pid=4893 先贴上一份还没过的代码,不知道拿出错了 1 // by caonima ; ; ],col[MAX< ...
- [K/3Cloud]进度条控件编程接口
进度条控件编程接口 1.启动进度查询 this.GetControl<ProgressBar>().Start(2) //每2秒查询一次进度 2.汇报进度 在插件中重载 OnQueryP ...
- centos7 安装mongodb3.4 及用户管理
https://docs.mongodb.com/manual/tutorial/install-mongodb-on-red-hat/1.semanage command not found yum ...