`

多线程带来的风险/多线程评定的标准

    博客分类:
  • JAVA
阅读更多
安全性--不损坏对象
    对象的损坏通常是指对象的字段所取得的值并非预期值。在多线程环境中,如果没有足够的同步,多个线程操作执行顺序是不可预测的,由于多个线程是共享相同的的内存地址,并且是并发运行,因此它们可能会访问或修改其他线程正在使用的变量。要使多线程程序的行为可预测,必须对共享变量的访问操作进行协同,这样才不会在线程间发生彼此干扰。
value++操作,当A、B线程并发图



并发编程中,这种由于不恰当的执行时序而出现不正确的结果有一个正式的名字:竞态条件
先检查后执行;延迟初始化;复合操作(读取-修改-写入)

活跃性(生存性)--进行必要的处理
    安全性是“永远不发生糟糕的事情”,而活跃性关注的目标是“某件正确的事最终会发生”。活跃性的形式之一就是无意中造成死循环,使循环后面的代码无法执行;线程A等待线程B释放其持有的资源,而线程B永远不释放,线程A将一直等下去;死锁等。

性能--能快速、大量进行处理
    活跃性意味着某件正确的事最终会发生,但却不够好,我们希望正确的事情尽快发生,性能问题包括多个方面:服务时间过长,响应不灵敏,吞吐率过低,资源消耗过高或可伸缩性较低等。在多线程程序中,当线程调度器临时挂起活跃线程并转而运行另一个线程时,就会频繁的出现上下文切换操作,这种操作将带来极大的开销:保存和恢复执行上下文,并且CPU时间将更多地花在线程调度而不是线程运行上。
数据吞吐量(throughput)是指在一定时间内所能完成的处理量,能处理的数量越多,表示数据吞吐量越高。
响应性(responsiveness)是指从发出要求到收到反应的时间。所费时间越短,则程序的响应性越高。
容量(capacity)是指可同时处理的数量。如:服务器可同时处理的客户端数量或文件数量等。

有时,这些因素可能会互相抵触,如果想较高的数据吞吐量,通常会相对降低响性;提高安全性可能会降低程序的性能。


复用性--可再利用类
    在写多线程程序时,若能将线程的共享互斥结构隐藏在类里,就是一个具有高度复用性的程序。

=============================================================================

设计多线程程序时,必须维持程序的安全性和活跃性,满足这两个必要条件后,再考虑如何提高复用性和性能。
安全性与活跃性--必要条件;
复用性与性能--提高程序质量。



  • 大小: 3.2 KB
0
0
分享到:
评论

相关推荐

    简单易用的奖学金评定系统

    7. **多线程**: 如果系统需要同时执行多个任务,比如后台数据处理和用户界面更新,多线程技术就显得尤为重要。Java提供了Thread类和Runnable接口来实现并发编程。 8. **用户认证与权限控制**: 对于一个奖学金评定...

    Concurrency:多线程

    Concurrency项目介绍多线程软件架构软件架构说明安装教程xxxxxxxxxxxx使用说明xxxxxxxxxxxx参与贡献Fork 本项目新建 Feat_xxx 分支提交代码新建 Pull Request码云特技使用 Readme_XXX.md 来支持不同的语言,例如 ...

    奖学金评定系统

    它具有面向对象的特性,支持多线程,语法简洁,且具有丰富的类库。在本项目中,Java可能被用来编写业务逻辑、控制层、数据访问层等不同模块。 2. **MySQL数据库**:MySQL是一款开源、免费的关系型数据库管理系统,...

    Java+access奖学金评定系统

    - **并发性**:Java支持多线程编程,能够同时处理多个任务,有效利用系统资源。 ##### (2)开发工具简介 **Eclipse**是一款流行的开源集成开发环境(IDE),广泛用于Java应用程序的开发。Eclipse具有高度的可扩展性和...

    阿里java开发标准 手册

    - 针对并发编程提供了指导,包括锁的使用、线程安全、同步机制等,以确保多线程环境下的程序稳定性和安全性。 **控制语句** - 给出了循环、条件判断等控制流语句的最佳实践。 **注释规约** - 注释应该简洁明了,...

    教科书评定系统

    这就需要用到Java的多线程、定时任务处理,以及可能的第三方API集成。 总的来说,【教科书评定系统】覆盖了Java编程、Web开发、数据库设计、前端技术、安全管理和服务器端服务等多个方面的知识。深入学习并实践这个...

    某数码员工技术景调查.pdf

    Java 语言是 Sun Microsystems 公司开发的一种编程语言,可以用来开发大型的 GUI 应用程序、基于 Socket 的多线程的后台应用程序、嵌入式 Java 应用程序等。 2.2 编程技术 * 2.2.1 数据库编程 * 2.2.2 网络通讯...

    基于STM32的线阵CCD图像采集系统.pdf

    系统利用多线程技术进行数据处理,提高了软件的执行效率和用户交互体验。 知识点六:缺陷风险评定与控制 在控制器设计中,缺陷风险评定及控制是保障系统稳定运行的关键环节。本文中风险评定主要通过型式试验、例行...

    java ATM毕业论文+任务书+申报书+ppt+评定表

    - **Java编程语言**:包括基本语法、类与对象、异常处理、多线程、IO流等。 - **GUI设计**:使用Java Swing或JavaFX创建用户界面,实现按钮、文本框等组件的交互逻辑。 - **数据库操作**:如SQL语言,与MySQL等...

    慧达淘宝快递单号批量安全检测 v1.4.zip

    支持分类导出、支持多线程查询等等,是淘宝掌柜必备的安全检测神器。 慧达淘宝快递单号批量安全检测功能 1.支持10大快递公司的单号检测 2.支持多线程检测 3.支持分类导出 4.支持安全等级评定 5.支持使用次数...

    《面向对象Java程序设计》教学大纲.docx

    课程内容涵盖了Java的基础知识,如Java的运行机制、程序结构、数据类型、变量、运算符、控制语句、数组,以及面向对象的核心概念,包括类、对象、接口、包,还有异常处理、多线程、输入输出(I/O)、图形用户界面(GUI)...

    《Java程序设计及应用》大作业-封面.doc

    6. **多线程**:Java支持多线程编程,让学生了解并发执行的概念。Thread类和Runnable接口是进行多线程编程的基础,而同步机制(如synchronized关键字、Lock接口)则能保证线程安全。 7. **网络编程**:Java提供...

    评定

    5. **多线程**:掌握线程的创建与同步,理解线程池的工作原理,如ExecutorService。 6. **反射机制**:允许程序在运行时检查类的信息并动态调用方法或访问属性。 7. **设计模式**:熟悉常见的23种设计模式,如工厂...

    计算机网络专业课程设计.doc

    总的来说,这个课程设计任务旨在锻炼学生的实际编程能力,特别是网络通信和多线程编程,同时提高其问题解决和团队协作的能力。通过这样的实践,学生可以深入理解计算机网络中数据传输的基本原理,为将来从事相关领域...

    OJ平台雷同率统计软件

    总结来说,“OJ平台雷同率统计软件”结合了HashMap的数据结构优势、集合排序的逻辑、Swing的GUI功能以及多线程处理,为1swust学校的ACM竞赛提供了一套有效的雷同代码检测解决方案。通过源码和jar包,用户不仅可以...

    Windows内核实验(北京大学)指导

    - **实验目的:** 通过多进程或多线程的方式实现快速排序算法,理解并行编程的基本思想。 - **背景知识:** 快速排序是一种高效的排序算法,通过递归地将数据分割成较小的部分来实现排序。 - **步骤:** - 设计并实现...

    java网络聊天室课程设计报告(内附代码).doc

    2. **多线程处理**:在聊天室中,每个连接的客户端都应有一个独立的线程来处理其输入和输出,以确保并发性。Java的Thread类和Runnable接口用于实现多线程。 3. **数据编码与解码**:在网络通信中,数据通常需要进行...

    《Java程序设计实验》课程教学大纲.pdf

    3. **多线程**:实验旨在让学生理解并使用多线程,通过定义和运行线程类来实现并发处理。这有助于学生掌握Java在处理多任务时的能力。 4. **图形用户界面**:实验要求学生编写具有GUI的程序,包括按钮、文本字段、...

    网络聊天室课程设计报告内附java代码.doc

    2. **多线程处理**:为了同时处理多个用户的连接请求,服务器端需要使用多线程技术。每个新连接的客户端将启动一个新的线程来处理其通信,使得服务器能够并发地处理多个用户的消息。 3. **用户界面设计**:使用JSP...

Global site tag (gtag.js) - Google Analytics