前言
C语言函数内存函数、memmove函数、、memcmp函数、memset函数等以及杨辉三角的介绍
一、memmove函数----重叠内存拷贝
库函数
#include <stdio.h>
#include <string.h>
int main()
{
int arr1[] = { 1,2,3,4,5,6,7,8,9 };
memmove(arr1 + 2, arr1, 20);
int i = 0;
int sz = sizeof(arr1) / sizeof(arr1[0]);
for (i = 0; i < sz; i++)
{
printf("%d ", arr1[i]); // 1 2 1 2 3 4 5 8 9
}
return 0;
}
- memmove的模拟实现
#include <stdio.h>
#include <assert.h>
void* my_memmove(void* dest, const void* src, size_t num)
{
assert(dest && src);
void* ret = dest;
if (dest < src)
{
while (num--)
{
*(char*)dest = *(char*)src;
dest = (char*)dest + 1;
src = (char*)src + 1;
}
}
else
{
while (num--)
{
*((char*)dest + num) = *((char*)src + num);
}
}
return ret;
}
int main()
{
int arr1[] = { 1,2,3,4,5,6,7,8,9 };
my_memmove(arr1 + 2, arr1, 20); // 1 2 1 2 3 4 5 8 9
//my_memmove(arr1, arr1+2, 20); // 3 4 5 6 7 6 7 8 9
int i = 0;
int sz = sizeof(arr1) / sizeof(arr1[0]);
for (i = 0; i < sz; i++)
{
printf("%d ", arr1[i]);
}
return 0;
}
二、memcmp----内存比较
库函数
int memcmp ( const void * ptr1, const void * ptr2, size_t num );
- 若ptr1 > ptr2, 则返回大于0的数字
- 若ptr1 == ptr1,则返回0
- 若ptr1 < ptr2, 则返回小于0的数字
- num 是要比较的字节数。
#include <stdio.h>
#include <string.h>
int main()
{
int arr1[] = { 1,2,3,4,5,6,7 };
int arr2[] = { 1,5,2 };// -1
//int arr2[] = { 1,2,3 };// 0
//int arr2[] = { 1,1,2 };// 1
int ret = memcmp(arr1, arr2, 12);
printf("%d ", ret);
return 0;
}
- 在vs2022编译器上只返回1 0 -1。
三、memset函数----内存设置
库函数
void * memset ( void * ptr, int value, size_t num );
- ptr 为要设置的内存的起始地址
- value 要设置为的内容
- num 以字节为单位的个数
#include <stdio.h>
#include <string.h>
int main()
{
char ch[] = "hello csdn";
int arr[] = { 1,2,3,4,5,60 };
memset(ch, 'x', 5); // xxxxx csdn
//memset(ch + 6, 'x', 4);// hello xxxx
memset(arr + 5, 6, 1);// 1 2 3 4 5 6
printf("%s\n", ch);
int i = 0;
for (i = 0; i < 6; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
四、杨辉三角
#include <stdio.h>
int main()
{
int arr[100][100] = { 0 };
int val = 0;
scanf("%d", &val);
int i = 0;
int j = 0;
for (i = 0; i < val; i++)
{
for (j = 0; j <= i; j++)
{
if (0 == j || i == j)
{
arr[i][j] = 1;
}
else
{
arr[i][j] = (arr[i - 1][j - 1]) + (arr[i - 1][j]);
}
}
}
for (i = 0; i < val; i++)
{
for (j = 0; j < val - 1 - i; j++)
{
printf(" ");
}
for (j = 0; j <= i; j++)
{
printf("%d ", arr[i][j]);
}
printf("\n");
}
return 0;
}
总结
C语言函数内存函数、memmove函数、、memcmp函数、memset函数等以及杨辉三角的介绍