一 ActiveMQ安装 从Apache官网上下载 ActivieMQ的安装包 apache-activemq-5.9.1-bin.tar.gz, 并拷贝到linux的安装目录解压 # tar -zxvf   apache-activemq-5.9.1-bin.tar.gz    // 解压 # cd ./apache-activemq-5.9.1/bin   // 进入bin目录 # ./activemq                 // 执行启动命令, 程序会启动失败 ,老版本执行 ./…
Java并行程序基础 一.线程的生命周期 其中blocked和waiting的区别: 作者:赵老师链接:https://www.zhihu.com/question/27654579/answer/128050125来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 假设t1,t2先后两个线程,都执行如下代码: synchronized(Obj) { Obj.wait(); } t1先进,最后在Obj.wait()下卡住,这时java管t1的状态waitting状态t…
JAVA并行程序基础 一.有关线程你必须知道的事 进程与线程 在等待面向线程设计的计算机结构中,进程是线程的容器.我们都知道,程序是对于指令.数据及其组织形式的描述,而进程是程序的实体. 线程是轻量级的进程,是程序执行的最小单位.(PS:使用多线程去进行并发程序的设计,是因为线程间的调度和切换成本远小于进程) 线程的状态(Thread的State类): NEW–刚刚创建的线程,需要调用start()方法来执行线程: RUNNABLE–线程处于执行状态: BLOCKED–线程遇到synchroni…
JAVA并行程序基础二 线程组 当一个系统中,如果线程较多并且功能分配比较明确,可以将相同功能的线程放入同一个线程组里. activeCount()可获得活动线程的总数,由于线程是动态的只能获取一个估计值. stop()可以停止当前线程组里的所有线程,但会遇到与Thread.stop()相同的问题,尽量不用. 守护线程 守护线程是系统的守护者,在后台默默地完成系统性的服务,如垃圾回收线程,JIT线程.与之对应的是用户线程,用户线程可以看做系统的工作线程,当系统工作线程全部执行完毕,那么整个系统将…
JAVA并行程序基础一 线程的状态 初始线程:线程的基本操作 1. 新建线程 新建线程只需要使用new关键字创建一个线程对象,并且用start() ,线程start()之后会执行run()方法 不要直接调用run()方法,它只会在当前线程串行执行run()中的方法. 重载run()方法有两种方式 直接继承Thread类 实现Runnable接口 它只有一个run()方法 在new Thread()时将接口实现类传入 2.终止线程 一般线程在执行完毕就会结束,无需手动关闭.但java也提供手动关闭…
java程序基础 没有特殊说明,我的所有学习笔记都是从廖老师那里摘抄过来的,侵删 引言 兜兜转转到了大四,学过了C,C++,C#,Java,Python,学一门丢一门,到了最后还是要把Java捡起来.所以奉劝大家,面向对象还是要掌握一门,虽然Python好写舒服,但是毕竟不能完全面向对象,也没有那么多的应用场景,所以,奉劝看到本文的各位,还是提前学好C#或者Java. Java程序的基本结构 每个Java程序只能有一个public修饰的类,并且该类的名字要和该Java程序文件同名. Java入口…
Spring MVC + Spring + Mybitis是除了SSH外的另外一种常见的web框架组合. Java web开发和普通的Java应用程序开发是不太一样的,下面是一个Java web开发在Eclipse EE中的目录结构: 普通的Java应用开发,我们的代码都在src目录下,不论是Java代码,配置文件,还是资源文件等.而Java web开发,我们关注的不是src目录,而是WebConent目录,发布项目时最终会将WebConent目录下的所有文件打成war包进行发布. WebCon…
并发,就是用多个执行器(线程)来完成一个任务(大任务)来处理业务(提高效率)的方法.而在这个过程中,会涉及到一些问题,所以学的就是解决这些问题的方法. 线程的基本操作: 1.创建线程:只需要new一个线程对象即可:Thread myThread=new Thread().然后 myThread.start() 即可开启线程.那么问题来了,这个线程到底要做些什么呢,所以,Thread有一个run() 方法,方法体则是线程要做的事情.而默认情况下,run()方法什么不做,所以我们需要重写run(),…
2.8 程序中的幽灵:隐蔽的错误 2.8.1 无提示的错误案例 以求两个整数的平均值为例.请看下面代码: int v1 = 1073741827; int v2 = 1431655768; System.out.println("v1 = " + v1); System.out.println("v2 = " + v2); int ave = (v1 + v2) / 2; System.out.println("ave = " + ave); 输…
2.3 volatile 与 Java 内存模型(JMM) volatile对于保证操作的原子性是由非常大的帮助的(可见性).但是需要注意的是,volatile并不能代替锁,它也无法保证一些复合操作的原子性.比如下面的例子,通过volatile是无法保证i++的原子性操 作的: static volatile int i = 0; public static class PlusTask implements Runable { @Override public void run() { for…