- 浏览: 400953 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
di1984HIT:
学习了,学习了~
Jpcap 网络抓包工具 -
Allen_J_Will:
pengtyao 写道Allen_J_Will 写道为何按照楼 ...
使用mod_cluster进行负载均衡初步预研 -
pengtyao:
Allen_J_Will 写道为何按照楼主的步骤,并参考了 h ...
使用mod_cluster进行负载均衡初步预研 -
Allen_J_Will:
为何按照楼主的步骤,并参考了 http://docs.jbos ...
使用mod_cluster进行负载均衡初步预研 -
362980633:
我在项目中写context.xml,项目没有不部署在tomca ...
配置Tomcat的<Context>元素
1.对象的哪些属性与方法应该公开,哪些应该隐藏?
封装两大原则:
(1)把尽可能多的东西隐藏起来,对外提供简捷的接口;
(2)把所有属性隐藏起来;
2.隐藏属性的好处?
(1)能够灵活的控制属性的读与修改的访问级别(允许读与修改的public公开get、set方法,只允许读的public公开get方法,private隐藏set方法);
(2)防止使用者错误的修改属性(可以在set方法里添加必要的逻辑判断);
(3)有助于对象封装实现细节(如某属性的变化可能引起内部系统一列连锁变化,可以在set方法里添加相关逻辑)
3.抽象的过程?
问题领域的事物—〉(抽取与问题领域相关的事物的属性和行为)对象模型中的对象—〉(把具有相同属性和行为的对象抽象为)对象模型中的类—〉(从具有相同属性和行为的类抽象出)对象模型中的父类。
ps:abstract抽象类不能实例化。
4.多态、动态绑定、静态绑定?
多态:一个接口可以有多个不同实现。
动态绑定:Java虚拟机根据对象运行时的类型唤起继承机制,寻找调用方法的最佳匹配(意味着正在调用的方法是最佳方法),动态绑定不包括:
1.静态方法
2.私有方法(因为他们只能从内部调用,属于隐式的最终方法);
3.最终方法
Java虚拟机采用以下绑定规则:
1.实例方法与引用变量实际引用的对象的方法绑定;
2.静态方法与引用变量所声明的类型的方法绑定;
3.成员变量(包括静态变量、实例变量)与应用变量所声明的类型的成员变量绑定;
静态绑定:编译时绑定。
重载方法的调用属于:静态绑定
覆盖方法的调用属于:动态绑定
5.继承与接口
1.一个类只能继承一个直接父类,但是能实现多个接口;
原因:继承多个父类导致程序变得特别复杂、有背面向对象原则(封装)。
解决方法:采用内部类去集成需要继承的类,但不推荐这么做。
2.一个接口不能实现另一个接口,但是能集成多个其它接口;
注意:当子类的构造方法没有用super语句显示的调用父类的构造方法,而此时父类又没有提供默认构造方法时,将会出现编译错误,如下:
6.类的生命周期
生命周期:
1.类的生命周期从类被加载,连接,初始化开始,到类被卸载结束;
2.类处于生命周期时,它的二进制数据位于运行时方法区内,在堆区还有一个相应的描述类的Class类的对象;
3.只有当类处于生命周期中时,Java程序才能够使用它。
类的加载,连接和初始化
a.Java程序要使用某个类时,Java虚拟机要确保这个类被加载,连接和运行,其中连接包括验证,准备和解析。
b.加载:查找并加载类的二进制数据;
c.连接
c.1 验证:确保加载类的正确性;
c.2 准备:为静态变量分配内存,并将其初始化为默认值;
c.3 解析:将类中的符号引用转换为直接引用。
d.初始化:
给类的静态变量赋予正确的初始值
首次使用一个类JVM才会对其进行初始化:
六种首次使用场景:
1.创建类的实例,途经包括:使用new 创建对象实例,反射(java.lang.Class.newInstance())、clone、反序列化等;
2.调用类的静态方法
3.使用类或者接口的静态变量,给静态变量赋值;
4.初始化一个类的子类(本条不适合接口类);
5.调用JAVA API中某些反射方法,比如Class.forName("Worker");
6.把类声明为启动类,如: java Test01
类加载器
1.Bootstrap ClassLoader:用C++实现,一切的开始,是所有类加载器的最终父加载器。负责将一些关键的Java类,如java.lang.Object和其他一些运行时代码先加载进内存中。它的实现依赖与底层操作系统,属于JVM的实现的一部分,并没有继承java.lang.ClassLoader类。从系统属性sun.boot.class.path所指定目录加载类库。
2.ExtClassLoader:用java实现,是Launcher.java的内部类,编译后的名字为:Launcher$ExtClassLoader.class 。此类由Bootstrap ClassLoader加载,但由于Bootstrap ClassLoader已经脱离了java体系(c++),所以Launcher$ExtClassLoader.class的Parent(父加载器)被设置为null;它用于装载Java运行环境扩展包(jre/lib/ext)中的类,而且一旦建立其加载的路径将不再改变,或从系统属性java.ext.dirs所指定目录加载类库。
3.AppClassLoader:系统类加载器(应用类加载器)用java实现,也是是Launcher.java的内部类,编译后的名字为:Launcher$AppClassLoader.class 。AppClassLoader是当Bootstrap ClassLoader加载完ExtClassLoader后,再被Bootstrap ClassLoader加载。所以ExtClassLoader和AppClassLoader都是被Bootstrap ClassLoader加载,但AppClassLoader的Parent被设置为ExtClassLoader。可见Parent和由哪个类加载器来加载不一定是对应的。这个类装载器是我们经常使用的,可以调用ClassLoader.getSystemClassLoader() 来获得,如果程序中没有使用类装载器相关操作设定或者自定义新的类装载器,那么我们编写的所有java类都会由它来装载。而它的查找区域就是我们常常说到的Classpath,一旦建立其加载路径也不再改变。它从环境变量classpath或系统属性java.class.path所指定目录加载类库。
4.User-Defined-ClassLoader:一般我们自定义的ClassLoader从ClassLoader类继承而来。比如:URLClassloader是ClassLoader的一个子类,而URLClassloader也是ExtClassLoader和AppClassLoader的父类(注意不是父加载器)。
说明:类加载器之间的父子关系实际指的是加载器对象之间的包装关系,而不是类继承关系。一对父子加载器可能是同一个加载器类的两个实例。
类加载父亲委托(parent delegation)机制
说明:在父亲委托机制中,各个加载器按照父子关系形成了树状结构,除了根类加载器以外,其余的类加载器有且只有一个父加载器。
假设loader2的父亲为loader1,loader1的父亲为系统类加载器。假设Java程序要求loader2加载Sample类,代码如下:
loader2首先从自己的命名空间中查找Sample类是否已经加载,如果已经加载,就直接返回代表Sample类的Class对象的引用。
如果Sample类还没有被加载,loader2首先请求loader1代为加载,loader1再请求系统类加载器代为加载,系统类加载器再请求扩展类加载器代为加载,扩展类加载器再请求根类加载器代为加载。若根类加载器和扩展类加载器都不能加载,则系统类加载器尝试加载,若能加载成功,则将Sample类所对应的Class对象的引用返回给loader1,loader1再将引用返回给loader2,从而成功将Sample类加载进虚拟机。
若系统类加载器不能加载Smaple类,则loader1尝试加载Sample类,若loader1也不能成功加载,则loader2尝试加载。若所有的父加载器和loader2本身都不能加载,则抛出ClassNotFoundException异常。
父亲委托机制的优点?
父亲委托机制的优点是能够提高软件系统的安全性。因为在此机制下,用户自定义的类加载器不可能加载应该由父加载器加载的可靠类,从而防止不可靠甚至恶意的代码代替由父加载器加载的可靠代码。例如,java.lang.Object类总是由根类加载器加载(BootStrap),其他任何用户自定义的类加载器都不可能加载含有恶意代码的java.lang.Object类。
有几个重要概念需要理解一下。(与安全有关)
1.命名空间:
每个类加载器都有自己的命名空间,命名空间由加载器及所有父加载器所加载的类组成。在同一个命名空间中,不会出现类的完整名字(包括类的包名)相同的两个类;在不同的命名空间中,有可能会出现类的完整名字(包括类的包名)相同的两个类。
2.运行时包
由同一个类加载器加载的属于相同包的类组成运行时包。决定两个类是不是属于同一个运行时包,不仅要看它们的包名是否相同,还要看定义类加载器是否相同。只有属于同一运行时包的类才能互相访问可见(即默认访问级别)的类和类成员。这样的限制能避免用户自定义的类冒充核心类库的类,去访问核心类库的包可见成员。假设用户自己定义了一个类java.lang.Spy,并由用户自定义的类加载器加载,由于jang.lang.Spy和核心类库java.lang.*由不同的加载器加载,它们属于不同的运行时包,所以java.lang.Spy不能访问核心类库java.lang包中的可见成员。
类的卸载
当一个类的Class对象不再被应用,即不可触及时,Class对象就会结束生命周期,这个类在方法区内的数据也会被卸载,从而结束此类的生命周期。
说明:由JVM自带的类加载器所加载的类,在JVM的生命周期中,始终不会被卸载。
运行时数据区
7.垃圾回收(Garbage Collection)
垃圾回收具有以下特点:
(1)只有当对象不再被程序中的任何引用变量引用时,它的内存才可能被回收。
(2)程序无法迫使垃圾回收器立即执行垃圾回收操作。当一个对象处于可复活状态(当程序不再有任何引用变量引用Sample对象时,它就进入可复活状态)时,垃圾回收线程何时执行它的finalize()方法,何时使它转到不可触及状态(当Java虚拟机执行完所有可复活对象的finalize()方法后,假如这些方法都没有使Sample对象转到可触及状态,那么Sample对象就进入不可触及状态。只有当对象处于不可触及状态时,垃圾回收器才会真正回收它占用的内存),何时回收它占用的内存,这对于程序来说都是透明的。
(3)程序中可以调用System.gc()或者Runtime.gc()方法提示垃圾回收器尽快执行垃圾回收操作,但是这也不能保证调用完该方法后,垃圾回收线程就立即执行回收操作,而且不能保证垃圾回收线程一定会执行这一操作。
(4)垃圾收集发生的不可预知性:由于实现了不同的垃圾收集算法和采用了不同的收集机制,所以它有可能是定时发生,有可能是当出现系统空闲CPU资源时发生,也有可能是和原始的垃圾收集一样,等到内存消耗出现极限时发生,这与垃圾收集器的选择和具体的设置都有关系。
(5)垃圾收集的精确性:主要包括2 个方面:(a)垃圾收集器能够精确标记活着的对象;(b)垃圾收集器能够精确地定位对象之间的引用关系。前者是完全地回收所有废弃对象的前提,否则就可能造成内存泄漏。而后者则是实现归并和复制等算法的必要条件。所有不可达对象都能够可靠地得到回收,所有对象都能够重新分配,允许对象的复制和对象内存的缩并,这样就有效地防止内存的支离破碎。
(6)现在有许多种不同的垃圾收集器,每种有其算法且其表现各异,既有当垃圾收集开始时就停止应用程序的运行,又有当垃圾收集开始时也允许应用程序的线程运行,还有在同一时间垃圾收集多线程运行。
(7)垃圾收集的实现和具体的JVM 以及JVM的内存模型有非常紧密的关系。不同的JVM可能采用不同的垃圾收集,而JVM 的内存模型决定着该JVM可以采用哪些类型垃圾收集。现在,HotSpot 系列JVM中的内存系统都采用先进的面向对象的框架设计,这使得该系列JVM都可以采用最先进的垃圾收集。
(8)随着技术的发展,现代垃圾收集技术提供许多可选的垃圾收集器,而且在配置每种收集器的时候又可以设置不同的参数,这就使得根据不同的应用环境获得最优的应用性能成为可能。
封装两大原则:
(1)把尽可能多的东西隐藏起来,对外提供简捷的接口;
(2)把所有属性隐藏起来;
2.隐藏属性的好处?
(1)能够灵活的控制属性的读与修改的访问级别(允许读与修改的public公开get、set方法,只允许读的public公开get方法,private隐藏set方法);
(2)防止使用者错误的修改属性(可以在set方法里添加必要的逻辑判断);
(3)有助于对象封装实现细节(如某属性的变化可能引起内部系统一列连锁变化,可以在set方法里添加相关逻辑)
3.抽象的过程?
问题领域的事物—〉(抽取与问题领域相关的事物的属性和行为)对象模型中的对象—〉(把具有相同属性和行为的对象抽象为)对象模型中的类—〉(从具有相同属性和行为的类抽象出)对象模型中的父类。
ps:abstract抽象类不能实例化。
4.多态、动态绑定、静态绑定?
多态:一个接口可以有多个不同实现。
动态绑定:Java虚拟机根据对象运行时的类型唤起继承机制,寻找调用方法的最佳匹配(意味着正在调用的方法是最佳方法),动态绑定不包括:
1.静态方法
2.私有方法(因为他们只能从内部调用,属于隐式的最终方法);
3.最终方法
Java虚拟机采用以下绑定规则:
1.实例方法与引用变量实际引用的对象的方法绑定;
2.静态方法与引用变量所声明的类型的方法绑定;
3.成员变量(包括静态变量、实例变量)与应用变量所声明的类型的成员变量绑定;
静态绑定:编译时绑定。
重载方法的调用属于:静态绑定
覆盖方法的调用属于:动态绑定
5.继承与接口
1.一个类只能继承一个直接父类,但是能实现多个接口;
原因:继承多个父类导致程序变得特别复杂、有背面向对象原则(封装)。
解决方法:采用内部类去集成需要继承的类,但不推荐这么做。
2.一个接口不能实现另一个接口,但是能集成多个其它接口;
注意:当子类的构造方法没有用super语句显示的调用父类的构造方法,而此时父类又没有提供默认构造方法时,将会出现编译错误,如下:
class D { int i; D(int i) { this.i = i * 2; } } class E extends D { E(int i) { /* * If there is no super(i) , it will compile failed :Implicit super * constructor D() is undefined. Must explicitly invoke another * constructor. */ super(i); System.out.println(); } }
6.类的生命周期
生命周期:
1.类的生命周期从类被加载,连接,初始化开始,到类被卸载结束;
2.类处于生命周期时,它的二进制数据位于运行时方法区内,在堆区还有一个相应的描述类的Class类的对象;
3.只有当类处于生命周期中时,Java程序才能够使用它。
类的加载,连接和初始化
a.Java程序要使用某个类时,Java虚拟机要确保这个类被加载,连接和运行,其中连接包括验证,准备和解析。
b.加载:查找并加载类的二进制数据;
c.连接
c.1 验证:确保加载类的正确性;
c.2 准备:为静态变量分配内存,并将其初始化为默认值;
c.3 解析:将类中的符号引用转换为直接引用。
d.初始化:
给类的静态变量赋予正确的初始值
首次使用一个类JVM才会对其进行初始化:
六种首次使用场景:
1.创建类的实例,途经包括:使用new 创建对象实例,反射(java.lang.Class.newInstance())、clone、反序列化等;
2.调用类的静态方法
3.使用类或者接口的静态变量,给静态变量赋值;
4.初始化一个类的子类(本条不适合接口类);
5.调用JAVA API中某些反射方法,比如Class.forName("Worker");
6.把类声明为启动类,如: java Test01
类加载器
1.Bootstrap ClassLoader:用C++实现,一切的开始,是所有类加载器的最终父加载器。负责将一些关键的Java类,如java.lang.Object和其他一些运行时代码先加载进内存中。它的实现依赖与底层操作系统,属于JVM的实现的一部分,并没有继承java.lang.ClassLoader类。从系统属性sun.boot.class.path所指定目录加载类库。
2.ExtClassLoader:用java实现,是Launcher.java的内部类,编译后的名字为:Launcher$ExtClassLoader.class 。此类由Bootstrap ClassLoader加载,但由于Bootstrap ClassLoader已经脱离了java体系(c++),所以Launcher$ExtClassLoader.class的Parent(父加载器)被设置为null;它用于装载Java运行环境扩展包(jre/lib/ext)中的类,而且一旦建立其加载的路径将不再改变,或从系统属性java.ext.dirs所指定目录加载类库。
3.AppClassLoader:系统类加载器(应用类加载器)用java实现,也是是Launcher.java的内部类,编译后的名字为:Launcher$AppClassLoader.class 。AppClassLoader是当Bootstrap ClassLoader加载完ExtClassLoader后,再被Bootstrap ClassLoader加载。所以ExtClassLoader和AppClassLoader都是被Bootstrap ClassLoader加载,但AppClassLoader的Parent被设置为ExtClassLoader。可见Parent和由哪个类加载器来加载不一定是对应的。这个类装载器是我们经常使用的,可以调用ClassLoader.getSystemClassLoader() 来获得,如果程序中没有使用类装载器相关操作设定或者自定义新的类装载器,那么我们编写的所有java类都会由它来装载。而它的查找区域就是我们常常说到的Classpath,一旦建立其加载路径也不再改变。它从环境变量classpath或系统属性java.class.path所指定目录加载类库。
4.User-Defined-ClassLoader:一般我们自定义的ClassLoader从ClassLoader类继承而来。比如:URLClassloader是ClassLoader的一个子类,而URLClassloader也是ExtClassLoader和AppClassLoader的父类(注意不是父加载器)。
说明:类加载器之间的父子关系实际指的是加载器对象之间的包装关系,而不是类继承关系。一对父子加载器可能是同一个加载器类的两个实例。
类加载父亲委托(parent delegation)机制
说明:在父亲委托机制中,各个加载器按照父子关系形成了树状结构,除了根类加载器以外,其余的类加载器有且只有一个父加载器。
假设loader2的父亲为loader1,loader1的父亲为系统类加载器。假设Java程序要求loader2加载Sample类,代码如下:
Class sampleClass = loader2.loadClass("Sample");
loader2首先从自己的命名空间中查找Sample类是否已经加载,如果已经加载,就直接返回代表Sample类的Class对象的引用。
如果Sample类还没有被加载,loader2首先请求loader1代为加载,loader1再请求系统类加载器代为加载,系统类加载器再请求扩展类加载器代为加载,扩展类加载器再请求根类加载器代为加载。若根类加载器和扩展类加载器都不能加载,则系统类加载器尝试加载,若能加载成功,则将Sample类所对应的Class对象的引用返回给loader1,loader1再将引用返回给loader2,从而成功将Sample类加载进虚拟机。
若系统类加载器不能加载Smaple类,则loader1尝试加载Sample类,若loader1也不能成功加载,则loader2尝试加载。若所有的父加载器和loader2本身都不能加载,则抛出ClassNotFoundException异常。
父亲委托机制的优点?
父亲委托机制的优点是能够提高软件系统的安全性。因为在此机制下,用户自定义的类加载器不可能加载应该由父加载器加载的可靠类,从而防止不可靠甚至恶意的代码代替由父加载器加载的可靠代码。例如,java.lang.Object类总是由根类加载器加载(BootStrap),其他任何用户自定义的类加载器都不可能加载含有恶意代码的java.lang.Object类。
有几个重要概念需要理解一下。(与安全有关)
1.命名空间:
每个类加载器都有自己的命名空间,命名空间由加载器及所有父加载器所加载的类组成。在同一个命名空间中,不会出现类的完整名字(包括类的包名)相同的两个类;在不同的命名空间中,有可能会出现类的完整名字(包括类的包名)相同的两个类。
2.运行时包
由同一个类加载器加载的属于相同包的类组成运行时包。决定两个类是不是属于同一个运行时包,不仅要看它们的包名是否相同,还要看定义类加载器是否相同。只有属于同一运行时包的类才能互相访问可见(即默认访问级别)的类和类成员。这样的限制能避免用户自定义的类冒充核心类库的类,去访问核心类库的包可见成员。假设用户自己定义了一个类java.lang.Spy,并由用户自定义的类加载器加载,由于jang.lang.Spy和核心类库java.lang.*由不同的加载器加载,它们属于不同的运行时包,所以java.lang.Spy不能访问核心类库java.lang包中的可见成员。
类的卸载
当一个类的Class对象不再被应用,即不可触及时,Class对象就会结束生命周期,这个类在方法区内的数据也会被卸载,从而结束此类的生命周期。
说明:由JVM自带的类加载器所加载的类,在JVM的生命周期中,始终不会被卸载。
运行时数据区
7.垃圾回收(Garbage Collection)
垃圾回收具有以下特点:
(1)只有当对象不再被程序中的任何引用变量引用时,它的内存才可能被回收。
(2)程序无法迫使垃圾回收器立即执行垃圾回收操作。当一个对象处于可复活状态(当程序不再有任何引用变量引用Sample对象时,它就进入可复活状态)时,垃圾回收线程何时执行它的finalize()方法,何时使它转到不可触及状态(当Java虚拟机执行完所有可复活对象的finalize()方法后,假如这些方法都没有使Sample对象转到可触及状态,那么Sample对象就进入不可触及状态。只有当对象处于不可触及状态时,垃圾回收器才会真正回收它占用的内存),何时回收它占用的内存,这对于程序来说都是透明的。
(3)程序中可以调用System.gc()或者Runtime.gc()方法提示垃圾回收器尽快执行垃圾回收操作,但是这也不能保证调用完该方法后,垃圾回收线程就立即执行回收操作,而且不能保证垃圾回收线程一定会执行这一操作。
(4)垃圾收集发生的不可预知性:由于实现了不同的垃圾收集算法和采用了不同的收集机制,所以它有可能是定时发生,有可能是当出现系统空闲CPU资源时发生,也有可能是和原始的垃圾收集一样,等到内存消耗出现极限时发生,这与垃圾收集器的选择和具体的设置都有关系。
(5)垃圾收集的精确性:主要包括2 个方面:(a)垃圾收集器能够精确标记活着的对象;(b)垃圾收集器能够精确地定位对象之间的引用关系。前者是完全地回收所有废弃对象的前提,否则就可能造成内存泄漏。而后者则是实现归并和复制等算法的必要条件。所有不可达对象都能够可靠地得到回收,所有对象都能够重新分配,允许对象的复制和对象内存的缩并,这样就有效地防止内存的支离破碎。
(6)现在有许多种不同的垃圾收集器,每种有其算法且其表现各异,既有当垃圾收集开始时就停止应用程序的运行,又有当垃圾收集开始时也允许应用程序的线程运行,还有在同一时间垃圾收集多线程运行。
(7)垃圾收集的实现和具体的JVM 以及JVM的内存模型有非常紧密的关系。不同的JVM可能采用不同的垃圾收集,而JVM 的内存模型决定着该JVM可以采用哪些类型垃圾收集。现在,HotSpot 系列JVM中的内存系统都采用先进的面向对象的框架设计,这使得该系列JVM都可以采用最先进的垃圾收集。
(8)随着技术的发展,现代垃圾收集技术提供许多可选的垃圾收集器,而且在配置每种收集器的时候又可以设置不同的参数,这就使得根据不同的应用环境获得最优的应用性能成为可能。
发表评论
-
通过JUnit理解反射与注解的使用方式与场景
2014-04-07 22:20 1616通过JUnit深入理解反射与注 解的使用方式与场景 引用 ... -
SiteMesh----Web界面布局、装饰框架
2013-06-02 22:48 1777一、SiteMesh项目简介 ... -
DWR--远程服务器端Ajax开源框架
2013-03-17 22:04 1376简介 DWR(Direct Web Remoting)是一个用 ... -
Jpcap 网络抓包工具
2012-07-22 15:17 145451.jpcap说明与安装 JAVA语言虽然在TCP/U ... -
初识敏捷开发
2011-12-27 23:50 1034敏捷软件开发宣言 个体 ... -
XStream序列化与反序列化对象
2011-12-25 19:50 6485XStream是一个将java对象序列化为xml以及从xml反 ... -
持续集成(Continous Integration)
2011-12-14 23:46 1283对持续集成的理解: 1、持续集成是敏捷开发的一种重要实践; 2 ... -
ConcurrentHashMap原理分析
2011-06-09 15:05 4662集合是编程中最常用的数据结构。而谈到并发,几乎总是离不开集合这 ... -
开发知识整理----数组和集合框架(2011-06)
2011-06-07 17:36 1661一、数组 Java数组 ... -
开发知识整理----多线程(2011-05)
2011-05-29 23:21 1338一.多线程 1.进程与线 ... -
动态数组:java.lang.System下的arraycopy和java.util.Arrays.copyOf方法
2011-05-24 00:24 16109java.lang.System下的arraycopy和jav ... -
Java多线程设计模式:wait/notify机制
2011-05-20 00:32 1190引用内容摘要:如果条件不满足,则等待。当条件满足时,等待该条件 ... -
近期开发能力加强与整理计划
2011-04-18 23:15 1171在这埋下的种子没有发芽... 也许真不适合... 不得已要换块 ... -
Junit设计模式学习
2011-04-12 23:05 1166Junit设计模式学习 -
instanceof VS isAssignableFrom
2011-04-06 00:49 1137public static void main(Str ... -
c:forEach标签的使用
2011-03-19 17:02 1143c:forEach标签的使用 在JSP的开发中,迭代是经常要 ... -
a4j:jsFunction & a4j:actionparam
2011-03-17 21:28 3744这次JSF的项目中遇到一种特殊情况,在一个CommandLin ... -
JSF f:loadBundle标签
2011-03-16 11:04 1563JSF f:loadBundle标签是JSF提供的一个支持JS ... -
cookie与session专题
2011-03-10 19:55 991一、cookie机制和session机 ... -
JVM 内存初学 (堆(heap)、栈(stack)和方法区(method) )
2010-12-14 00:09 1398JVM 内存初学 (堆(heap)、 ...
相关推荐
根据提供的文档信息,我们可以总结出以下关于自考03173软件开发工具的重要知识点: ### 1. 软件开发工具的发展历程 - **专用软件开发工具阶段的开端**:文档中提到的一些专门用于支持软件开发的工具出现在20世纪80...
本文将围绕“土地开发整理-土地整理-施工方案”这一主题,深入探讨其中的关键知识点。 一、土地开发整理概念 土地开发整理是指通过科学规划,对土地进行合理布局,改善土地质量,提高土地利用效率,防止水土流失,...
根据您提供的文件信息,这份文档的标题和描述部分都指向了同一款产品——E73-2G4M04S1B+开发套件。其开发资料涵盖了nRF52832这款芯片。该芯片是由Nordic Semiconductor公司开发的蓝牙系统级芯片(SoC),广泛应用于...
Java架构师的核心面试知识涉及到多个领域,包括JVM与...这些知识点涵盖了Java开发中的关键领域,对于成为一名合格的Java架构师至关重要。在面试准备时,不仅需要理解这些概念,还要能够结合实际项目经验进行深入讨论。
这个压缩包文件“土地开发整理-土地开发整理标准(全)”显然包含了一份全面的土地开发整理的标准文档,这通常涵盖了一系列规范、准则和技术要求。下面将详细阐述这一领域的关键知识点。 一、土地开发整理的定义与...
通过阅读"[二次开发] ABAQUS-UMAT-自学知识整理贴[2].pdf"和"[二次开发] ABAQUS-UMAT-自学知识整理贴[1].pdf",你可以系统地学习和掌握ABAQUS中的二次开发技术,从而提升你在工程分析中的能力,解决更复杂的问题。...
这份"单片机开发资源整理"包含了丰富的学习材料和实践指南,对于初学者和有经验的工程师来说都是宝贵的参考资料。 一、单片机基础 单片机的核心是微处理器,它集成了CPU、内存(ROM和RAM)、定时器/计数器、输入/...
在“土地开发整理-土地整理施工方案1-6章”这份资料中,详细阐述了从规划到实施的一系列关键步骤和知识点,旨在为相关领域的专业人员提供指导。 第一章:项目背景与目标 这一章节通常会介绍土地开发整理项目的总体...
2011年11月更新整理的这份资料,包含了当时最新的DOS使用技巧和实践经验,对于想要深入了解DOS操作系统的用户来说,具有很高的学习价值。 DOS,全称Disk Operating System,是磁盘操作系统,是个人计算机上早期广泛...
"山景资料大全-多年开发学习资料整理-里面资料自己写的,或整理的" 这个标题表明这是一个由个人或团队精心整理的、与"山景"相关的开发学习资源集合,涵盖了多年的知识积累。"山景"在这里可能是指一个特定的技术品牌...
数据库基础知识是IT领域中至关重要的一个部分,关系数据模型是其中的核心概念。关系数据模型由三个要素构成:数据结构、关系操作和完整性约束。 1. 数据结构: - 属性(Attribute):描述实体特征的元素,如学号、...
本文将围绕“土地开发整理-土地整理实施方案”这一主题,深入探讨其涉及的关键知识点。 1. 土地开发整理的定义: 土地开发整理是指通过科学规划,对未利用土地进行开发,或对已利用土地进行改造和整治,以达到增加...
在本文中,我们将深入探讨“土地开发整理-土地整理施工方案1”所涵盖的关键知识点,以便理解这一过程的复杂性和重要性。 1. 土地开发整理概述: 土地开发整理是对土地进行有序、合理、高效利用的过程,旨在改善土地...
以下是对标题为“Java核心知识点整理-已转换.docx”的文档中提及的一些关键概念的详细解释: 1. JVM(Java Virtual Machine) JVM是Java程序的执行引擎,它负责将字节码(.class文件)转换为机器码,使得Java具有...
本文将围绕“土地开发整理-土地整理施工方案”这一主题,详细阐述其相关知识点。 首先,土地开发整理的目的是优化土地资源配置,提高土地使用效率,改善土地质量,为城市的建设和发展提供基础条件。这通常包括土地...
### 软件过程与管理知识点整理 #### 一、概论背景 ##### 什么是软件工程? 软件工程是指将工程的原则和技术应用于软件的开发、运行和维护,旨在提高软件产品的质量和生产效率。它关注于软件生命周期内的所有活动,...
以下是我根据“软件工程简答题整理--幕布大纲”这个标题和描述所提炼出的相关知识点,它们对复试备考至关重要。 1. **软件工程基础**: - 软件生命周期:从概念形成、需求分析、设计、实现、测试到运行和维护的...
文件“土地开发整理-土地整理施工组织设计.doc”可能详细列出了以上各个方面的具体实施方案和细节,对于项目管理人员、工程师、规划师来说,是实施土地开发整理项目的重要参考资料。通过深入理解和应用这些知识,...
这份"JavaWEB基础知识整理.rar"压缩包提供了一份详细的Java Web开发基础教程,适合初学者和有一定经验的开发者进行复习和巩固。以下是对其中核心知识点的详细解读: 1. **Java Web概述** - Java Web开发主要涉及...
在“土地开发整理-施工方案(土地整理)”这个文档中,我们可能会涵盖以下几个重要的知识点: 1. **项目背景**:首先,施工方案通常会介绍项目的背景,包括项目的目标、位置、规模和范围,以便所有参与者理解项目的...