java吧 关注:1,253,078贴子:12,739,955

回复:【职场-技能系列の作死和不作死的区别,纪念当年的新手路】

取消只看楼主收藏回复

Java环境变量设置
设置方法
java环境变量设置通常需要设置三个环境变量:JAVA_HOME、PATH 和 CLASSPATH
1.右键打开我的电脑 -> 属性 -> 高级 -> 环境变量
2.新建系统变量JAVA_HOME和CLASSPATH
变量名(N):JAVA_HOME
变量值(V):C:\Program Files\Java\jdk1.7.0_15
变量名(N):CLASSPATH
变量值(V):.;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;
3.选择“系统变量”中的“Path”变量,添加下面的变量值到最前
变量名(N):Path


87楼2014-12-25 22:29
收起回复
    变量值(V):%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin;
    4.测试环境变量
    运行或者win+r,输入cmd 进入DOC界面
    输入命令“java -version”,“java”,“javac”几个命令,出现画面,说明环境变量配置成功;
    运行JAVA HelloWorld
    1.编写代码,并命名为HelloWorld.java
    public class HelloWorld{
    public static void main(String arg[]) {
    System.out.println("Hello, World!");
    }
    }
    2.doc输入代码如下
    1)“d:”切换到D盘
    2)“cd demo\java” 进入存示例的目录
    3)“javac HelloWorld.java”编译出文件HelloWorld.class
    4)“java HelloWorld”运行 HelloWorld.class
    5)最后输出结果“Hello, World!”。


    88楼2014-12-25 22:30
    回复
      美美的拍一张 哼


      89楼2014-12-25 22:31
      收起回复
        环境变量的涵义
        JAVA_HOME:该环境变量的值就是 Java 所在的目录,一些 Java 版的软件和一些 Java 的工具需要用到该变量,设置 PATH 和 CLASSPATH 的时候,也可以使用该变量以方便设置。
        PATH:指定一个路径列表,用于搜索可执行文件的。执行一个可执行文件时,如果该文件不能在当前路径下找到,则依次寻找 PATH 中的每一个路径,直至找到。或者找完 PATH 中的路径也不能找到,则报错。Java 的编译命令 (javac),执行命令 (java) 和一些工具命令 (javadoc, jdb 等) 都在其安装路径下的 bin 目录中。因此我们应该将该路径添加到 PATH 变量中。
        CLASSPATH:也指定一个路径列表,是用于搜索 Java 编译或者运行时需要用到的类。在 CLASSPATH 列表中除了可以包含路径外,还可以包含 .jar 文件。Java 查找类时会把这个 .jar 文件当作一个目录来进行查找。通常,我们需要把 JDK 安装路径下的 jre\lib\rt.jar (Linux: jre/lib/rt.jar) 包含在 CLASSPATH 中。 PATH 和 CLASSPATH 都指定路径列表,列表中的各项 (即各个路径) 之间使用分隔符分隔。在 Windows 下,分隔符是分号 (;),而在 Linux 下,分隔符是冒号 (:)。


        90楼2014-12-25 22:58
        收起回复
          姐姐睡觉了 你们这群小孩纸不睡?


          93楼2014-12-26 02:06
          收起回复
            我能抽象出整个世界...但是我不能抽象出你... 因为你在我心中是那么的具体... 所以我的世界并不完整... 我可以重载甚至覆盖这个世界里的任何一种方法... 但是我却不能重载对你的思念... 也许命中注定了 你在我的世界里永远的烙上了静态的属性... 而我不慎调用了爱你这个方法... 当我义无返顾的把自己作为参数传进这个方法时... 我才发现爱上你是一个死循环... 它不停的返回对你的思念压入我心里的堆栈... 在这无尽的黑夜中... 我的内存里已经再也装不下别人... 我不停的向系统申请空间... 但却捕获一个异常---我爱的人不爱我...为了解决这个异常... 我愿意虚拟出最后一点内存... 把所有我能实现的方法地址压入堆栈... 并且在栈尾压入最后一个方法---将字符串”我爱你,你爱我吗?”传递给你... 如果返回值为真--我将用尽一生去爱你... 否则--我将释放掉所有系统资源...@常无忧2


            104楼2014-12-26 15:28
            收起回复
              JAVA经典面试题网上收集的,@难得糊涂的神 @巨小毅 @merry_fan @弦歌问情2013 @
              暴风库里欧 @riyvitxgt @我是楚湘寒 赶紧看 赶紧长大!!


              105楼2014-12-26 16:17
              收起回复
                1.Java的HashMap是如何工作的?
                HashMap是一个针对数据结构的键值,每个键都会有相应的值,关键是识别这样的值。
                HashMap 基于 hashing 原理,我们通过 put ()和 get ()方法储存和获取对象。当我们将键值对传递给 put ()方法时,它调用键对象的 hashCode ()方法来计算 hashcode,让后找到 bucket 位置来储存值对象。当获取对象时,通过键对象的 equals ()方法找到正确的键值对,然后返回值对象。HashMap 使用 LinkedList 来解决碰撞问题,当发生碰撞了,对象将会储存在 LinkedList 的下一个节点中。 HashMap 在每个 LinkedList 节点中储存键值对对象。


                106楼2014-12-26 16:18
                收起回复
                  2.什么是快速失败的故障安全迭代器?
                  快速失败的Java迭代器可能会引发ConcurrentModifcationException在底层集合迭代过程中被修改。故障安全作为发生在实例中的一个副本迭代是不会抛出任何异常的。快速失败的故障安全范例定义了当遭遇故障时系统是如何反应的。例如,用于失败的快速迭代器ArrayList和用于故障安全的迭代器ConcurrentHashMap。


                  107楼2014-12-26 16:18
                  回复
                    3.Java BlockingQueue是什么?
                    Java BlockingQueue是一个并发集合util包的一部分。BlockingQueue队列是一种支持操作,它等待元素变得可用时来检索,同样等待空间可用时来存储元素。


                    108楼2014-12-26 16:18
                    回复
                      4.什么时候使用ConcurrentHashMap?
                      在问题2中我们看到ConcurrentHashMap被作为故障安全迭代器的一个实例,它允许完整的并发检索和更新。当有大量的并发更新时,ConcurrentHashMap此时可以被使用。这非常类似于Hashtable,但ConcurrentHashMap不锁定整个表来提供并发,所以从这点上ConcurrentHashMap的性能似乎更好一些。所以当有大量更新时ConcurrentHashMap应该被使用。


                      110楼2014-12-26 16:31
                      回复
                        5.哪一个List实现了最快插入?
                        LinkedList和ArrayList是另个不同变量列表的实现。ArrayList的优势在于动态的增长数组,非常适合初始时总长度未知的情况下使用。LinkedList的优势在于在中间位置插入和删除操作,速度是最快的。
                        LinkedList实现了List接口,允许null元素。此外LinkedList提供额外的get,remove,insert方法在LinkedList的首部或尾部。这些操作使LinkedList可被用作堆栈(stack),队列(queue)或双向队列(deque)。
                        ArrayList实现了可变大小的数组。它允许所有元素,包括null。 每个ArrayList实例都有一个容量(Capacity),即用于存储元素的数组的大小。这个容量可随着不断添加新元素而自动增加,但是增长算法并没有定义。当需要插入大量元素时,在插入前可以调用ensureCapacity方法来增加ArrayList的容量以提高插入效率。


                        111楼2014-12-26 16:35
                        收起回复
                          6.Iterator和ListIterator的区别
                          ●ListIterator有add()方法,可以向List中添加对象,而Iterator不能。
                          ●ListIterator和Iterator都有hasNext()和next()方法,可以实现顺序向后遍历,但是ListIterator有hasPrevious()和previous()方法,可以实现逆向(顺序向前)遍历。Iterator就不可以。
                          ●ListIterator可以定位当前的索引位置,nextIndex()和previousIndex()可以实现。Iterator没有此功能。
                          ●都可实现删除对象,但是ListIterator可以实现对象的修改,set()方法可以实现。Iierator仅能遍历,不能修改。


                          112楼2014-12-26 16:37
                          回复
                            7.什么是CopyOnWriteArrayList,它与ArrayList有何不同?
                            CopyOnWriteArrayList是ArrayList的一个线程安全的变体,其中所有可变操作(add、set等等)都是通过对底层数组进行一次新的复制来实现的。相比较于ArrayList它的写操作要慢一些,因为它需要实例的快照。
                            CopyOnWriteArrayList中写操作需要大面积复制数组,所以性能肯定很差,但是读操作因为操作的对象和写操作不是同一个对象,读之间也不需要加锁,读和写之间的同步处理只是在写完后通过一个简单的"="将引用指向新的数组对象上来,这个几乎不需要时间,这样读操作就很快很安全,适合在多线程里使用,绝对不会发生ConcurrentModificationException ,因此CopyOnWriteArrayList适合使用在读操作远远大于写操作的场景里,比如缓存。


                            113楼2014-12-26 16:40
                            回复
                              不想敲代码了 烦死了烦死了


                              117楼2014-12-26 17:03
                              收起回复