关于编程术语的讲解?

如题所述

在软件开发行业中存在着许多的术语,比如说线程、线程池等等。今天,电脑培训就一起来了解一下,在java编程软件开发项目中都有哪些开发术语是需要我们了解的。



什么是线程?


术语“线程”可以用来描述很多不同的事情。在本文中,我会使用它来代指一个逻辑线程。也就是:按照线性顺序的一系列操作;一个执行的逻辑路径。CPU的每个核心只能真正并发同时执行一个逻辑线程。这就带来一个固有的问题:如果线程的数量多于内核的数量,那么有的线程必须要暂停以便于其他的线程来运行工作,当再次轮到自己的执行的时候,会将任务恢复。为了支持暂停和恢复,线程至少需要如下两件事情:


某种类型的指令指针。也就是,当我暂停的时候,我正在执行哪行代码?


一个栈。也就是,我当前的状态是什么?栈中包含了本地变量以及指向变量所分配的堆的指针。同一个进程中的所有线程共享相同的堆。


鉴于以上两点,系统在将线程调度到CPU上时就有了足够的信息,能够暂停某个线程、允许其他的线程运行,随后再次恢复原来的线程。这种操作通常对线程来说是完全透明的。从线程的角度来说,它是连续运行的。线程能够感知到重新调度的方式是测量连续操作之间的计时。


JVM使用操作系统线程


尽管并非规范所要求,但是据我所知所有的现代、通用JVM都将线程委托给了平台的操作系统线程来处理。在接下来的内容中,我将会使用“用户空间线程(userspacethread)”来代指由语言进行调度的线程,而不是内核/OS所调度的线程。操作系统实现的线程有两个属性,这两个属性极大地限制了它们可以存在的数量;任何将语言线程和操作系统线程进行1:1映射的解决方案都无法支持大规模的并发。


在JVM中,固定大小的栈


使用操作系统线程将会导致每个线程都有固定的、较大的内存成本


采用操作系统线程的另一个主要问题是每个OS线程都有大小固定的栈。尽管这个大小是可以配置的,但是在64位的环境中,JVM会为每个线程分配1M的栈。你可以将默认的栈空间设置地更小一些,但是你需要权衡内存的使用,因为这会增加栈溢出的风险。代码中的递归越多,就越有可能出现栈溢出。如果你保持默认值的话,那么1000个线程就将使用1GB的RAM。虽然现在RAM便宜了很多,但是几乎没有人会为了运行上百万个线程而准备TB级别的RAM。


温馨提示:答案为网友推荐,仅供参考
相似回答