做网站费用上海wordpress收费版怎么激活
2026/5/13 18:00:35 网站建设 项目流程
做网站费用上海,wordpress收费版怎么激活,linux系统打开wordpress,手机网站开发 html51.1简单了解多线程【理解】 是指从软件或者硬件上实现多个线程并发执行的技术。 具有多线程能力的计算机因有硬件支持而能够在同一时间执行多个线程#xff0c;提升性能。 1.2并发和并行【理解】 并行#xff1a;在同一时刻#xff0c;有多个指令在多个CPU上同时执行。 并…1.1简单了解多线程【理解】是指从软件或者硬件上实现多个线程并发执行的技术。 具有多线程能力的计算机因有硬件支持而能够在同一时间执行多个线程提升性能。1.2并发和并行【理解】并行在同一时刻有多个指令在多个CPU上同时执行。并行在同一时刻有多个指令在多个CPU上同时执行。1.3进程和线程【理解】进程是正在运行的程序独立性进程是一个能独立运行的基本单位同时也是系统分配资源和调度的独立单位 动态性进程的实质是程序的一次执行过程进程是动态产生动态消亡的 并发性任何进程都可以同其他进程一起并发执行线程是进程中的单个顺序控制流是一条执行路径单线程一个进程如果只有一条执行路径则称为单线程程序多线程一个进程如果有多条执行路径则称为多线程程序1.4实现多线程方式一继承Thread类【应用】方法介绍方法名说明void run()在线程开启后此方法将被调用执行void start()使此线程开始执行Java虚拟机会调用run方法()实现步骤定义一个类MyThread继承Thread类在MyThread类中重写run()方法创建MyThread类的对象启动线程代码演示public class MyThread extends Thread { Override public void run() { for(int i0; i100; i) { System.out.println(i); } } } public class MyThreadDemo { public static void main(String[] args) { MyThread my1 new MyThread(); MyThread my2 new MyThread(); // my1.run(); // my2.run(); //void start() 导致此线程开始执行; Java虚拟机调用此线程的run方法 my1.start(); my2.start(); } }两个小问题为什么要重写run()方法因为run()是用来封装被线程执行的代码run()方法和start()方法的区别run()封装线程执行的代码直接调用相当于普通方法的调用start()启动线程然后由JVM调用此线程的run()方法1.5实现多线程方式二实现Runnable接口【应用】Thread构造方法方法名说明Thread(Runnable target)分配一个新的Thread对象Thread(Runnable target, String name)分配一个新的Thread对象实现步骤定义一个类MyRunnable实现Runnable接口在MyRunnable类中重写run()方法创建MyRunnable类的对象创建Thread类的对象把MyRunnable对象作为构造方法的参数启动线程代码演示public class MyRunnable implements Runnable { Override public void run() { for(int i0; i100; i) { System.out.println(Thread.currentThread().getName():i); } } } public class MyRunnableDemo { public static void main(String[] args) { //创建MyRunnable类的对象 MyRunnable my new MyRunnable(); //创建Thread类的对象把MyRunnable对象作为构造方法的参数 //Thread(Runnable target) // Thread t1 new Thread(my); // Thread t2 new Thread(my); //Thread(Runnable target, String name) Thread t1 new Thread(my,坦克); Thread t2 new Thread(my,飞机); //启动线程 t1.start(); t2.start(); } }1.6实现多线程方式三: 实现Callable接口【应用】方法介绍方法名说明V call()计算结果如果无法计算结果则抛出一个异常FutureTask(CallableV callable)创建一个 FutureTask一旦运行就执行给定的 CallableV get()如有必要等待计算完成然后获取其结果实现步骤定义一个类MyCallable实现Callable接口在MyCallable类中重写call()方法创建MyCallable类的对象创建Future的实现类FutureTask对象把MyCallable对象作为构造方法的参数创建Thread类的对象把FutureTask对象作为构造方法的参数启动线程再调用get方法就可以获取线程结束之后的结果。代码演示public class MyCallable implements CallableString { Override public String call() throws Exception { for (int i 0; i 100; i) { System.out.println(跟女孩表白 i); } //返回值就表示线程运行完毕之后的结果 return 答应; } } public class Demo { public static void main(String[] args) throws ExecutionException, InterruptedException { //线程开启之后需要执行里面的call方法 MyCallable mc new MyCallable(); //Thread t1 new Thread(mc); //可以获取线程执行完毕之后的结果.也可以作为参数传递给Thread对象 FutureTaskString ft new FutureTask(mc); //创建线程对象 Thread t1 new Thread(ft); String s ft.get(); //开启线程 t1.start(); //String s ft.get(); System.out.println(s); } }三种实现方式的对比实现Runnable、Callable接口好处: 扩展性强实现该接口的同时还可以继承其他的类缺点: 编程相对复杂不能直接使用Thread类中的方法继承Thread类好处: 编程比较简单可以直接使用Thread类中的方法缺点: 可以扩展性较差不能再继承其他的类1.7设置和获取线程名称【应用】方法介绍方法名说明void setName(String name)将此线程的名称更改为等于参数nameString getName()返回此线程的名称Thread currentThread()返回对当前正在执行的线程对象的引用代码演示public class MyThread extends Thread { public MyThread() {} public MyThread(String name) { super(name); } Override public void run() { for (int i 0; i 100; i) { System.out.println(getName():i); } } } public class MyThreadDemo { public static void main(String[] args) { MyThread my1 new MyThread(); MyThread my2 new MyThread(); //void setName(String name)将此线程的名称更改为等于参数 name my1.setName(高铁); my2.setName(飞机); //Thread(String name) MyThread my1 new MyThread(高铁); MyThread my2 new MyThread(飞机); my1.start(); my2.start(); //static Thread currentThread() 返回对当前正在执行的线程对象的引用 System.out.println(Thread.currentThread().getName()); } }1.8线程休眠【应用】相关方法方法名说明static void sleep(long millis)使当前正在执行的线程停留暂停执行指定的毫秒数代码演示public class MyRunnable implements Runnable { Override public void run() { for (int i 0; i 100; i) { try { Thread.sleep(100); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName() --- i); } } } public class Demo { public static void main(String[] args) throws InterruptedException { /*System.out.println(睡觉前); Thread.sleep(3000); System.out.println(睡醒了);*/ MyRunnable mr new MyRunnable(); Thread t1 new Thread(mr); Thread t2 new Thread(mr); t1.start(); t2.start(); } }1.9线程优先级【应用】线程调度两种调度方式分时调度模型所有线程轮流使用 CPU 的使用权平均分配每个线程占用 CPU 的时间片抢占式调度模型优先让优先级高的线程使用 CPU如果线程的优先级相同那么会随机选择一个优先级高的线程获取的 CPU 时间片相对多一些Java使用的是抢占式调度模型随机性假如计算机只有一个 CPU那么 CPU 在某一个时刻只能执行一条指令线程只有得到CPU时间片也就是使用权才可以执行指令。所以说多线程程序的执行是有随机性因为谁抢到CPU的使用权是不一定的优先级相关方法方法名说明final int getPriority()返回此线程的优先级final void setPriority(int newPriority)更改此线程的优先级线程默认优先级是5线程优先级的范围是1-10代码演示public class MyCallable implements CallableString { Override public String call() throws Exception { for (int i 0; i 100; i) { System.out.println(Thread.currentThread().getName() --- i); } return 线程执行完毕了; } } public class Demo { public static void main(String[] args) { //优先级: 1 - 10 默认值:5 MyCallable mc new MyCallable(); FutureTaskString ft new FutureTask(mc); Thread t1 new Thread(ft); t1.setName(飞机); t1.setPriority(10); //System.out.println(t1.getPriority());//5 t1.start(); MyCallable mc2 new MyCallable(); FutureTaskString ft2 new FutureTask(mc2); Thread t2 new Thread(ft2); t2.setName(坦克); t2.setPriority(1); //System.out.println(t2.getPriority());//5 t2.start(); } }1.10守护线程【应用】相关方法方法名说明void setDaemon(boolean on)将此线程标记为守护线程当运行的线程都是守护线程时Java虚拟机将退出代码演示public class MyThread1 extends Thread { Override public void run() { for (int i 0; i 10; i) { System.out.println(getName() --- i); } } } public class MyThread2 extends Thread { Override public void run() { for (int i 0; i 100; i) { System.out.println(getName() --- i); } } } public class Demo { public static void main(String[] args) { MyThread1 t1 new MyThread1(); MyThread2 t2 new MyThread2(); t1.setName(女神); t2.setName(备胎); //把第二个线程设置为守护线程 //当普通线程执行完之后,那么守护线程也没有继续运行下去的必要了. t2.setDaemon(true); t1.start(); t2.start(); } }

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询