线程和简单并发问题
2021-06-09 00:06
标签:cpu 自己 结果 public void http 操作系统 nts art ? 很多多线程是模拟出来的,真整的多线程是指有多个cpu,即多核,如服务器。如果是模拟出来的多线程,在一个cpu的情况下,同一个时间点,cpu只能执行一个代码,因为切换的快,所以就有同时执行的错觉。 ? @线程是独立的执行路径 ? @在程序运行时,即使自己没有创建线程,后台也会有多个线程,如主线程,gc线程 ? @在一个进程中,如果开辟了多个线程,线程的运行由调度器安排调度,调度器是与操作系统紧密相关的,先后顺序不能人为干预 ? @线程会带来额外的开销,如cpu调度时间,并发控制开销 ? @对同一份资源操作时,会存在资源抢夺问题,需要加入并发控制 ? @每个线程在自己的工作内存交互,内存控制不当会造成数据不一致 ? 这是上述代码的执行结果,可以看出线程与主线程是交替运行的。 ? 线程开启不一定立即执行,而是等待CPU调度执行 ? ? 推荐使用实现Runnable接口的方式,可以避免单继承局限性,灵活方便,方便同一个对象被多个对象使用 线程和简单并发问题 标签:cpu 自己 结果 public void http 操作系统 nts art 原文地址:https://www.cnblogs.com/wsl975/p/14501855.html线程的一些概念
Java中线程的创建
1 . 继承Thread类
//创建线程方式一:继承Thread类,重写run()方法,调用start()开启线程
public class TestThread extends Thread {
@Override
public void run() {
for (int i = 0; i
2.实现Runnable接口
//创建线程方式2: 实现runnable接口,重写run方法,执行线程需要丢入runnable接口实现类,调用start()方法
public class ThreadTest_02 implements Runnable{
@Override
public void run() {
for(int i = 0 ;i
3.实现Callable接口
并发问题
//多个线程操作一个对象实例
//买火车票
//多个线程操作同一个资源的情况下,数据不安全
public class ThreadTest_03 implements Runnable{
private int ticketNums = 15;
@Override
public void run() {
while(true){
if(ticketNums
下一篇:js题集21