创建数组注意事项:js中的数组长度、类型都是“动态性”的。即长度可变、类型多样。
面试的时候经常会被问道:js中怎么判断一个变量是数组类型?
答案有很多,这里我列举一下我所知道的一些判断方法
1 //千万别犯这种错误 2 console.log(typeof []) //object 3 // 方法一 4 var arr = [1,2,3]; 5 console.log(arr.constructor === Array)//true 6 //方法二 7 console.log(arr instanceof Array) //true 8 //方法三 9 console.log(Object.PRototype.toString.call(arr) === '[object Array]')//true10 //方法四11 Array.isArray(arr) //es5 新方法
1 //代码来自网络,大致能表达我的意思 2 // 定义一个数组,存储不同数据类型的元素 3 var array = [8, 2, 1, 5], 4 array2 = [ 5 [0, 1], 6 [1, 2], 7 [2, 3] 8 ], 9 value;10 11 /// Array.prototype.reduce = function(callback,initialValue) {};12 // 化解数组:13 // 调用reduce 方法提供的回调函数,14 // 总共调用 数组的lenght - 1次 回调函数15 // 第一次时 previousValue 为 initialValue16 // 此后 reduce方法的返回值 作为 previousValue17 18 // reduceRight 则从数组最右边开始,进行上述操作19 20 // 数组中元素累加21 value = array.reduce(function (previousValue, currentValue, index, array) {22 return previousValue + currentValue;23 }24 );25 console.log(value); // 1626 27 // 数组扁平化28 value = array2.reduce(function (previousValue, currentValue, index, array) {29 return previousValue.concat(currentValue);30 }31 );32 console.log(value); // [ 0, 1, 1, 2, 2, 3 ]33 34 /// Array.prototype.indexOf = function(searchElement,fromIndex) {};35 // 从fromIndex索引处 向后寻找searchElement元素 找到并返回其索引,否则返回-136 // fromIndex 默认为 037 console.log(array.indexOf(1)); // 238 console.log(array.indexOf(3)); // -139 40 /// Array.prototype.lastIndexOf = function(searchElement,fromIndex) {};41 // 从fromIndex索引处 向前寻找searchElement元素 找到并返回其索引,否则返回-142 console.log(array.lastIndexOf(1)); // 243 console.log(array.lastIndexOf(3)); // -144 45 /// Array.prototype.every = function(callback,thisObject) {};46 // 测试数组的所有元素是否都通过了指定函数的测试47 value = array.every(function (element, index, array) {48 return element > 1;49 });50 console.log(value); // false51 52 53 /// Array.prototype.filter = function(callback,thisObject) {};54 // 数组过滤:55 // 返回通过函数测试的 元素(当回调函数的返回true,表明元素通过测试 ),生成新的数组56 value = array.filter(function (element, index, array) {57 return element > 1;58 });59 console.log(value);// [ 8, 2, 5 ]60 61 62 /// Array.prototype.forEach = function(callback,thisObject) {};63 // 为每个数组元素执行一次回调函数。64 array.forEach(function (element, index, array) {65 console.log(element);66 });67 68 69 /// Array.prototype.map = function(callback,thisObject) {};70 // 数组映射:71 // 返回一个由原数组中的每个元素调用一个指定方法后的返回值组成的新数组。72 value = array.map(function (element, index, array) {73 return element * element;74 });75 console.log(value); // [ 64, 4, 1, 25 ]76 77 78 /// Array.prototype.some = function(callback,thisObject) {};79 // 测试数组中的某些元素是否通过了指定函数的测试。80 value = array.some(function (element, index, array) {81 return element > 1;82 });83 console.log(value); // true84 85 86 /// Array.prototype.isArray = function(object) {};87 // 判断元素是否为数组类型88 console.log(Array.isArray(array)); // trueView Code
这是我在谷歌浏览器查找的数组全部方法属性 截图如下
1 var x = [1, 9, 8]; 2 var y = x; 3 x[0] = 2; 4 console.log(y[0]);//2
2.联合数组
1 var arr=[]; 2 arr['a']=1; 3 arr['b']=2; 4 console.log(a.length);//0 数组是对象类型,当然js中一切皆为对象!!!
3.类数组。
JavaScript和DOM中有很多类数组对象,它们只是类似数组,而不是数组,并不能使用数组的特有方法,如slice、push、pop等。
arguments
getElementsByName(name)
getElementsByClassName(className)
getElementsByTagName(tagName)
document.forms //所有form元素
document.images //所有img元素
document.links //所有带href属性的a元素和area元素
.......
类数组转为真正的数组方法:Array.prototype.slice.call(arguments);
4.稀疏数组。
稀疏数字就是包含从0开始的不连续索引的数组。
稀疏数组的length属性值大于元素的个数. 代码如下
var a=[];a[100]=23;console.log(a.length);//101
5.作为数组的字符串
个人理解是:可索引的字符串。
var s="javascript";console.log(s[1]);//a 标准的字符串方法应该是s.charAt(1)//数组和字符串方法可以灵活的相互利用Array.prototype.join.call(s,"+");//j+a+v+a+s+c+r+i+p+t
备注:push()、sort()、reverse()、splice()等数组方法会修改数组,但是在字符串上是无效的。因为字符串是不可变值!!!
前言:JAVA数组与容器类主要有三方面的区别:效率、类型和保存基本类型的能力。在JAVA中,数组是一种效率最高的存储和随机访问对象引用序列的方式。数组就是一个简单的线性数列,这使得元素访问非常快速。但是为此付出的代价却是数组的大小被固定,并且在其生命周期中不可改变。
当我们定义一个变量时可以使用一个变量名表示,但是如果出现很多的变量我们分别起变量名代替表示存储就比较麻烦了,为了解决这样的问题我们采用数组的形式表示存储,使用下标 表示每个变量。
声明一个变量就是在内存中划出一块合适的空间;声明一个数组就是在内存中划出一串连续打的空间
1、打印数组
int[] intArray = { 1, 2, 3, 4, 5 };String intArrayString = Arrays.toString(intArray); // print directly will print reference valueSystem.out.println(intArray);// [I@7150bd4d System.out.println(intArrayString);// [1, 2, 3, 4, 5]
2、检查一个数组是否包含某个值
String[] stringArray = { "a", "b", "c", "d", "e" };boolean b = Arrays.asList(stringArray).contains("a");System.out.println(b);// true
3、移除数组中的元素
int[] intArray = { 1, 2, 3, 4, 5 };int[] removed = ArrayUtils.removeElement(intArray, 3);System.out.println(Arrays.toString(removed));
4、数组转为list
String[] stringArray = { "a", "b", "c", "d", "e" };ArrayList<String> arrayList = new ArrayList<String>(Arrays.asList(stringArray));System.out.println(arrayList);// [a, b, c, d, e]
5、数组转为set
Set<String> set = new HashSet<String>(Arrays.asList(stringArray));System.out.println(set);//[d, e, b, c, a]
6、数组比较
Arrays提供了重载后的equals()方法,针对所有类型和Object类型都做了重载,用来比较整个数组。数组相等的条件是元素个数必须相等,并且对应位置的元素也相等。而多维数组的比较用deepEquals()方法。Array.equals()方法比较的两个数组必须是同类型的数组。
import java.util.Arrays;public class javaArrayEquals{ public static void main(String args[]){ int[] arrayA = {1,2,3}; int[] arrayB = {1,2,3,}; int[] arrayC = new int[4]; //if int[] arrayC = new int[3],return true arrayC[0] = 1; arrayC[1] = 2; arrayC[2] = 3; System.out.println(Arrays.equals(arrayA, arrayB)); System.out.println(Arrays.equals(arrayA, arrayC)); String[][] arrayD = {{"a","b"},{"c","d"}}; String[][] arrayE = {{"a","b"},{"c","d"}}; System.out.println(Arrays.deepEquals(arrayD, arrayE)); }}View Code
7、集合更加强
新闻热点
疑难解答