1,线程状态转换

无限期等待:

限期等待:

线程生命流程:

2,实现方式

代码实现样例【三种方式】:

package com.cnblogs.mufasa.demo2;

import java.util.concurrent.Callable;

public class test1_Runnable implements Runnable{
@Override
public void run() {
for(int i=0;i<50;i++){
System.out.println("当前线程:"+i);
}
}
} class test2_Callable implements Callable<String> {
private int num;
public test2_Callable(){}
public test2_Callable(int num){
this.num=num;
}
@Override
public String call() throws Exception {
for(int i=0;i<50;i++){
System.out.println(this.num+"线程:"+i);
}
return num+"线程已完成";
}
} class test3_Thread extends Thread {
private int num;
public test3_Thread(){}
public test3_Thread(int num){
this.num=num;
}
@Override
public void run() {
for(int i=0;i<50;i++){
System.out.println(this.num+"线程:"+i);
}
}
}
package com.cnblogs.mufasa.demo2;

import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask; public class Client {
public static void main(String[] args) throws ExecutionException, InterruptedException {
//实现 Runnable 接口
// test1_Runnable instance=new test1_Runnable();
// Thread thread=new Thread(instance);
// Thread thread1=new Thread(instance);
// thread.start();
// thread1.start(); //实现 Callable 接口
// test2_Callable instance=new test2_Callable(1);
// FutureTask<String> ft=new FutureTask<>(instance);
// Thread thread = new Thread(ft);
// test2_Callable instance1=new test2_Callable(2);
// FutureTask<String> ft2=new FutureTask<>(instance1);
// Thread thread1 = new Thread(ft2);
//
// thread.start();
// thread1.start();
// System.out.println(ft.get());
// System.out.println(ft2.get()); //继承 Thread 类
test3_Thread thread1=new test3_Thread(1);
test3_Thread thread2=new test3_Thread(2);
thread1.start();
thread2.start(); }
}

3,基础线程机制

代码实现样例:

package com.cnblogs.mufasa.demo3;

public class Client1 {
public static void main(String[] args) throws InterruptedException { //设置守护线程 setDaemon 伴随线程而运行
// Thread thread1 = new Thread(new test1_Runnable(1));
// Thread thread2 = new Thread(new test3_Thread(2));
// thread1.setDaemon(true);
// thread1.start();
// thread2.start(); //sleep Thread.sleep(millisec) 方法会休眠当前正在执行的线程,millisec 单位为毫秒
// sleep() 可能会抛出 InterruptedException,因为异常不能跨线程传播回 main() 中,因此必须在本地进行处理
// Thread thread1 = new Thread(()->{
// try {
// System.out.println("延迟2s");
// Thread.sleep(2000);
// System.out.println("延迟结束");
// } catch (InterruptedException e) {
// e.printStackTrace();
// }
// });
// thread1.start(); // new Thread(new Runnable() {
// @Override
// public void run() {
// System.out.println("延迟2s");
// try {
// Thread.sleep(2000);
// System.out.println("延迟结束");
// Thread.yield();//可以让出资源
// Thread.sleep(2000);
// } catch (InterruptedException e) {
// e.printStackTrace();
// }finally {
// System.out.println("线程1运行结束");
// }
// }
// }).start();
//
// new Thread(()->{
// try {
// Thread.sleep(2000);
// } catch (InterruptedException e) {
// e.printStackTrace();
// }finally {
// System.out.println("线程2延迟结束");
// }
// }).start(); Thread t = new Thread(new Runnable(){
public void run(){
System.out.println("First task started");
System.out.println("Sleeping for 2 seconds");
try{
Thread.sleep();
} catch (InterruptedException e){
e.printStackTrace();
}
System.out.println("First task completed");
}
});
Thread t1 = new Thread(new Runnable(){
public void run(){
System.out.println("Second task completed");
}
});
//在t执行完毕后t1执行
t.start(); // Line 15
t.join(); // Line 16
t1.start(); }
}

4,中断

package com.cnblogs.mufasa.demo4;

import java.util.concurrent.Executor;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future; import static java.lang.Thread.interrupted; class InterruptExample extends Thread {
@Override
public void run() {
System.out.println("sleep 2s");
try {
Thread.sleep(2000);
System.out.println("Thread run");
} catch (InterruptedException e) {
System.out.println("休眠中断");
e.printStackTrace();
}
}
} class InterruptExample1 extends Thread {
@Override
public void run() {
while (!interrupted()) {
// ..
}
System.out.println("Thread end");
}
} public class Client {
public static void main(String[] args) {
// InterruptExample thread1 = new InterruptExample();
// thread1.start();
// thread1.interrupt();
// System.out.println("Main run"); // InterruptExample1 thread2 = new InterruptExample1();
// thread2.start();
// thread2.interrupt(); // ExecutorService executorService = Executors.newCachedThreadPool();
// executorService.execute(() -> {
// try {
// Thread.sleep(2000);
// System.out.println("Thread run");
// } catch (InterruptedException e) {
// System.out.println("线程程序池全体中断");
// e.printStackTrace();
// }
// });
// executorService.shutdownNow();
// System.out.println("Main run"); ExecutorService executorService = Executors.newCachedThreadPool();
Future<?> future=executorService.submit(()->{
System.out.println("3");
while (!interrupted()){
System.out.println("2");
}
System.out.println("1");
});
future.cancel(true);//强制中断
}
}

5,互斥同步

代码实现:

package com.cnblogs.mufasa.demo5;

import java.util.concurrent.Executor;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock; class SynchronizedExample {//同步代码块,作用于同一个对象
public void func1() {
synchronized (this) {
for (int i = 0; i < 10; i++) {
System.out.print(i + " ");
}
}
}
} class SynchronizedExample1 {//同步方法,作用于同一个对象
public synchronized void func1() {
for (int i = 0; i < 10; i++) {
System.out.print(i + " ");
}
}
} class SynchronizedExample2 {//同步类,作用于整个类。
public void func1() {
synchronized(SynchronizedExample2.class){
for (int i = 0; i < 10; i++) {
System.out.print(i + " ");
}
}
}
} class SynchronizedExample3 {//同步静态方法,作用于整个类。
public static synchronized void func1() {
for (int i = 0; i < 10; i++) {
System.out.print(i + " ");
}
}
} class LockExample {//ReentrantLock 是 java.util.concurrent(J.U.C)包中的锁。
private Lock lock=new ReentrantLock();
public void func() {
lock.lock();
try {
for (int i = 0; i < 10; i++) {
System.out.print(i + " ");
}
}finally {
lock.unlock();//确保解锁,防止死锁
} }
} public class Client {
public static void main(String[] args) { //synchronized-代码块 相同对象-同步代码块
// SynchronizedExample e1=new SynchronizedExample();
// ExecutorService executorService= Executors.newCachedThreadPool();
// executorService.execute(()->e1.func1());
// executorService.execute(()->e1.func1()); //synchronized-代码块 不同对象-同步代码块,没有同步!!!
// SynchronizedExample e1 = new SynchronizedExample();
// SynchronizedExample e2 = new SynchronizedExample();
// ExecutorService executorService = Executors.newCachedThreadPool();
// executorService.execute(()->e1.func1());
// executorService.execute(()->e2.func1()); //synchronized-方法 不同对象,没有同步!!!
// SynchronizedExample1 e1 = new SynchronizedExample1();
// SynchronizedExample1 e2 = new SynchronizedExample1();
// ExecutorService executorService = Executors.newCachedThreadPool();
// executorService.execute(()->e1.func1());
// executorService.execute(()->e2.func1()); //synchronized-类 不同对象,有同步
// SynchronizedExample2 e1 = new SynchronizedExample2();
// SynchronizedExample2 e2 = new SynchronizedExample2();
// ExecutorService executorService = Executors.newCachedThreadPool();
// executorService.execute(()->e1.func1());
// executorService.execute(()->e2.func1()); //synchronized-静态方法 不同对象,有同步
// SynchronizedExample3 e1 = new SynchronizedExample3();
// SynchronizedExample3 e2 = new SynchronizedExample3();
// ExecutorService executorService = Executors.newCachedThreadPool();
// executorService.execute(()->e1.func1());
// executorService.execute(()->e2.func1()); //JDK实现的锁,作用一个对象
LockExample lockExample = new LockExample();
LockExample lockExample1 = new LockExample();
ExecutorService executorService = Executors.newCachedThreadPool();
executorService.execute(() -> lockExample.func());
// executorService.execute(() -> lockExample1.func());
executorService.execute(() -> lockExample.func());
}
}

6,线程协作

样例代码:

package com.cnblogs.mufasa.demo6;

import java.util.concurrent.Executor;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock; class JoinExample{
private class A extends Thread{
@Override
public void run(){
for(int i=0;i<10;i++){
System.out.println("A:"+i);
}
}
} private class B extends Thread {
private A a;
B(A a) {
this.a = a;
}
@Override
public void run() {
try {
a.join();//先完成A线程,继续B线程
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("B");
}
} public void test() {
A a = new A();
B b = new B(a);
b.start();
a.start();
} } class WaitNotifyExample{
public synchronized void before(){
System.out.println("before");
notifyAll();//通知等待的线程
}
public synchronized void after(){
try {
wait();//先进行等待
} catch (InterruptedException e) {
e.printStackTrace();
}
for(int i=0;i<10;i++){
System.out.print(i);
}
System.out.println("after");
}
} class AwaitSingalExample{
private Lock lock=new ReentrantLock();
private Condition condition=lock.newCondition();
public void before(){
lock.lock();
try {
System.out.println("before");
condition.signalAll();
}finally {
lock.unlock();
}
}
public void after(){
lock.lock();
try {
condition.await();
System.out.println("after");
} catch (InterruptedException e) {
e.printStackTrace();
}finally {
lock.unlock();
}
} } public class Client {
public static void main(String[] args) { // JoinExample example=new JoinExample();
// example.test(); // ExecutorService executorService = Executors.newCachedThreadPool();
// WaitNotifyExample example = new WaitNotifyExample();
// WaitNotifyExample example1 = new WaitNotifyExample();
// executorService.execute(() -> example.after());
// executorService.execute(() -> example1.after());
// executorService.execute(() -> example.before());
// executorService.execute(() -> example1.before()); ExecutorService executorService= Executors.newCachedThreadPool();
AwaitSingalExample example=new AwaitSingalExample();
executorService.execute(()->example.after());
executorService.execute(()->example.before()); }
}

7,J.U.C-AQS【java.util.concurrent】

样例代码:

package com.cnblogs.mufasa.demo7;

import java.util.concurrent.*;

class CyclicBarrier {
private int parties;
private int count;
private Runnable barrierCommand; public CyclicBarrier(int parties,Runnable barrierAction){
if (parties <= 0) throw new IllegalArgumentException();
this.parties = parties;
this.count = parties;
this.barrierCommand = barrierAction;
}
public CyclicBarrier(int parties) {
this(parties, null);
}
} public class Client {
public static void main(String[] args) throws InterruptedException {
final int clientCount=5;
final int totalRequestCount=10;
Semaphore semaphore=new Semaphore(clientCount);
ExecutorService executorService=Executors.newCachedThreadPool();
for(int i=0;i<totalRequestCount;i++){
executorService.execute(()->{
try {
semaphore.acquire();
System.out.print(semaphore.availablePermits()+" ");
} catch (InterruptedException e) {
e.printStackTrace();
}finally {
semaphore.release();
}
});
}
executorService.shutdown(); //Semaphore
// final int totalThread =10;
// CyclicBarrier cyclicBarrier=new CyclicBarrier(totalThread);
// ExecutorService executorService=Executors.newCachedThreadPool();
// for(int i=0;i<totalThread;i++){
// executorService.execute(()->{
// System.out.println("before...");
// try{
// cyclicBarrier.wait();//源程序是await,这里只能使用wait
// } catch (InterruptedException e) {
// e.printStackTrace();
// }
// System.out.print("after..");
// });
// executorService.shutdown();
// } //CountDownLatch实例
// final int totalThread=10;
// CountDownLatch countDownLatch=new CountDownLatch(3);
// ExecutorService executorService= Executors.newCachedThreadPool();
// for(int i=0;i<6;i++){
// int finalI = i;
// Thread.sleep(1000);
// executorService.execute(()->{
// System.out.print(finalI +"run-");
// countDownLatch.countDown();
// });
// }
// new Thread(()->{
// try {
// countDownLatch.await();
// } catch (InterruptedException e) {
// e.printStackTrace();
// }
// System.out.println("await等待线程");
// }).start();
//
// System.out.println("end");
// executorService.shutdown(); }
}
package com.cnblogs.mufasa.demo7;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Semaphore; public class SemaphoreExample { public static void main(String[] args) {
final int clientCount = 3;
final int totalRequestCount = 10;
Semaphore semaphore = new Semaphore(clientCount);
ExecutorService executorService = Executors.newCachedThreadPool();
for (int i = 0; i < totalRequestCount; i++) {
executorService.execute(()->{
try {
semaphore.acquire();
System.out.print(semaphore.availablePermits() + " ");
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
semaphore.release();
}
});
}
executorService.shutdown();
}
}

8.J.U.C-其他组件

样例代码:

package com.cnblogs.mufasa.demo8;

import java.util.concurrent.ExecutionException;
import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.Future;
import java.util.concurrent.RecursiveTask; public class ForkJoinExample extends RecursiveTask<Integer> {
private final int threshold=5;
private int first;
private int last; public ForkJoinExample(int first,int last){
this.first=first;
this.last=last;
} @Override
protected Integer compute() {
int result=0;
if(last-first<=threshold){
//运算量足够小直接计算
for(int i=first;i<=last;i++){
result +=i;
}
}else {
//拆分成小任务
int middle=first+(last-first)/2;
ForkJoinExample leftTask=new ForkJoinExample(first,middle);
ForkJoinExample rightTask=new ForkJoinExample(middle+1,last);
leftTask.fork();
rightTask.fork();
result =leftTask.join()+rightTask.join();
}
return result;
}
public static int sum(int first,int last){
int sum=0;
for(int i=first;i<=last;i++){
sum+=i;
}
return sum;
} public static void main(String[] args) throws ExecutionException, InterruptedException {
//普通方法计算
// System.out.println(sum(1, 1000000000)); //并行计算方法
// ForkJoinExample example = new ForkJoinExample(1, 1000000000);
// ForkJoinPool forkJoinPool = new ForkJoinPool();
// Future result=forkJoinPool.submit(example);
// System.out.println(result.get()); }
}
package com.cnblogs.mufasa.demo8;

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;
import java.util.concurrent.FutureTask; public class FutureTaskExample{
public static void main(String[] args) throws ExecutionException, InterruptedException {
FutureTask<Integer> futureTask=new FutureTask<>(new Callable<Integer>() {
@Override
public Integer call() throws Exception {
int result=0;
for(int i=0;i<10;i++){
Thread.sleep(500);
System.out.println("thread-A:"+i);
result +=i;
}
return result;
}
});
Thread computeThread=new Thread(futureTask);
computeThread.start(); Thread otherThread=new Thread(()->{
System.out.println("other task is running...");
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
});
otherThread.start(); System.out.println("运行正常");
System.out.println(futureTask.get());
}
}
package com.cnblogs.mufasa.demo8;

import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue; public class ProducerConsumer {
private static BlockingQueue<String> queue=new ArrayBlockingQueue<>(5);
private static class Producer extends Thread{
@Override
public void run() {
try {
queue.put("product");
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(queue.size()+"produce..");
}
} private static class Consumer extends Thread{
@Override
public void run() {
try {
String product=queue.take();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(queue.size()+"consume..");
}
} public static void main(String[] args) {//类似缓存,协调速率
for(int i=0;i<2;i++){
Producer producer=new Producer();
producer.start();
} for(int i=0;i<5;i++){
Consumer consumer=new Consumer();
consumer.start();
} for (int i = 0; i < 3; i++) {
Producer producer = new Producer();
producer.start();
}
}
}

9.线程不安全

package com.cnblogs.mufasa.demo9;

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.Executor;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; class ThreadUnsafeExample{
private int cnt=0;
// public synchronized void add(){//输出为1000,同步后输出正常
public void add(){//不同步后,输出不正常
cnt++;
}
public int get(){
return cnt;
}
} public class Client {
public static void main(String[] args) throws InterruptedException {
final int threadSize=1000;
ThreadUnsafeExample example=new ThreadUnsafeExample();
final CountDownLatch countDownLatch=new CountDownLatch(threadSize);
ExecutorService executorService= Executors.newCachedThreadPool();
for(int i=0;i<threadSize;i++){
executorService.execute(()->{
example.add();
countDownLatch.countDown();
});
}
countDownLatch.await();
executorService.shutdown();
System.out.println(example.get()); }
}

10.Java内存模式

package com.cnblogs.mufasa.demo10;

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.atomic.AtomicInteger; public class AtomicExample {
private AtomicInteger cnt=new AtomicInteger();
public void add(){
cnt.incrementAndGet();//原子自增
}
public int get(){
return cnt.get();
} public static void main(String[] args) throws InterruptedException {
final int threadSize=1000;
AtomicExample example=new AtomicExample();
final CountDownLatch countDownLatch=new CountDownLatch(threadSize);
ExecutorService excutorService= Executors.newCachedThreadPool();
for(int i=0;i<threadSize;i++){
excutorService.execute(()->{
example.add();
countDownLatch.countDown();
});
}
countDownLatch.await();
excutorService.shutdown();
System.out.println(example.get());
}
}
package com.cnblogs.mufasa.demo10;

import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; public class AtomicSynchronizedExample {
private int cnt=0;
public synchronized void add(){
cnt++;
}
public synchronized int get(){
return cnt;
} public static void main(String[] args) throws InterruptedException {
final int threadSize = 1000;
AtomicSynchronizedExample example=new AtomicSynchronizedExample();
final CountDownLatch countDownLatch = new CountDownLatch(threadSize);
ExecutorService executorService = Executors.newCachedThreadPool();
for(int i=0;i<threadSize;i++){
executorService.execute(()->{
example.add();
countDownLatch.countDown();
});
}
countDownLatch.await();
executorService.shutdown();
System.out.println(example.get());
}
}

11.线程安全

package com.cnblogs.mufasa.demo11;

import java.util.concurrent.Executor;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.atomic.AtomicInteger; public class AtomicIntegerExample {
private AtomicInteger cnt=new AtomicInteger();
public void add(){
cnt.incrementAndGet();
}
public int get(){
return cnt.get();
} public static void main(String[] args) throws InterruptedException {
AtomicIntegerExample example=new AtomicIntegerExample();
ExecutorService executorService= Executors.newCachedThreadPool();
for(int i=0;i<10;i++){
executorService.execute(()->example.add());
}
Thread.sleep(100);
example.add();
System.out.println(example.get());
executorService.shutdown(); } }
package com.cnblogs.mufasa.demo11;

import java.util.Collections;
import java.util.HashMap;
import java.util.Map; public class ImmutableExample {
public static void main(String[] args) {
Map<String,Integer> map=new HashMap<>();
map.put("b",2);
System.out.println(map.get("b"));
Map<String,Integer> unmodifiableMap= Collections.unmodifiableMap(map);//相当于设置一下
System.out.println(unmodifiableMap.get("b"));
unmodifiableMap.put("a",1);
}
}
package com.cnblogs.mufasa.demo11;

import java.util.concurrent.Executor;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; public class Stack_closedExample {
public void add100() {
int cnt=0;
for(int i=0;i<100;i++){
cnt++;
}
System.out.println(cnt);
} public static void main(String[] args) {
Stack_closedExample example=new Stack_closedExample();
ExecutorService executorService= Executors.newCachedThreadPool();
executorService.execute(()->example.add100());
executorService.execute(()->example.add100());
executorService.shutdown();
}
}
package com.cnblogs.mufasa.demo11;

public class ThreadLocalExample {

    public static void main(String[] args) {
ThreadLocal threadLocal=new ThreadLocal();
Thread thread1=new Thread(()->{
threadLocal.set(1);
try{
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(threadLocal.get());
threadLocal.remove();
});
Thread thread2=new Thread(()->{
threadLocal.set(2);
threadLocal.remove();
});
thread1.start();
thread2.start();
}
}
package com.cnblogs.mufasa.demo11;

public class ThreadLocalExample1 {
public static void main(String[] args) {
ThreadLocal threadLocal1=new ThreadLocal();
ThreadLocal threadLocal2=new ThreadLocal();
Thread thread1 = new Thread(() -> {
threadLocal1.set(1);
threadLocal2.set(1);
});
Thread thread2 = new Thread(() -> {
threadLocal1.set(2);
threadLocal2.set(2);
});
thread1.start();
thread2.start();
}
}

12.锁优化

package com.cnblogs.mufasa.demo12;

public class StringExample {
public static String concatString(String s1, String s2, String s3) {
return s1 + s2 + s3;
}
public static String concatString1(String s1, String s2, String s3) {
StringBuilder sb = new StringBuilder ();
sb.append(s1);
sb.append(s2);
sb.append(s3);
return sb.toString();
} public static void main(String[] args) {
System.out.println(concatString("12","34","56"));
System.out.println(concatString1("12","34","56"));
}
}

13.多线程开发良好的实践

https://blog.csdn.net/StefanTimber/article/details/73823689

https://github.com/CyC2018/CS-Notes/blob/master/notes/Java%20%E5%B9%B6%E5%8F%91.md

Java并发(思维导图)的更多相关文章

  1. JAVA并发思维导图

    原博客:https://blog.csdn.net/oqkdws/article/details/82145389

  2. java 基础-思维导图

    思维导图的好处 最近看了一些文章的思维导图,发现思维导图真是个强大的工具.了解了思维导图的作用之后,觉得把它运用到java上应该是个不错的想法,这样回顾知识点的时候一目了然,快速知道自己的短板. 思维 ...

  3. java基础思维导图,让java不再难懂

    java基础思维导图,让java不再难懂 原文链接  https://my.oschina.net/u/3080373/blog/873056 最近看了一些文章的思维导图,发现思维导图真是个强大的工具 ...

  4. java技术思维导图(转载)

      在网上看到有个人总结的java技术的东东,觉得很好,就保存下来了,码农还真是累啊,只有不断的学习才能有所提高,才能拿更多的RMB啊. java技术思维导图 服务端思维导图 前端思维导图

  5. Head First Java设计模式思维导图总结

    关于Head First Java设计模式的思维导图总结:

  6. 浅谈Java的主要学习要点_上海尚学堂java培训课程思维导图

    Java是一种可以撰写跨平台应用程序的面向对象的程序设计语言.Java 技术具有卓越的通用性.高效性.平台移植性和安全性,广泛应用于PC.数据中心.游戏控制台.科学超级计算机.移动电话和互联网,同时拥 ...

  7. Java相关思维导图分享

    非常多朋友都给我发私信希望获得一份Java知识的思维导图,我来不及一一答复.原先是给大家一个百度网盘的链接分享,大家能够自己去下载,可是不知道云盘还能用多久.把相关资源转移到了QQ的群共享中.须要的朋 ...

  8. 【xmind】 使用 Java 生成思维导图

    前言 在日常的工作与学习中,我们经常会使用思维导图这个工具,来把抽象而又无形的思考转换成有形并且具体的图像,是理清思路,梳理逻辑的一大神器. 准确的说,思维导图并不是一个具体的工具,而是一种方法.是道 ...

  9. java编程思想-并发思维导图

  10. 推荐:全新Java开发思维导图

    蓦然回首自己做开发已经十年了,这十年中我获得了很多,技术能力.培训.出国.大公司的经历,还有很多很好的朋友. 但再仔细一想,这十年中我至少浪费了五年时间,这五年可以足够让自己成长为一个优秀的程序员,可 ...

随机推荐

  1. Can I prevent the Firefox developer tools network panel from clearing on page reload?

    Can I prevent the Firefox developer tools network panel from clearing on page reload? I couldn't fin ...

  2. 解决Visual Studio:"无法导入以下密钥文件: xxxx.pfx,该密钥文件可能受密码保护"

    [解决方法] 从开始菜单找到并打开Visual Studio 命令提示(2010):开始->Microsoft Visual Studio 2010->Visual Studio Tool ...

  3. android studio 错误汇总以及解决办法

    android studio 错误汇总以及解决办法  参考 https://www.jianshu.com/p/7c7de6562231 问题1. Error:Execution failed for ...

  4. 40 Flutter仿京东商城项目签名验证原理、签名验证算法

    加群452892873 下载对应40课文件,运行方法,建好项目,直接替换lib目录 pubspec.yaml crypto: ^ SignServices.dart import 'dart:conv ...

  5. react起步——从零开始编写react项目

    # index.html <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> ...

  6. QML使用moveToThread线程【QML工程使用C++】

    一.需求来源 对于使用Qt线程,有两种方式,见本人其他文章:https://www.cnblogs.com/judes/p/6884964.html 个人认为QObject::moveToThread ...

  7. 重新认识Java 8的HashMap

    [转自]美团技术博客 HashMap是Java程序员使用频率最高的用于映射(键值对)处理的数据类型.随着JDK(Java Developmet Kit)版本的更新,JDK1.8对HashMap底层的实 ...

  8. PAT 甲级 1044 Shopping in Mars (25 分)(滑动窗口,尺取法,也可二分)

    1044 Shopping in Mars (25 分)   Shopping in Mars is quite a different experience. The Mars people pay ...

  9. Azure AADSTS7000215 其中一种问题的解决

    众所周知,Azure提供了整套的rest api,经过认证和授权,完美阐述了”我是谁,我能做什么“.对资源层的操作,我们很多时候是使用Powershell或者Azure CLI或者各个语言的SDK, ...

  10. 高级UI-Snackbar

    在与用户的交互中,最为常用的Toast和Dialog,但二者都存在其局限,Toast无法与用户进行交互,Dialog虽然可以与用户交互,但却会阻断用户操作的连贯性,介于二者之间的平衡,Snackbar ...