for(i=0;i<strlen(a);i++) {s[i]=a[i];}
可以,使用:memcpy函数
memcpy函数用于在内存之间复制一定数量的字节。您可以使用memcpy函数将一个数组的内容复制到另一个数组中。
#include <string.h>
int main() {
int arr1[] = {1, 2, 3, 4, 5};
int arr2[5];
memcpy(arr2, arr1, sizeof(arr1));
// arr2现在包含arr1的值
return 0;
}
使用memcpy函数也行
#include<stdio.h>
#include<string.h>
int main()
{
int a[5] = {1, 2, 3, 4, 5};
int b[5];
memcpy(b, a, sizeof(int) * 5);
for (int i=0;i<5;i++){
printf("%d",b[i]);
}
return 0;
}
可以利用memcpy(s,a,strlen(a))或strcpy(s,a)进行整体的内存拷贝或字符拷贝。
不知道你这个问题是否已经解决, 如果还没有解决的话:参考自:
https://blog.csdn.net/this_capslock/article/details/17001003方法一:回调函数为普通的全局函数,但在函数体内执行类的成员函数
在创建线程调用回调函数时,传入类对象的指针(比如this指针)作为参数,并在回调函数中把void*强制转换为类的指针(MyClass*),就能使用该指针调用类的成员函数。
这样做的原理是把当前对象的指针当作参数先交给一个外部函数,再由外部函数调用类成员函数。以外部函数作为回调函数,但执行的是成员函数的功能,这样相当于在中间作了一层转换。
缺点:回调函数在类外,影响了封装性。
方法二:回调函数为类内静态成员函数,在其内部调用类的非静态成员函数
此时需要一个指向类本身的、类的静态成员变量指针(static MyClass* CurMy),用来存储当前回调函数调用的对象,相当于法1中给回调函数传入的指针参数。在回调函数中通过CurMy指针调用类的成员函数。
优点:1、解决了法1的封装性问题,
2、没有占用callback的参数,可以从外界传递参数进来
缺点:每个对象启动子线程前一定要注意先让CurMy正确的指向自身,否则将为其它对象开启线程。
方法三:对成员函数进行强制转换,使其作为回调函数
这个方法是原理是,MyClass::func最终会转化成 void func(MyClass *this);即在原第一个参数前插入指向对象本身的this指针。可以利用这个特性写一个非静态类成员方法来直接作为线程回调函数。
typedef void* (*FUNC)(void*);
FUNC callback = (FUNC)&MyClass::func;
对编译器而言,void (MyClass::*FUNC1)()和void* (*FUNC)(void*)这两种函数指针虽然看上去很不一样,但他们的最终形式是相同的,因此就可以把成员函数指针强制转换成普通函数的指针来当作回调函数。在建立线程时要把当前对象的指针this当作参数传给回调函数(成员函数func),这样才能知道线程是针对哪个对象建立的。
注意:此方法中FUNC函数的参数一定要是void*,这样才能在编译后把this指针转变为MyClass *this。
优点:法3的封装性比法2更好,因为不涉及多个对象共用一个静态成员的问题,每个对象可以独立地启动自己的线程而不影响其它对象。
可以使用ES6中的解构赋值来实现数组的互相整体赋值。具体步骤如下:
定义需要互相赋值的数组A和数组B。
使用解构赋值语法,将数组A的值赋值给数组B。
```javascript let A = [1, 2, 3]; let B = [];
// 使用解构赋值将A赋值给B [B[0], B[1], B[2]] = A;
// 输出B的值 console.log(B); // [1, 2, 3] ```
在上面的代码中,我们使用解构赋值语法将数组A的值赋值给数组B。由于A和B的长度相同,因此可以直接使用下标的方式将值赋给B。
如果A和B的长度不同,也可以使用类似下面的方式来实现:
```javascript let A = [1, 2, 3]; let B = [4, 5];
// 使用解构赋值将A赋值给B [B[0], B[1], B[2] = 0] = A;
// 输出B的值 console.log(B); // [1, 2, 3] ```
在上面的代码中,由于两个数组的长度不同,因此需要再使用解构赋值语法时,给B数组多赋一个默认值,以免数组越界。
需要注意的是,解构赋值只是ES6语法中的一种方式,如果需要兼容旧版本的浏览器,需要使用其他方式来实现。
直接赋值
初始化赋值
使用memcpy()函数将一个数组的元素复制到另一个数组中。