当前位置: 首页 > wzjs >正文

免费网站设计定制网络营销策划是什么

免费网站设计定制,网络营销策划是什么,用什么建设网站,南京汽车企业网站建设目录&#xff1a; 1. memcpy使用和模拟实现 2. memmove使用和模拟实现 3. memset函数的使用 4. memcmp函数的使用 以上函数均包含在一个头文件<string.h>里面 一、memcpy的使用和模拟实现。 memcpy函数介绍&#xff1a; 函数原型&#xff1a; void * memcpy ( void…

目录:

        1. memcpy使用和模拟实现

        2. memmove使用和模拟实现

        3. memset函数的使用

        4. memcmp函数的使用

以上函数均包含在一个头文件<string.h>里面 

一、memcpy的使用和模拟实现。

memcpy函数介绍:

函数原型:

 void * memcpy ( void * destination, const void * source, size_t num );

• 函数memcpy从source的位置开始向后复制num个字节的数据到destination指向的内存位置。

• 这个函数在遇到 '\0' 的时候并不会停下来。

• 如果source和destination有任何的重叠,复制的结果都是未定义的。

解释一下第三点:

比如 :要把一个数组的3,4,5,6拷贝到1,2,3,4的位置,就是内存重叠

         即一个数组一个位置的值复制另一个位置的值的时候,不能有内存的叠加,否则会报错。

        对于重叠的内存,交给memmove来处理。 

 参考代码:


#include<stdio.h>
#include<string.h>
int main()
{ int arr1[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };int arr2[10] = { 0 };memcpy(arr2, arr1, 20);for (int i = 0; i < 10; i++){printf("%d ", arr2[i]);}return 0;
}

 运行结果:

模拟实现memcpy: 

1.从低地址向高地址拷贝

2.因为数据类型是不知道的,所以只能一个一个的字节来拷贝,

比如:int类型需要1个字节1个字节得拷贝4次,才能完成一个数的拷贝

参考代码: 

void* memcpy(void* dst, const void* src, size_t count)
{void* ret = src;assert(dst);assert(src);while (count--){*(char*)dst = *(char*)src;dst = (char*)dst + 1;src = (char*)src + 1;}return ret;}

二、 memmove使用和模拟实现

memcpy函数介绍:

函数原型:

 void * memmove ( void * destination, const void * source, size_t num );

• 和memcpy 的差别就是 memmove 函数处理的源内存块和目标内存块是可以重叠的。

• 如果源空间和目标空间出现重叠,就得使用memmove函数处理。

即可以解决内存重叠的拷贝 

参考代码:

#include<stdio.h>
#include<string.h>int main()
{int arr1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};memmove(arr1 + 2, arr1, 20);int i = 0;for (i = 0; i < 10; i++){printf("%d ", arr1[i]);}return 0;
}

这段代码可以实现:将数组arr1里面的前4个数,拷贝到第2个位置数的后面,

即将红色区域里面的内容拷贝到绿色位置上。

模拟实现memmove:

分情况讨论:

        假设源空间(src)在中间,即3,4,5,6,7 

        情况一:目标空间(dest)在源空间(src)的前面(无重叠),从前往后拷贝 和 从后往前拷贝都行。

        情况二:目标空间(dest)和源空间(src)有重叠,需要分:前重叠 ,后重叠

                       前重叠:从前往后拷贝

                       后重叠:从后往前拷贝

        情况三:目标空间(dest)在源空间(src)的后面(无重叠),从前往后拷贝和从后往前拷贝都行。

参考代码:

void* memmove(void* dst, const void* src, size_t count)
{void* ret = dst;if (dst <= src || (char*)dst >= ((char*)src + count))  //情况一 ,前重叠,情况三{while (count--)                        //从前往后拷贝{*(char*)dst = *(char*)src;dst = (char*)dst + 1;src = (char*)src + 1;}}else        //后重叠{dst = (char*)dst + count - 1;    //从后往前拷贝src = (char*)src + count - 1;while (count--){*(char*)dst = *(char*)src;dst = (char*)dst - 1;src = (char*)src - 1;}}return ret;
}

三、memset的使用 

memset的介绍

函数原型

void * memset ( void * ptr, int value, size_t num );

memset是用来设置内存的,将内存中的值以字节为单位设置成想要的内容。 

参考代码

#include <stdio.h>
#include <string.h>
int main()
{char str[] = "hello world";memset(str, 'x', 6);printf(str);return 0;
}

将字符串str的前6个字符设置成x 

运行结果: 

四、memcmp函数的使用

memcmp函数的介绍

函数原型:

int memcmp ( const void * ptr1, const void * ptr2, size_t num );

• 比较 从 ptr1 和 ptr2 指针指向的位置开始,向后的num个字节(按照字典序来比较)

• 返回值如下: 

str1 小于 str2 返回小于0的数

str1 等于 str2 返回0

str1 大于 str2 返回大于0的数

参考代码:

#include <stdio.h>
#include <string.h>
int main()
{char buffer1[] = "DWgaOtP12df0";char buffer2[] = "DWGAOTP12DF0";int n;n = memcmp(buffer1, buffer2, sizeof(buffer1));if (n > 0)printf("'%s' is greater than '%s'.\n", buffer1, buffer2);else if (n < 0)printf("'%s' is less than '%s'.\n", buffer1, buffer2);elseprintf("'%s' is the same as '%s'.\n", buffer1, buffer2);return 0;
}

http://www.dtcms.com/wzjs/58325.html

相关文章:

  • 中国监理建设注册网站湖南疫情最新情况
  • 班级网站建设策划书目前最流行的拓客方法
  • 宁波做网站哪里专业广告推销
  • 深圳网站建设 公司元体育热点新闻
  • 沧州哪里做网站小吃培训去哪里学最好
  • 江西网站建设哪家专业网站seo优化教程
  • 楼盘网站建设方案seo网站优化公司
  • 在天津做网站的公司全国人大常委会
  • 免费浪漫网页制作网站合肥网站排名推广
  • 世界疫情最新数据统计排名seo优化师培训
  • 大连网站开发师b站推广入口
  • 信息部网站建设工作计划学网络运营需要多少钱
  • java做网站后端近一周的新闻大事热点
  • 网站开发报告书河北关键词seo排名
  • 网站前置审批怎么做发稿
  • 网站怎么做直播大连头条热点新闻
  • 晋江市规划局建设网站国内新闻大事20条
  • 网站开发与维护视频教程it培训机构出来能找到工作吗
  • 个人网站做电商福州百度快照优化
  • 做图标的网站seo教程之关键词是什么
  • 建立网站有哪些步骤百度如何注册公司网站
  • 东莞网站建设服务网络营销软件下载
  • 网站首页制作公司seo入门课程
  • 关于网站建设论文的结束语西安seo网站优化
  • 湘潭网站建设 技精磐石网络企业营销型网站策划
  • 东莞中英文网站建设seo的目的是什么
  • 中国工商注册营业执照的官网seo兼职
  • php企业网站程序网址如何被快速收录
  • 黄冈市建设银行网站武汉大学人民医院
  • 备案网站大全百度推广登陆