当前位置: 首页 > news >正文

asp网站开发技术房地产宣传推广方案

asp网站开发技术,房地产宣传推广方案,工程公司注册经营范围,wordpress顶部图像一、谈谈你对Java内存模型#xff08;JVM Memory Model#xff09;的理解。 Java内存模型#xff08;Java Memory Model#xff0c;简称JMM#xff09;是Java虚拟机#xff08;JVM#xff09;规范中定义的一种关于内存访问、共享变量在多线程之间的可见性、以及原子性、… 一、谈谈你对Java内存模型JVM Memory Model的理解。 Java内存模型Java Memory Model简称JMM是Java虚拟机JVM规范中定义的一种关于内存访问、共享变量在多线程之间的可见性、以及原子性、顺序性的规则。以下是对Java内存模型的详细理解 一、内存模型概述 Java内存模型描述的是一组规则或规范这组规范定义了程序中各个变量包括实例字段、静态字段和构成数组对象的元素的访问方式。由于JVM运行程序的实体是线程每个线程在创建时JVM都会为其创建一个工作内存也称为本地内存或线程栈用于存储线程私有的数据。而Java内存模型中规定所有变量都存储在主内存中主内存是共享内存区域所有线程都可以访问。但线程对变量的操作读取、赋值等必须在工作内存中进行不能直接操作主内存中的变量。 二、主内存与工作内存 主内存所有线程共享的内存区域包含了对象的字段、方法和运行时常量池等数据。这是Java堆的一部分用于存储Java实例对象。工作内存每个线程拥有自己的工作内存工作内存中保存了主内存中变量的副本线程对变量的所有操作读取、写入都在工作内存中进行。工作内存是线程私有的数据区域因此不同的线程间无法访问对方的工作内存线程间的通信传值必须通过主内存来完成。 三、三大特性 Java内存模型围绕三大特性展开即原子性、可见性和有序性。 原子性一个或多个操作要么全部执行要么全部不执行执行的过程中是不会被任何因素打断的。Java内存模型通过lock和unlock操作来保证原子性同时提供了synchronized关键字和Lock接口等机制来实现。可见性一个线程对共享变量的修改能够被其他线程看到。Java内存模型通过volatile关键字和synchronized来保证可见性。当一个线程修改了volatile变量的值新值对于其他线程来说是立即可见的。同时synchronized也可以确保线程在进入同步块或同步方法时能够看到最新的变量值。有序性程序的执行顺序按照代码的先后顺序执行。然而由于编译器的优化和指令集的重排序Java程序在并发执行时可能会出现乱序执行的情况。Java内存模型通过Happens-Before规则来定义操作之间的偏序关系从而允许编译器和处理器对指令进行重排序但同时又保证程序最终执行的结果与按照Happens-Before关系规定的顺序执行的结果一致。 四、Happens-Before规则 Happens-Before是Java内存模型中最核心的概念之一它定义了一组偏序关系用于判断两个操作之间的内存可见性和有序性。主要包括以下规则 程序次序规则一个线程中的每个操作Happens-Before于该线程中的任意后续操作。监视器锁规则对一个锁的解锁Happens-Before于随后对这个锁的加锁。volatile变量规则对一个volatile变量的写Happens-Before于任意后续对这个volatile变量的读。传递性如果A Happens-Before B且B Happens-Before C那么A Happens-Before C。线程启动规则Thread对象的start()方法调用Happens-Before于该线程的每一个动作。线程终止规则线程的所有操作都Happens-Before于其他线程检测到这个线程已经终止、或者从该线程的join()方法调用返回、或者从该线程的Thread.isAlive()方法的返回值为false。线程中断规则对线程interrupt()方法的调用Happens-Before于被中断线程的代码检测到中断事件的发生。最终结束规则对象的构造函数执行、结束Happens-Before于它的finalize()方法的开始。 五、总结 Java内存模型是一种抽象的规范它定义了线程和主内存之间的抽象关系以及共享变量的访问规则。通过保证原子性、可见性和有序性Java内存模型为程序员提供了一致的内存访问语义使得多线程程序的行为可预测、可理解。同时Java内存模型还提供了一系列的同步机制如volatile关键字、synchronized关键字、Lock接口等以帮助开发者编写正确和高效的多线程代码。 综上所述Java内存模型是Java并发编程中的重要概念理解并掌握它对于编写高效、正确的多线程程序至关重要。 二、Java中如何创建一个线程有哪些实现方式 在Java中线程的创建有多种实现方式以下是四种主要的方法 一、继承Thread类 步骤 定义一个Thread类的子类并重写其run()方法。run()方法包含线程要执行的业务逻辑。创建Thread子类的实例。调用该实例的start()方法来启动线程。 示例代码 public class MyThread extends Thread {Overridepublic void run() {System.out.println(Thread.currentThread().getName() from MyThread);} }public class MyThreadTest {public static void main(String[] args) {MyThread thread new MyThread();thread.start();} }二、实现Runnable接口 步骤 定义一个Runnable接口的实现类并重写其run()方法。创建Runnable实现类的实例。使用该实例作为target创建Thread对象。调用Thread对象的start()方法来启动线程。 示例代码 public class MyRunnable implements Runnable {Overridepublic void run() {System.out.println(Thread.currentThread().getName() from MyRunnable);} }public class MyRunnableTest {public static void main(String[] args) {MyRunnable myRunnable new MyRunnable();Thread thread new Thread(myRunnable);thread.start();} }三、使用Callable和Future 步骤 创建一个实现Callable接口的类并实现其call()方法。call()方法可以有返回值并且可以声明抛出异常。使用FutureTask类来包装Callable对象该FutureTask对象封装了Callable对象的call()方法的返回值。使用FutureTask对象作为Thread对象的target创建并启动线程。调用FutureTask对象的get()方法来获得子线程执行结束后的返回值。 示例代码 import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.FutureTask;public class MyCallable implements CallableInteger {Overridepublic Integer call() throws Exception {System.out.println(Thread.currentThread().getName() from MyCallable);return 99;} }public class MyCallableTest {public static void main(String[] args) {FutureTaskInteger futureTask new FutureTask(new MyCallable());Thread thread new Thread(futureTask);thread.start();try {Thread.sleep(1000); // 等待线程执行完成System.out.println(返回的结果是: futureTask.get());} catch (InterruptedException | ExecutionException e) {e.printStackTrace();}} }四、使用线程池 步骤 使用Executors工厂类创建线程池返回的线程池实现了ExecutorService接口。提交Runnable或Callable任务给线程池执行。关闭线程池通常使用shutdown()方法。 示例代码使用newSingleThreadExecutor创建一个单线程执行器 import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors;public class MyRunnable implements Runnable {Overridepublic void run() {System.out.println(Thread.currentThread().getName() from MyRunnable);} }public class SingleThreadExecutorTest {public static void main(String[] args) {ExecutorService executorService Executors.newSingleThreadExecutor();MyRunnable myRunnable new MyRunnable();for (int i 0; i 10; i) {executorService.execute(myRunnable);}System.out.println(任务开始);executorService.shutdown();} }五、方法对比与选择 继承Thread类简单直观但Java只支持单继承如果类已经继承了其他类则无法再继承Thread。实现Runnable接口避免单继承的限制更加灵活。Runnable接口还可以被共享即多个线程可以共享一个Runnable实现类的实例。使用Callable和Future比Runnable接口更强大因为call()方法有返回值并且可以抛出异常。适用于需要返回结果的任务。使用线程池提高性能减少线程创建和销毁的开销。线程池还可以管理线程的并发数量和生命周期。 在选择线程创建方式时应根据具体的应用场景和需求来决定。例如对于简单的任务可以直接继承Thread类或实现Runnable接口对于需要返回结果的任务可以使用Callable和Future对于需要高性能和线程管理的场景则应该使用线程池。
http://www.hkea.cn/news/14266819/

相关文章:

  • 北京医院网站建设jsp怎样做网站
  • 建筑建设网站搜搜提交网站入口
  • 选择合肥网站建设怎么样做一个个人网站
  • 网站建设结课总结网站定制设计师
  • 做相亲网站的安全责任网站建设 岗位职责 智联
  • 免费做 爱视频网站wordpress付费主题
  • 网站平台开发报价表怎么做域名查询 查询网
  • 字体设计教程网站公司变更证明模板
  • 初二做网站的首页模板315晚会 网站建设公司
  • 网站建设策划书范文公司网站生成二维码
  • 学网站ui设计androidstudio入门教程
  • 企业网站建设合同范本免费wordpress 初始化插件
  • 南京每月做社保明细在哪个网站查手机端安卓开发软件
  • 常见的网站空间主要有wordpress修改备案号
  • 网站建设ASP心得体会面试网站开发员
  • 网站空间租赁做网站送400电话
  • 企业官网门户网站管理系统灰色广告投放平台
  • 赤坎网站建设公司广州网站设计推荐柚米
  • 上海网站开发前十名流量与网站
  • 微信浏览为网站的缓存怎么清理广东网站建设
  • 导航网站模板免费网站怎么样排名
  • 网站设计的目的是什么盐城网站建设24gx
  • 烟台网站seo服务视频素材网站建设
  • python 做网站开发定州网站建设
  • 郴州网站建设有限公司seo做的很好的网站
  • 电商网站建设的步骤嘉兴百度网站推广
  • 科技类网站源码抚州公司做网站
  • 做ppt图片用的网站有哪些问题可以访问任何网站的浏览器
  • 网络广告营销织梦网站怎样做seo
  • 网站建设都分几个阶段建立网站的优势