對數組的整體賦值,以及兩個數組間的復制容易出錯,這里使用string頭文件中的memset和memcpy進行
不必遍歷數組,速度快。
之前沒有頭文件,顯示decla
頭文件:
代碼:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
/* Project: 數組的整體賦值與復制 Date: 2018/07/31 Author: Frank Yu memset(數組名,0或-1,字節) memcpy(數組名,數組名,字節) */ #include<iostream> #include<cstring> //memset需要頭文件 #include<cstdio> #define n 5 using namespace std; int main() { int a[n]; int b[n]; memset(a,0, sizeof (a)); //初始化為0 //memset(b,1,sizeof(b));//初始化為1,錯誤 memset(b,-1, sizeof (b)); printf( "請輸入%d個數:\n" ,n); for ( int i=0;i<n;i++) { scanf( "%d" ,&a[i]); } printf( "第一個數組為:\n" ); for ( int i=0;i<n;i++) { printf( "%d " ,a[i]); } printf( "\n" ); printf( "第二個數組為:\n" ); for ( int i=0;i<n;i++) { printf( "%d " ,b[i]); } printf( "\n" ); memcpy(a,b, sizeof (b)); //b的元素復制給a printf( "第一個數組被第二個數組覆蓋后:\n" ); for ( int i=0;i<n;i++) { printf( "%d " ,a[i]); } return 0; } |
結果截圖:
20190304更新...
fiil函數需要頭文件 algorithm fill執行速度不如memset
fill(first,last,val)對數組進行初始化,first,last為地址,val為值。例如,fill(a,a+5,123) 將數組a的前5個初始化為123。
補充知識:C++ 中使用memset和memcpy 對字符串和字符串數組處理
我就廢話不多說了,大家還是直接看代碼吧~
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
#include <iostream> #include <string.h> using namespace std; struct SomeInfo { char id[30]; char name[30]; }; struct TotalInfo { char total[20]; SomeInfo my[10]; }; class myClass { public : myClass() { } ~myClass() { } void memcopy( int ,TotalInfo); void print(); private : TotalInfo m_totalInfo; int m_count; }; void myClass::memcopy( int count ,TotalInfo info) { m_count = count; memcpy(&m_totalInfo,&info, sizeof (m_totalInfo)); } void myClass::print() { std::cout << m_totalInfo.total << std::endl; for ( int i = 0; i != m_count ; ++i) { std::cout << m_totalInfo.my[i].id << std::endl; std::cout << m_totalInfo.my[i].name << std::endl; } } int main() { myClass here = myClass(); TotalInfo totalInfo; memset(&totalInfo, 0, sizeof (totalInfo)); char total[20] = "totalInfo.total" ; memcpy(totalInfo.total,total,20); int count = 5; for ( int i = 0; i != count ; ++i) { char _id[30] = "totalInfo.Some.id" ; char _name[30] = "totalInfo.Some.name" ; memcpy(totalInfo.my[i].id, _id, sizeof (_id)); memcpy(totalInfo.my[i].name, _name, sizeof (_name)); } here.memcopy(count, totalInfo); here.print(); return 0; } |
在main函數的第三行,memset初始化新申請的內存。memset:作用是在一段內存塊中填充某個給定的值,它是對較大的結構體或數組進行清零操作的一種最快方法。
一共三個參數,地址,請零(目前做的是清零動作,而不是char型值),地址空間大小。
memcpy 也有三個參數,一個目標地址,源地址,和 大小。
以上這篇C/C++中memset,memcpy的使用及fill對數組的操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:https://blog.csdn.net/lady_killer9/article/details/81321947