JavaScript引用类型
引用类型虽然看起来和类很相似,但是它们却是不同的概念,引用类型的值,也就是对象是引用类型的一个实例。在Js中引用类型主要有Object,Array,Date,正则,Function等。
数组Array
在Js中数组可以存储任意的数据,而且它的大小是可以动态调整的。创建数组可以使用构造函数的方式也可以使用字面量的形式,另外可以使用concat从一个数组中复制一个副本出来。
方法:
length 数组的长度
toString 将数组转换为一个字符串,并且返回这个字符串,相当于是调用了下join(',')
join 把数组中的所有元素放入一个字符串中,元素通过指定的分隔符进行分割的。如果省略参数,则会使用逗号作为分隔符。
push 向数组末尾添加一个或者多个元素,并返回新的长度。
pop 删除数组中的最后一项,把数组的长度减1,并且返回它被删除元素的值,如果数组变为空,则该方法不改变数组,返回undefine值。
shift 删除数组的第一项,返回值同pop
unshift 是向数组的开头添加一个或者更多元素,并返回新的长度。
reverse 倒序
concat 该方法用于连接2个或者多个数组。该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本。如果连接多个数组,使用逗号隔开。
sort 该方法是对数组的元素进行排序;参数规定排序顺序,且必须是函数。如果该方法没有使用参数,则是按字母的字符编码的顺序进行排序。
如果想按其他标准进行排序,就需要提供比较函数,该函数比较2个值,然后返回一个用于说明这2个值的相对顺序的数字,比如比较a与b,返回值如下:
若a小于b,在排序后的数组中a应该出现在b之前,则返回一个小于0的值。
若a等于b,在排序后的数组中 a等于b 则返回0;
若a大于b,则返回一个大于0的值;
var arrs = ["tugenhua","longen","alibaba"];
console.log(arrs.sort()); // ["alibaba", "longen", "tugenhua"]
var arrs2 = ["","","",""];
console.log(arrs2.sort(function(a,b){
return a - b; // ["5", "8", "12", "15"]
}));
splice 该方法用于插入,删除和替换数组的元素;
基本语法如下:Array.splice(index,howmany,element1,.....elementX);
Index参数:必填,是从何处添加/删除元素,该参数是开始插入或删除数组元素的下标,必须是数字;
Howmany: 应该删除多少个元素,必须是数字,也可以是0,如果未设定该参数,则删除从index开始到原数组结尾的所有元素;
Element1: 可选,规定要添加到数组的新元素,从index所指的下标处开始插入;
ElementX: 可选,可向数组中添加若干个元素;
slice 该方法是从已有的数组中返回指定的元素。
基本语法:arrs.slice(start,end);
start参数:必须,从何处开始选取(包括start),如果是负数,那么会从尾部选取,比如-1代表最后一个元素,-2代表倒数第二个元素,以此类推。
End参数:可选,规定是从何处结束选取(不包括end),如果没有指定该参数,那么数组会包含从start开始到数组结束的所有元素,如果该参数是负数的话,那么它规定的是从数组尾部开始算起的元素。
判断一个数组中是否有相同的元素
一
function isRepeat1(arrs) {
if(arrs.length > ) {
var s = arrs.join(",");
for(var i = ,ilen = arrs.length; i < ilen; i+=) {
if(s.replace(arrs[i],"").indexOf(arrs[i])>-) {
return true;
}
}
}
return false;
}
二
function isRepeat2(arrs) {
var hash = {};
if(arrs.length > ){
for(var i = ,ilen = arrs.length; i < ilen; i+=) {
if(hash[arrs[i]]) {
return true;
}
hash[arrs[i]] = true;
}
}
return false;
}
三
function and(arr){
var json = {};
for(var i=;i<arr.length;i++){
if(json[arr[i]] == undefined){json[arr[i]] = ;}
else{json[arr[i]]++;}
} for(var j in json){
if(json[j]>){console.log("true");break;}
}
}
计算一个数组中每个元素在数组中出现的次数
一
/*
* 计算数组中每个元素在数组中出现的个数
* @param {arrs} 数组
* @method 定义一个新数组,循环当前的数组,使用一个临时的变量temp保存当前的值,外层for循环定义一次变量count=0,当做计数器,内部再一次循环数组判断当前的数组与外层的数组某一项是否相等,如是count++; 然后把当前的一项值置为-1,下一次就不会再继续循环了
* @return {newArrs} 返回一个新数组
*/
function arrayElemCount(arrs){
var newArrs = [];
if(arrs.length > ) {
for(var i = ,ilen = arrs.length; i < ilen; i+=) {
var temp = arrs[i];
var count = ;
for(var j = ,jlen = arrs.length; j < jlen; j+=) {
if(arrs[j] == temp) {
count++;
arrs[j] = -;
}
}
newArrs.push(temp + ":" +count);
}
}
return newArrs;
}
var arrs = [,,,,,,,,,,,];
console.log(arrayElemCount(arrs));
// 打印如下:["1:3", "2:3", "-1:6", "-1:6", "3:2", "4:1", "5:1", "6:1", "7:1", "-1:12", "-1:12", "-1:12"]
// 键值为-1的,都可以去掉 二
function and(arr){
var json = {};
for(var i=;i<arr.length;i++){
if(json[arr[i]] == undefined){json[arr[i]] = ;}
else{json[arr[i]]++;}
}
return json;
}
Javascript删除数组重复元素的操作
1. 方案一遍历数组使用indexOf方法,代码如下:
/*
* javascript数组去重方案一
* @param {arrs} 原数组
* @method 新建一个新数组,遍历原数组,在新数组内使用indexOf查找原数组内的每一项,如果没有找到,就把当前的项存入新数组里面去,这样就过滤掉
* 重复项 indexOf方法在IE8及IE8以下不支持,因此有必要封装一个
* @return {newArrays} 返回新数组
*/
function arrayUnique(arrs) {
var newArrays = [];
for(var i = ,ilen = arrs.length; i < ilen; i++) {
if(newArrays.indexOf) {
if(newArrays.indexOf(arrs[i]) == -) {
newArrays.push(arrs[i]);
}
}else {
if(indexOf(arrs[i],newArrays) == -) {
newArrays.push(arrs[i]);
}
} }
return newArrays;
}
/*
* 为了支持IE8及以下浏览器需要封装一个indexOf方法
* @param {arr,arrs} 某一项 原数组
* @return 返回数组某一项
*/
function indexOf(arr,arrs){
if(arrs.length > ) {
for(var i = ,ilen = arrs.length; i < ilen; i+=) {
if(arrs[i] == arr) {
return i;
}
}
}
return -;
}
var arrs = [,,,,,];
console.log(arrayUnique(arrs)); // [1,2,3]
2. 方案二:数组下标判断法;
/*
* 数组下标判断法
* 思路:先定义一个新数组,循环当前数组,使用indexOf方法,如果在当前的数组的第i项在当前数组中的位置是i项的话,说明该项在数组中并未出现过,存入新数组,否则的话,在原数组中出现过,因此需要过滤掉。性能和第一种方案差不多。
* @return {newArrars} 返回新数组
*/
function arrayUnique(arrs) {
var newArrays = [];
if(arrs.length > ) {
for(var i = ,ilen = arrs.length; i < ilen; i+=) {
if(arrs.indexOf) {
if(arrs.indexOf(arrs[i]) == i) {
newArrays.push(arrs[i]);
}
}else {
if(indexOf(arrs[i],arrs) == i) {
newArrays.push(arrs[i]);
}
} }
}
return newArrays;
}
/*
* 为了支持IE8及以下浏览器需要封装一个indexOf方法
* @param {arr,arrs} 某一项 原数组
* @return 返回数组某一项
*/
function indexOf(arr,arrs){
if(arrs.length > ) {
for(var i = ,ilen = arrs.length; i < ilen; i+=) {
if(arrs[i] == arr) {
return i;
}
}
}
return -;
}
var arrs = [,,,,];
console.log(arrayUnique(arrs)); // [1,2,3]
3. 方案三:排序后相邻去除法
/*
* 排序后相邻去除法
* @method 新建一个新数组,遍历当前的数组,如果当前的数组某一项不等于新数组的最后一项的话,就把当前的项存入新数组中,最后返回新数组
*/
function arrayUnique(arrs) {
var newArrays = [];
if(arrs.length > ) {
arrs.sort();
for(var i = ,ilen = arrs.length; i < ilen; i+=) {
if(arrs[i] !== newArrays[newArrays.length - ]) {
newArrays.push(arrs[i]);
}
}
}
return newArrays;
}
var arrs = [,,,,];
console.log(arrayUnique(arrs)); // [1,2,3]
4. 方案四:对象键值对法
/*
* 对象键值法(该方法性能最优)
* @method 定义一个空对象和空新数组,遍历当前的数组,判断该对象是否存在数组的某一项,如果不存在
* 就当当前的某一项存入新数组去,且当前的项置为-1 目的过滤掉重复的项
*/
function arrayUnique(arrs) {
var newArrays = [];
var hash = {};
if(arrs.length > ) {
for(var i = ,ilen = arrs.length; i < ilen; i+=) {
if(!hash[arrs[i]]) {
hash[arrs[i]] = ;
newArrays.push(arrs[i]);
}
}
}
return newArrays;
}
var arrs = [,,,,,,,];
console.log(arrayUnique(arrs)); // [4,5,2,1,3]
Javascript删除数组里面的某个元素。
方案一:使用indexOf和splice()方法删除某个元素;
/*
* 为了支持IE8及以下浏览器需要封装一个indexOf方法
* @param {arr,arrs} 某一项 原数组
* @return 返回数组某一项
*/
function indexOf(arr,arrs){
if(arrs.length > ) {
for(var i = ,ilen = arrs.length; i < ilen; i+=) {
if(arrs[i] == arr) {
return i;
}
}
}
return -;
}
/*
* 删除数组里面的某个元素
* @param {elem,arrs} 要删除的元素 原数组
* 思路:先使用indexOf方法在数组里面找到该元素的位置,然后使用splice()方法删除一个元素
* @return {elem,arrs} 返回一个对象,对象有2个元素,第一个是被删除的元素elem键,另一个是被删除元素
后的数组,也就是新数组 [2,3]
*/
function removeAttrsElem(elem,arrs){
var newElem;
if(arrs.length > ) {
var index = indexOf(elem,arrs);
if(index > -) {
newElem = arrs.splice(index,);
}
}
return {
elem: newElem,
arrs: arrs
}
}
var arrs = [,,];
var elem = ;
console.log(removeAttrsElem(elem,arrs));
// 返回一个对象 {elem:1,arrs:[2,3]}
方案二:直接遍历数组 取其中某一项 如果某一项与该元素相同的话,直接截取,和第一种方案类似,比第一种方案简单
/*
* 删除数组里面的某个元素
* @param {elem,arrs} 要删除的元素 原数组
* 思路:直接遍历数组 取其中某一项 如果某一项与该元素相同的话,直接截取,和第一种方案类似,比第一种方案简单
* @return {elem,arrs} 返回一个对象,对象有2个元素,第一个是被删除的元素elem键,另一个是被删除元素
后的数组,也就是新数组 [2,3]
*/
function removeAttrsElem(elem,arrs){
var newElem;
if(arrs.length > ) {
for(var i =,ilen = arrs.length; i < ilen; i+=) {
if(arrs[i] == elem) {
newElem = arrs.splice(i,);
}
}
}
return {
elem: newElem,
arrs: arrs
}
}
var arrs = [,,];
var elem = ;
console.log(removeAttrsElem(elem,arrs));
// 返回一个对象 {elem:1,arrs:[2,3]}
在javascript中求出2个数组的相同的元素
思路:先定义一个对象,把A数组转换成对象,然后遍历B数组,判断B数组中某一项是否在A数组那个对象里面 如果在的话,说明B数组与A数组有相同的元素,否则B数组和A数组有不同的元素有哪些;
/*
* 求出2个数组的相同的元素和不同的元素
* 思路:先定义一个对象,把A数组转换成对象,然后遍历B数组,判断B数组中某一项是否在
* A数组那个对象里面 如果在的话,说明有相同的元素,否则为不同的元素
*/
function getArrsSameAndDiffElem(arrs1,arrs2){
var hash = {},
sameElemArrs = [],
diffElemArrs = [];
if(arrs1.length > ) {
for(var i = ,ilen = arrs1.length; i < ilen;i+=) {
hash[arrs1[i]] = ;
}
}
if(arrs2.length > ) {
for(var j = ,jlen = arrs2.length; j < jlen; j+=) {
if(hash[arrs2[j]]) {
// 说明有相同的元素,把相同的元素存入sameElemArrs数组里面去
sameElemArrs.push(arrs2[j]);
}else {
// 说明是不同的元素,把不同的元素存入diffElemArrs数组里面去
diffElemArrs.push(arrs2[j]);
}
}
}
return {
sameElemArrs: sameElemArrs,
diffElemArrs: diffElemArrs
}
}
var arrs1 = ["aac","aab","cfg",'longen','tugenhua','single'];
var arrs2 = ["aac","mnc","nba","cba","anta",'tugenhua','single'];
console.log(getArrsSameAndDiffElem(arrs1,arrs2));
// 打印出 diffElemArrs = ["mnc","nba","cba","anta"]
// 相同的元素 sameElemArrs = ["aac",'tugenhua','single']
如上可以看到 arrs2中与arr1中数组有相同的元素如上,不同的元素也如上;
如果需要判断arr1中与arr2中数组相同元素及不同的元素,传递参数调换位置即可!
Javascript检测2个数组是否相似
判断2个数组是否相似的条件:
- 先判断这两个对象是否为Array的实例。
- 接着判断该数组的长度是否一致。
- 判断该2个对象的类型是否一样,先对这2个数组先转换为字符串后,再进行排序比较,如果该2个对象类型的个数一致,长度一致,且都是数组,说明该2个数组是相似的;比如如下:
var arr11 = [,true]; var arr22 = [false,];
如上2个数组是相似的,但是如果2个数组如下这样的话
var arr11 = [,true]; var arr22 = [false,true];
说明2个数组不相似了~
function arraysSimilar(arr1,arr2) {
if(!(arr1 instanceof Array) || !(arr2 instanceof Array)) {
return false;
}
if(arr1.length !== arr2.length) {
return false;
}
var arrsLen = arr1.length;
var tempArrs1 = [],
tempArrs2 = [];
for(var i = ; i < arrsLen; i+=) {
var t1 = Object.prototype.toString.apply(arr1[i]);
tempArrs1.push(t1);
var t2 = Object.prototype.toString.apply(arr2[i]);
tempArrs2.push(t2);
}
return tempArrs1.sort().join() === tempArrs2.sort().join() ? true : false;
}
var arr1 = ["aa","cc",false,"bb"];
var arr2 = ["","cc","",false];
console.log(arraysSimilar(arr1,arr2)); // true var arr11 = [,true];
var arr22 = [false,];
console.log(arraysSimilar(arr11,arr22)); // true
如何判断该对象是否为数组。
1. typeof
首先我们会想到的是使用typeof来检测数据类型,但是对于Function, String, Number, Undefined等这几种基本类型来说,使用typeof来检测都可以检测到,比如代码如下:
function test(){}
console.log(typeof ); // number
console.log(typeof test); // function
console.log(typeof "yunxi"); // string
console.log(typeof undefined); // undefined
但是对于数组或者正则来说,使用typeof来检测的话,那就满足不了,因为当我们检测数组或者正则的话,那么返回的类型将会是一个对象object,如下代码所示:
console.log(typeof []); // object
console.log(typeof /\d+/g); // object
2. Instanceof
由此我们很容易会想到使用instanceof来检测某个对象是否是数组的实例,该检测会返回一个布尔型(boolean),如果是数组的话,返回true,否则的话返回false;我们再来看下上面的检测是否为数组的代码如下:
console.log([] instanceof Array); // true
console.log(/\d+/g instanceof Array); // false
如上可以看到使用instanceof确实可以判断是否为数组的列子;
3. constructor属性
在javascript中,每个对象都有一个constructor属性,它引用了初始化该对象的构造函数,比如判断未知对象的类型,因此我们可以如下写一个方法:代码如下:
function isArray(obj) {
return typeof obj == 'object' && obj.constructor == Array
}
// 测试demo
console.log(isArray([])); // true
var a = {"a":1};
console.log(isArray(a)); // false var b = [1,2,3];
console.log(isArray(b)); // true
console.log(isArray(/\d+/g));// false
如上可以看到,通过调用isArray 方法也可以判断是否为数组的列子。
我们现在可以看到,对于第二点和第三点分别使用instanceof方法和constructor属性貌似都可以来判断是否为数组了,但是也有列外情况,比如在跨框架iframe的时候使用页面中的数组时,会失败,因为在不同的框架iframe中,创建的数组是不会相互共享其prototype属性的;如下代码测试即可得到验证~
var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;
var arr = new xArray("1","2","3","4","5");
//这个写法IE下是不支持的,标准浏览器firefox,chrome下有 console.log(arr); // 打印出 ["1", "2", "3", "4", "5"]
console.log(arr instanceof Array); // false
console.log(arr.constructor === Array); // false
如上的方法我们都不能来判断一个对象是否为数组的方式; 但是我们在看ECMA262中可以看到,可以用 Object.prototype.toString.call()方法来判断一个对象是否为数组;如下代码:
function isArray(obj) {
return Object.prototype.toString.call(obj) == '[object Array]';
}
// 代码调用
console.log(isArray([])); // true
console.log(isArray([1,2,3])); // true var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;
var arr = new xArray("1","2","3","4","5"); console.log(arr); // ["1","2","3","4","5"]
console.log(isArray(arr)); // true
js将类数组对象转换成数组对象
首先我们来看一下类数组,什么是类数组,类数组有什么特征呢?
具有:有指向对象的数字索引 及 length属性值;
不具有:它不具有数组的方法,比如push,slice,pop等方法;
Javascript中常见的类数组有arguments, HTMLCollection的集合(比如document.getElementsByClassName,document.getElementsByTagName)等方法,常见的类数组对象有如下:
document.getElementsByClassName, document.getElementsByTagName,document.getElementsByName,arguments等等;比如如下测试代码:类数组可以有length属性,可以遍历,但是它并不是数组的实例,如下代码:
function elems(){
for(var i = 0, ilen = arguments.length; i < ilen; i+=1) {
console.log(arguments[i]); // 循环2次 打印出 1,2 }
console.log(arguments instanceof Array);// false
}
elems(1,2);
我们再来测试下arguments是否和数组一样有push方法;测试代码如下:
function test(){
console.log(arguments.push(1)); //arguments.push is not a function
}
test();
在控制台中打印出 arguments.push is not a function 报错,说明类数组并不是一个真正的数组,因为它没有数组的方法;
但是我们可以将类数组转换为数组,我们可以使用slice()方法call对象;slice()方法可以将一个类数组对象/集合转换成一个数组,只需要使用数组原型上的slice方法call这个对象,即Array.prototype.slice.call(arguments);即可将类数组转换为数组,或者我们也可以使用[].slice.call(arguments);来转换数组;
如下代码:
function test(){
//var args = [].slice.call(arguments);
var args = Array.prototype.slice.call(arguments);
console.log(args.push(1)); //1
}
test();
使用上面的 [].slice.call()方法和 Array.prototype.slice.call()方法都可以将类数组转换为数组的,比如上面的args就是转换后的数组,其后就拥有push()方法;
当然如果我们不嫌麻烦的话,我们可以先在函数内部定义一个新数组,然后使用arguments.length的属性遍历每一项,把每一项存入到新数组里面去也是可以的,但是这样做并没有上面的好;如下代码:
function elems(){
var newArrs = [];
for(var i = 0, ilen = arguments.length; i < ilen; i+=1) {
newArrs[i] = arguments[i];
}
console.log(newArrs); // [1,2]
}
elems(1,2);
查找数组中最大值与最小值
最小值算法如下:
- 将数组中第一个元素赋值给一个变量,把这个变量作为最小值;
- 开始遍历数组,从第二个元素开始依次和第一个元素进行比较。
- 如果当前的元素小于当前的最小值的话,就把当前的元素值赋值给最小值;
- 移动到下一个元素,继续对第三步操作;
- 当数组元素遍历结束时,这个变量存储的就是最小值;
代码如下:
// 查找数组中最小值
function arrayMin(arrs){
var min = arrs[0];
for(var i = 1, ilen = arrs.length; i < ilen; i+=1) {
if(arrs[i] < min) {
min = arrs[i];
}
}
return min;
}
// 代码测试
var rets = [2,4,5,6,7,9,10,15];
console.log(arrayMin(rets));//2
上面是对数组中的数值进行比较的,如果数组中的数字是字符串的话,先要把字符串转换成数字再进行比较即可,因为字符串比较的不是值,而是ASCII编码,比如2的ASCLL编码会大于15的ASCII编码,因为15的编码第一个数字是1,2的ASCII编码肯定大于1的;
求最大值的算法和上面类似:
1.将数组中第一个元素赋值给一个变量,把这个变量作为最大值;
2.开始遍历数组,从第二个元素开始依次和第一个元素进行比较。
3.如果当前的元素大于当前的最大值的话,就把当前的元素值赋值给最大值;
4移动到下一个元素,继续对第三步操作;
5.当数组元素遍历结束时,这个变量存储的就是最小值;
// 在数组中查找最大值
function arrayMax(arrs) {
var max = arrs[0];
for(var i = 1,ilen = arrs.length; i < ilen; i++) {
if(arrs[i] > max) {
max = arrs[i];
}
}
return max;
}
// 代码测试
var rets = [2,4,5,6,7,9,10,15];
console.log(arrayMax(rets));//15
参考:
http://www.cnblogs.com/tugenhua0707/p/5052808.html
JavaScript引用类型的更多相关文章
- 图解Javascript引用类型之数组
以图说事明理,恰当时候会事半功陪.今天我就尝试着用图的方式讲讲“JavaScript引用类型之数组”.望更多童鞋给我反馈! 好东西分享给大家,但要尊重事实!!!因此特别说明:本图非我本人亲自所作,乃我 ...
- JavaScript - 引用类型
对象在JavaScript中被称为引用类型的值. 引用类型和传统面向对象设计中的类相似,但实现不同. Object是一个基础类型,其他所有类型都从Object继承了基本的行为. Array类型,Dat ...
- 浅析JavaScript引用类型之--Object、Array
1.Object类型 对象是某个特定引用类型的实例,新对象有两种创建方式: i.使用new操作符调用构造函数来创建. var person = new Object(); person.name = ...
- JavaScript引用类型(二)
Date类型 Javascript中的Date类型是采用Java中的java.util.Date类基础上构建的,使用UTC时间来保存数据,可以精确到1970年1月1日之前或之后的285616年 创建一 ...
- 【javascript 引用类型(一)】
javascript 的引用类型大致分为:Object 类型.Array 类型.Date 类型.RegExp 类型.Function 类型.基本包装类型和单体内置对象.这里我们着重介绍 Object ...
- JavaScript引用类型之Object类型
在JavaScript中大多数的引用类型都是Object的实例,Object类型也是使用最多的类型! 创建Object类型实例的方式有两种,下面分别来分析一下: (1)第一种是使用new操作符后跟Ob ...
- JavaScript引用类型和值类型
thead>tr>th,.table>tbody>tr>th,.table>tfoot>tr>th,.table>thead>tr>t ...
- JavaScript——引用类型之数组
前言 之前本菜打算在写完基本类型后写引用类型Object的,因为Object是引用类型的基础,其他的引用类型也是以Object为根本.只是关于对象的基本认识与简单操作确实可写的不多,打算之后与原型.原 ...
- JavaScript引用类型和基本类型的区别
JavaScript变量可以用来保存的两种类型的值:基本类型值和引用类型值. 基本类型值有5种类型:undefined,null,boolean,number,string 引用类型值有两种类型:函数 ...
随机推荐
- iocp还是select
上一个项目libevent应该是select,现在libuv是iocp,都知道Windows下iocp比select效率高,boost asio 也是iocp,但具体使用select和iocp发现没有 ...
- 对Java垃圾回收最大的误解是什么
当 我还是小孩的时候,父母常说如果你不好好学习,就只能去扫大街了.但他们不知道的是,清理垃圾实际上是很棒的一件事.可能这也是即使在Java的世界中, 同样有很多开发者对GC算法产生误解的原因--包括它 ...
- 自然语言16.1_Python自然语言处理学习笔记之信息提取步骤&分块(chunking)
QQ:231469242 欢迎喜欢nltk朋友交流 http://www.cnblogs.com/undercurrent/p/4754944.html 一.信息提取模型 信息提取的步骤共分为五步,原 ...
- Hash Table in C
http://www.sparknotes.com/cs/searching/hashtables/section3.rhtml http://en.literateprograms.org/Spec ...
- background属性
background: url(images/01.jpg) 0 10px; 效果: background: url(images/01.jpg) 0 -10px; 效果: *注释:10px 是网上去 ...
- Brew Command Not Found
安装了brew后,居然找不到brew命令.于是uninstall后再次install,居然还是Brew Command Not Found. 解决办法: http://stackoverflow.co ...
- Quartz.NET总结(二)CronTrigger和Cron表达式
Quartz.NET的任务调度,主要就是依靠CronTrigger和Cron表达式.Cron是已经在UNIX存在了很长一段时间,它有着强大和可靠的调度能力.CronTrigger类也正是是基于Cron ...
- Tomcat服务器原理详解
[目录]本文主要讲解Tomcat启动和部署webapp时的原理和过程,以及其使用的配置文件的详解.主要有三大部分: 第一部分.Tomcat的简介和启动过程 第二部分.Tomcat部署webapp 第三 ...
- 对AccessViolationException的一些总结
引言 开发Winform程序时,应用程序出现了异常,整个应用程序崩溃自动退出了.在断点调试后,发现异常是AccessViolationException.所以对周围的语句加上了异常的处理机制.但是接下 ...
- Web 安全测试
http://blog.sina.com.cn/s/blog_a1bbddc70101dt12.html http://blog.csdn.net/pdn2000/article/details/64 ...