java - day017 - 线程
- 进程
- 操作系统中, 并行执行的任务
- 线程
- 进程内部, 并行执行的任务
- 进程包含线程
- 线程的创建
- 继承Thred
- 定义 Thred 的子类
- 重写 run() 方法
- 在 run() 方法中的代码, 是与其他代码并行的代码
- 线程启动后, 自动执行
package day1702_线程; public class Test1 {
public static void main(String[] args) { T1 t1 = new T1();
T1 t2 = new T1(); // 创建线程对象 t1.start(); // 启动线程后, 自动执行
t2.start(); System.out.println("main"); } static class T1 extends Thread{ // 继承线程
@Override
public void run() {
super.run(); super.setName("thred1");// 设置线程名称 super.getName();// 获取线程名 String n = super.getName(); for (int i = ; i < ; i++) {
System.out.println(n+": "+i);
} }
}
}
- 实现 Runnable
- 定义 Runnable 子类
- 实现 run() 方法
- 把 Runnable 对象, 放入Thred 线程对象启动
- 线程启动后, 执行 Runnable 对象的 Run() 方法
package day1702_线程; public class Test2 {
public static void main(String[] args) { R1 r1 = new R1();// 创建 R1 对象
R1 r2 = new R1(); Thread t1 = new Thread(r1); // 创建线程
Thread t2 = new Thread(r2); t1.start(); // 执行线程
t2.start(); } static class R1 implements Runnable{
@Override
public void run() { // 获得 正在执行这行代码的线程对象
Thread t = Thread.currentThread(); // 获得线程名
String n = t.getName();
for (int i = ; i < ; i++) {
System.out.println(n+": "+i);
}
}
} }- 线程的状态
- 新生
- 可执行
- 阻塞
- 执行
- 消亡 即run()结束
- 线程的方法
- Thread.currentThread(); // 获得正在执行这行代码的线程对象
- Thread.sleep(毫秒值) // 当前线程暂停指定的毫秒时间
- iterrupt()
- 打断一个线程的暂停状态, 被打断的线程会出现异常
- InterruptedException
package day1702_线程; import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Scanner; public class Test3 {
public static void main(String[] args) {
T1 t1 = new T1();
t1.start(); // main 线程 打断t1 线程的暂停状态
System.out.println("按回车打断 t 线程");
new Scanner(System.in).nextLine(); t1.interrupt(); // 打断
} static class T1 extends Thread{
@Override
public void run() {
// TODO Auto-generated method stub
super.run(); SimpleDateFormat sdf =
new SimpleDateFormat("HH:ss:mm"); while (true) {
String s = sdf.format(new Date());
System.out.println(s); // 停一秒
try {
Thread.sleep();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace(); System.out.println("谁TMD桶我");
break; } } }
}
}- join(); //当前线程,等待被调用的线程结束
package day1702_线程; public class Test4 {
public static void main(String[] args) throws InterruptedException {
// 1000万内的质数数量 System.out.println(" 单线程");
f1();
System.out.println("五个线程");
f2(); } private static void f1() throws InterruptedException {
long t = System.currentTimeMillis(); T1 t1 = new T1(,);
t1.start(); // 让main 线程等待 t1 结束
t1.join();
int r = t1.count; t = System.currentTimeMillis() - t;
System.out.println("执行时间: "+t);
System.out.println("质数数量: "+r);
} private static void f2() throws InterruptedException {
// TODO Auto-generated method stub
long t = System.currentTimeMillis(); T1[] a = new T1[];
for (int i = ; i < a.length; i++) {
a[i] = new T1(*i,*(i+));
a[i].start();
} int sum = ;
for (T1 t1 : a) {
t1.join();
sum+=t1.count;
} t = System.currentTimeMillis() - t;
System.out.println("执行时间: "+t);
System.out.println("质数数量: "+sum);
} static class T1 extends Thread{ int from;
int to;
int count; //最终结果,质数的数量 public T1(int from, int to) {
if (from <= ) {
count = ;
from = ;
} this.from = from;
this.to = to;
} @Override
public void run() {
// TODO Auto-generated method stub
super.run(); for (int i = from; i < to; i++) {
if (isPrime(i)) {
count++;
}
} } // 是否是质数
private boolean isPrime(int i) {
double max = +Math.sqrt(i);
for (int j = ; j < max; j++) {
if (i%j == ) {
return false;
}
} return true;
} }
}- Thread.yield();
- 当前线程放弃时间片, 让出 cpu 资源
- getPriority(), setPriority();
- 优先级, 1到10, 默认5
- setDaemon(true);
- 后台线程,守护线程
- 一般所有前台线程结束,虚拟机自动退出
package day1702_线程; import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Scanner; public class Test3 {
public static void main(String[] args) {
T1 t1 = new T1();
t1.start(); Thread t2 = new Thread() {
@Override
public void run() {
// TODO Auto-generated method stub
super.run(); System.out.println("按回车打断 t 线程");
new Scanner(System.in).nextLine(); t1.interrupt(); // 打断
}
}; t2.setDaemon(true); // 设置后台线程
t2.start();
} static class T1 extends Thread{
@Override
public void run() {
// TODO Auto-generated method stub
super.run(); SimpleDateFormat sdf =
new SimpleDateFormat("HH:ss:mm"); for (int i = ; i < ; i++) {
String s = sdf.format(new Date());
System.out.println(s); // 停一秒
try {
Thread.sleep();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace(); System.out.println("谁TMD桶我");
break; }
} }
}
}
- 多线程的数据访问冲突
- 多个线程, 共享访问数据
- 一个线程访问到修改的一半的数据,称为 脏数据
- 线程同步 synchronized
- 多个线程,步调一致的执行
- 让多个线程, 争夺同一个对象的 同步锁
- 谁抢到谁执行, 抢不到等待
- 同步锁
- 任何对象, 都有一个唯一的同步锁
- synchronized
- 遇到同步关键字, 要先抢到锁才能执行,否则等待
- synchronized(对象){ }
- 争夺指定对象的锁
package day1702_线程; import java.util.Arrays; public class Test5 { static char[] a = {'-','-','-','-'};
static char v = '*'; public static void main(String[] args) {
new Thread() {
@Override
public void run() {
// TODO Auto-generated method stub
super.run(); while (true) { // 数组同步锁
synchronized (a) {
for (int i = ; i < a.length; i++) {
a[i] = v;
}
v = (v=='*'?'-':'*');
} }
}
}.start(); new Thread() {
@Override
public void run() {
// TODO Auto-generated method stub
super.run(); while (true) {
// 数组同步锁
synchronized (a) {
System.out.println(Arrays.toString(a));
} }
}
}.start();
}
}- synchronized void f() { };
- 抢当前对象的锁
package day1702_线程; public class Test6 {
public static void main(String[] args) { R1 r1 = new R1(); Thread t1 = new Thread(r1);
t1.start(); // main 线程死循环 ,检查 i 是否是奇数
while (true) { int i = r1.get();
if (i%==) {
System.out.println(i);
System.exit();// 关闭虚拟机 } }
} static class R1 implements Runnable{ static int i; synchronized public void add(){
i++;
i++;
} synchronized public int get() {
return i;
} @Override
public void run() {
// TODO Auto-generated method stub
while (true) {
add();
}
}
}
}- static synchronized void f() { };
- 抢类的锁
package day1702_线程; public class Test6 {
public static void main(String[] args) { R1 r1 = new R1();
R1 r2 = new R1(); Thread t1 = new Thread(r1);
t1.start(); Thread t2 = new Thread(r2);
t2.start(); // main 线程死循环 ,检查 i 是否是奇数
while (true) { int i = r2.get();
if (i%==) {
System.out.println(i);
System.exit();// 关闭虚拟机 } }
} static class R1 implements Runnable{ static int i; static synchronized public void add(){
i++;
i++;
} static synchronized public int get() {
return i;
} @Override
public void run() {
// TODO Auto-generated method stub
while (true) {
add();
}
}
}
}
java - day017 - 线程的更多相关文章
- java之线程
java之线程 一:线程: 线程是什么呢?线程,有时被称为轻量级进程是程序执行流的最小单元.一个标准的线程由线程ID,当前指令指针(PC),寄存器集合和堆栈组成.另外,线程是进程中的一个实体,是被系统 ...
- Java 使用线程方式Thread和Runnable,以及Thread与Runnable的区别
一. java中实现线程的方式有Thread和Runnable Thread: public class Thread1 extends Thread{ @Override public void r ...
- Java的线程安全
线程安全 我们这里讨论的线程安全,就限定于多个线程之间存在共享数据访问这个前提,因为如果一段代码根本不会与其他线程共享数据,那么从线程安全的角度来看,程序是串行执行还是多线程执行对它来说是完全没有区别 ...
- 深入理解Java之线程池
原作者:海子 出处:http://www.cnblogs.com/dolphin0520/ 本文归作者海子和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则 ...
- java中线程分两种,守护线程和用户线程。
java中线程分为两种类型:用户线程和守护线程. 通过Thread.setDaemon(false)设置为用户线程: 通过Thread.setDaemon(true)设置为守护线程. 如果不设置次属性 ...
- java 多线程—— 线程让步
java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...
- java 多线程—— 线程等待与唤醒
java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...
- Java的线程模型
并发不一定要依赖多线程(如PHP中很常见的多进程并发),但是在Java里面谈论并发,大多数都与线程脱不开关系. 线程是比进程更轻量级的调度执行单位,线程的引入,可以把一个进程的资源分配和执行调度分开, ...
- Java多线程 - 线程状态
转自: http://www.cnblogs.com/lwbqqyumidi/p/3804883.html 一.线程的生命周期及五种基本状态 关于Java中线程的生命周期,首先看一下下面这张较为经典的 ...
随机推荐
- LeetCode_404. Sum of Left Leaves
404. Sum of Left Leaves Easy Find the sum of all left leaves in a given binary tree. Example: 3 / \ ...
- 超文本css样式换行
之前有关于LODOP中纯文本换行的相关博文:Lodop纯文本英文-等符号自动换行问题纯文本的遇到不拆分的单词的时候,可以通过LODOP 语句设置允许标点溢出,且英文单词拆开.超文本需要通过css样式控 ...
- web端自动化——python多线程
Python通过两个标准库thread和threading提供对线程的支持.thread提供了低级别的.原始的线程以及一个简单的锁.threading基于Java的线程模型设计. 锁(Lock)条件变 ...
- 打印格式化printf
#define _DEBUG_ #ifdef _DEBUG_#define printm(fmt, ...) do { printf("%s line %d, "fmt, __f ...
- 读取以key=value形式存储的txt文件
代码片段(假设只有3个key=value): public static void main(String[] args) throws IOException { BufferedReader br ...
- 【转】JS中处理Number浮点数精度问题
https://github.com/dt-fe/number-precision ~(function(root, factory) { if (typeof define === "fu ...
- python防止sql注入的方法
python防止sql注入的方法: 1. 使用cursor.execute(sql, args)的参数位: sql_str = "select * from py_msgcontrol.py ...
- SpringMVC常用注解@Controller,@Service,@repository,@Component,@Autowired,@Resource,@RequestMapping
1.controller层使用@Controller注解-用于呈现层,(spring-mvc) @Controller 用于标记在一个类上,使用它标记的类就是一个SpringMVC Controlle ...
- PHP 生成公钥私钥,加密解密,签名验签
test_encry.php <?php //创建私钥,公钥 //create_key(); //要加密内容 $str = "test_str"; //加密 $encrypt ...
- hugepage设置
1.设置memlock 编辑/etc/security/limits.conf 增加: * Soft memlock 稍小于RAM值 * hard memlock 稍小于RAM值 Memlock,锁定 ...