整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

javascript基础内容之数组的赋值

javascript基础内容之数组的赋值

面一个小分享给大家演示了数组的定义、获取、以及遍历等小例子

这一节小分享呢道哥给大家细说一下javascript数组中的赋值,赋值什么意思呢,就是说要把内容都存储在数组中都有哪些个基本的方法

在上面的例子中呢大家可以看一下说的呢很基础,希望能给初学的盆友一点点帮助,在后续的数组案例分享中呢,道哥会一一的给大家分享怎么用数组来实现一些小案例,比如用数组做一个随机抽取人名的小游戏,用数组呢动态的计算一些平均数啊 总分啊等等等等。

  • 怎么理解迭代与归并,就是对整个数组进行一系列函数的操作的方法,具体如下。

every();通过函数核对各项,返回结果true或false,every就是全部符合条件为true。

some();通过函数核对各项,返回结果true或false,some就是部分符合条件为true。

filter();通过函数核对各项,返回符合条件项的数组。

map();通过函数处理各项,返回处理后项的数组。

forEach();类似于一个for循环来处理数组,注意它是无返回值的。

reduce();可以理解为一个数组的遍历函数,它是从头开始遍历。

reduceRight();它是与上一个相反的,从尾往前遍历数组。

一、every()返回true或false。

图1

二、some()返回true或false。

图2

三、filter()返回的是数组,而不再是true或是flase。

图3

四、map()返回的也是数组,是经过处理后的数组。

图4

五、forEach(),这里要注意的是,它是没有返回值的,有点像把数组丢到for循环去处理一样,你可以把这个函数看成是for的循环体。

图5

六、reduce(),可以理解为一个数组的遍历函数,它是从头开始遍历。

图6

七、reduceRight(),它是与上一个相反的,从尾往前遍历数组。

图7

本文来源于,落笔承冰原创。

者在上一篇文章《C语言中为何不能直接对一个数组对象赋值》中谈到了为何C语言设计之初没有把对数组赋值的语法引入的各种缘由。当然,从其语法体系角度而言,一个数组对象作为表达式被使用时,其类型会被隐式转换为指向其元素类型的指针,而数组本身的引用是不能被修改的,所以像下面的代码会导致语法错误:

int arr1[3]={ 0 };
int arr2[3]={ 0 };
arr1=arr2;    // 相当于:(int * const)arr1=(int *)arr2;

这是显而易见的。

那有没有办法能通过某种语法扩展来使得C语言能方便地对数组进行赋值呢?答案是可以被设计出来的!笔者这里通过GNU语法扩展中所引入的 Case Ranges(https://gcc.gnu.org/onlinedocs/gcc/Case-Ranges.html),再结合C++17中所完善的折叠表达式fold expression)为C语言设计出 [ from ... to ] 这一索引折叠表达式(index fold expression的语法扩展。


基本定义

如果一个表达式中含有 [ from ... to ] 这种表达,那么该表达式即为索引折叠表达式。其通常表现形式为:

a[ 0 ... 2 ]=b[ 5 ... 7 ];

相当于:

( a[0]=b[5],
  a[1]=b[6],
  a[2]=b[7]
);

这里为了简化编译器实现,可以将 fromto 限定为常量表达式,即它们必须是编译时就能确定的常量。这一点是跟GNU语法扩展中所引入的 Case Ranges 所契合的。当 [ from ... to ] 的操作数是一个数组对象时,to 可被缺省。而当 to 被缺省时,其值为 sizeof(array) / sizeof(array[0]) - 1U。这一点也可适用于变长数组。


约束

  • 对于任何一个 [ from ... to ],必须满足:from <= to。当 from == to 时,它即被退化为基本表达式primary expression)。
  • 如果一个表达式具有多个 [ from ... to ],那么所有子表达式中的 to - from 的值必须全都相同。
  • 索引折叠表达式的返回值与其他约束均可继承于逗号表达式


代码例子

int arr1[3]={ 1, 2, 3 };
int arr2[5]={ 1, 2, 3, 4, 5 };
// 相当于:(arr1[0]=arr2[2], arr1[1]=arr2[3], arr1[2]=arr2[4]);
arr1[0 ...]=arr2[2 ...];
// 相当于:int arr3[3]={ arr2[1], arr2[2], arr[3] };
int arr3[]={ arr2[1 ... 3] };

int sum=0;
// 相当于:(sum +=arr1[0], sum +=arr1[1], sum +=arr[2]);
sum +=arr1[0 ...];
// 相当于:(arr1[0] +=sum, arr1[1] +=sum, arr1[2] +=sum);
arr1[0 ...] +=sum;

static bool IsLower(int a, int b)
{
     return a < b;
}

bool bArr[3];
// 相当于:
// (bArr[0]=IsLower(arr1[0], arr3[0]), 
//  bArr[1]=IsLower(arr1[1], arr3[1]),
//  bArr[2]=IsLower(arr1[2], arr3[2])
// );
bArr[0 ...]=IsLower(arr1[0 ...], arr3[0 ...]);

int FooInc(int arr[static 3])
{
    // 相当于:(++arr[0], ++arr[1], ++arr[2]);
    // 注意,arr作为函数形参,其本质上属于指针,而不是数组,
    // 因此,这里 to 的位置不可缺省!
    ++arr[0 ... 2];
    // 相当于:return (arr[0], arr[1], arr[2]);
    // 因此最后其实返回的是 arr[2] 的值。
    return arr[0 ... 2]; 
}


优化

如果对多个数组或是被 restrict 修饰的指针进行操作的话,编译器后端可以生成SIMD指令或是使用Intel TBB或微软的PPL这种并行库的 parallel_for,对这些数组元素做多线程并行操作。