Java 并发编程实践基础 读书笔记: 第一章 JAVA并发编程实践基础
1.创建线程的方式:
/**
* StudySjms
* <p>
* Created by haozb on 2018/2/28.
*/
public class ThreadDemo extends Thread {
/**
* 定义线程的名字
* @param name
*/
public ThreadDemo(String name) {
super(name);
} @Override
public void run() {
for (int i = ; i < ; i++) {
System.out.println(this.getName()+":"+i);
}
} public static void main(String[] args) {
for (int i = ; i < ; i++) {
new ThreadDemo("name"+i).start();
}
}
}
/**
* StudySjms
* <p>
* Created by haozb on 2018/2/28.
*/
public class ThreadDemo implements Runnable {
@Override
public void run() {
for (int i = ; i < ; i++) {
System.out.println(Thread.currentThread().getName()+":"+i);
}
} public static void main(String[] args) {
/* Runnable demo = new ThreadDemo();
for (int i = 0; i < 3; i++) {
new Thread(demo,""+i).start();
}*/ // 也可以直接采用内名内部类方式来创建
final int num = ;
for (int i = ; i < ; i++) {
new Thread(new Runnable() {
@Override
public void run() {
for (int i = ; i < num; i++) {
System.out.println(Thread.currentThread().getName()+":"+i);
}
}
},""+i).start();
}
}
}
Executors其实就是工厂类,用来创建各种的线程池;
import java.util.concurrent.*; /**
* StudySjms
* <p>
* Created by haozb on 2018/2/28.
*/
public class ThreadPool {
public static void main(String[] args) {
//ExecutorService pool = Executors.newFixedThreadPool(2);
// 这种是固定线程数的线程池,控制了现场的最大并发量
//ExecutorService pool = Executors.newCachedThreadPool();
// 这种没有长度限制,会自动控制池的大小,如果任务多了,会创建新现场,如果任务少了,会回收线程
//ScheduledExecutorService pool = Executors.newScheduledThreadPool(5);
/*
这种例子是延迟3秒执行
pool.schedule(new Runnable() {
@Override
public void run() { }
},3,TimeUnit.SECONDS);*/
/*
这种是延迟1秒 每3秒执行一次
pool.scheduleAtFixedRate(new Runnable() {
@Override
public void run() { }
},1,3,TimeUnit.SECONDS);*/
/*
相当于单线程执行任务,有顺序
ExecutorService singleThreadExecutor = Executors.newSingleThreadExecutor();
*/ ExecutorService pool = new ThreadPoolExecutor(,,0L, TimeUnit.MILLISECONDS,new LinkedBlockingDeque<Runnable>());
for (int i = ; i < ; i++) {
final int tmp = i;
Runnable run = new Runnable() {
@Override
public void run() {
long time = (long)(Math.random()*);
System.out.println(Thread.currentThread().getName()+":"+tmp+"sleeping"+time); try {
Thread.sleep(time);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
};
pool.execute(run);
}
pool.shutdown();
}
}
线程的基本控制方法:
Thread.sleep(); 使线程睡眠,放弃cpu
join :使一个线程等待另一个线程完事在执行。eg: t1里面,t2.join() t1暂停执行,立即执t2,t2执行完事之后再去执行t1
可以有参数,t2.join(10); 表示为t1只等t210毫秒就继续执行了
interrupt():中断线程,有些时候需要在线程执行过程中中断线程。
Java 并发编程实践基础 读书笔记: 第一章 JAVA并发编程实践基础的更多相关文章
- 深入Java虚拟机读书笔记第一章Java体系结构介绍
第1章 Java体系结构介绍 Java技术核心:Java虚拟机 Java:安全(先天防bug的设计.内存).健壮.平台无关.网络无关(底层结构上,对象序列化和RMI为分布式系统中各个部分共享对象提供了 ...
- javascript 数据结构和算法读书笔记 > 第一章 javascript的编程环境和模型
1.变量的声明和初始化 必须使用关键字 var,后跟变量名,后面还可以跟一个赋值表达式. var name; var age = 5; var str = 'hello'; var flg = fal ...
- Java核心技术(卷一)读书笔记——第一章(概述)
1.Java不提供多重继承,通过接口来实现.一个类只能继承一个父类,但是可以同时实现多个接口. 2.Java中的int类型的大小是固定的32位,以避免代码移植时候的不兼容问题.唯一的限制是int类型的 ...
- 《Java并发编程实战》读书笔记-第一部分 基础知识小结
并发技巧清单 可变状态是至关重要的 所有的并发问题都可以归结为如何协调对并发状态的访问.可变状态越少,就越容易确保线程安全性. 尽量将域声明为final类型,除非需要它们是可变的. 不可变对象一定是线 ...
- .net架构设计读书笔记--第一章 基础
第一章 基础 第一节 软件架构与软件架构师 简单的说软件架构即是为客户构建一个软件系统.架构师随便软件架构应运而生,架构师是一个角色. 2000年9月ANSI和IEEE发布了<密集性软件架构建 ...
- 《疯狂Java:突破程序员基本功的16课》读书笔记-第一章 数组与内存控制
很早以前就听过李刚老师的疯狂java系列很不错,所以最近找一本拿来拜读,再此做下读书笔记,促进更好的消化. 使用Java数组之前必须先对数组对象进行初始化.当数组的所有元素都被分配了合适的内存空间,并 ...
- 《Java编程思想》读书笔记-第一个Java程序
积少成多,欢迎大家关注我的微信公众号,共同探讨Java相关技术 今天的重点是:编写源代码.编译.运行.查看成果.除此之外,还需要搭建起与前面学习的知识的联系. 写本文时依据的系统环境是Windows1 ...
- 《css3实战》读书笔记 第一章 基于CSS需求而编写的HTML.
笔记说明 <CSS3实战手册第3版(影印版)>可以消除Web设计工作的痛苦,并且带给你:HTML--重新入门.如果你是HTML新手,你会学到如何以CSS友好的方式进行基本页面构造.若你是H ...
- Java 学习笔记 ------第一章 Java平台概论
本章学习目标: Java版本迁移简介 认识Java SE.Java EE.Java ME 认识JDK规范与操作 了解JVM.JRE与JDK 下载与安装JDK 一.Java版本迁移简介 书上已经表达得非 ...
- 《C++ Primer》读书笔记 第一章
读<C++ Primer>才知道,自己对C++知之甚少... 写个博客记录下自己C++的成长,只是读书笔记,不是对<C++ Primer>知识点的总结,而是对自己在书上看到的以 ...
随机推荐
- Flex的 Event中属性currentTarget与target的区别
Flex的 Event中属性currentTarget与target的区别 1.区别 (1)currentTarget是事件的处理对象(event processor) (2)target是事件的调用 ...
- js、css动态压缩页面代码
1.js.css动态压缩页面代码 <%@ Page Language="C#" AutoEventWireup="true" CodeFile=" ...
- Cookie操作类、压缩、序列化
1.cookie类 CartCookie.cs using System; using System.Data; using System.Configuration; using System.We ...
- CF368 D - Persistent Bookcase
re了20多发 还是我在测试数据上操作最后了10多发才发现的 其实只需要多加一句就好了 真的愚蠢啊,要不都能进前100了 #include<bits/stdc++.h> using nam ...
- 三:Linux 的基本命令、
Ubuntu切换用户 su root sudo passwd root 使用管理员提权修改root 登录密码 连续输入两次即可..... 重置root 用户密码 例:当前登录用户为:ubuntu,但是 ...
- 【CJOJ P1957】【NOIP2010冲刺十模拟赛】数字积木
[NOIP2010冲刺十模拟赛]数字积木 Description 小明有一款新式积木,每个积木上都有一个数,一天小明突发奇想,要是把所有的积木排成一排,所形成的数目最大是多少呢? 你的任务就是读入n个 ...
- 【Luogu2711】小行星(网络流,最大流)
[Luogu2711]小行星(网络流,最大流) 题面 题目描述 星云中有n颗行星,每颗行星的位置是(x,y,z).每次可以消除一个面(即x,y或z坐标相等)的行星,但是由于时间有限,求消除这些行星的最 ...
- animate 动画滞后执行的解决方案
jQuery动画: animate 容易出现连续触发.滞后反复执行的现象: 针对 jQuery 中 slideUp.slideDown.animate 等动画运用时出现的滞后反复执行等问题的解决方法有 ...
- Redis进阶实践之十七 Redis协议的规范
一.介绍 Redis客户端使用称为RESP(Redis的序列化协议)的协议与Redis服务器进行通信. 虽然协议是专门为Redis设计的,但它可以用于其他客户端 - 服务器软件项 ...
- Redis之Set
一.Redis之Set简介 1. Set是String类型的无序集合(元素成员唯一). 2. Set是通过hash表实现的,添加.删除.查找的复杂度都是O(1). 3. 每个集合最大成员数为232-1 ...