用c语言实现字符串拷贝函数有几种方式
首先是使用库函数
比如下面代码
123void ourstrcopy(char s1[] , char s2[]){
strcpy(s1, s2); //该函数还有另一个版本可以按长度截取
}
还有一个函数是memcpy,这个是内存拷贝,原型是
123void memcpy(void *dest, const void *src, size_t n);
需要注意的是这个函数第一个和第二个指针都是void型且第二个指针不能被修改,第三个参数是需要拷贝的内存长度按字节记。
然后是用指针引用,注意这个并非赋值,而是引用,这种操作需要注意内存。
12char s1[] = “abcdefg”;//定义一组字符串
char *s2 = s1;//按照指针拷贝字符串
第三种方法就是直接赋值了
12345678910111213void outstrcopy(char s1[] , char s2[]){
int len1 = strlen(s1);//获取第一个字符串的长度
int len2 = strlen(s2);//获取第二个字符串的长度
int len = 0; //字符串总长度
if(len1 《= len2){
len = len2; //选择copy的长度
}else{
len = len1;
}
for(int i = 0 ; i 《 len ; i++){
s1[i] = s2[i]; //实现数据拷贝
利用c语言中的函数实现文件的copy
网上的方法大致有这样几种:
1、使用操作系统提供的复制文件的api
2、使用c语言本身提供的复制文件的函数
3、直接读写文件,从文件角度来操作,从而直接将一个文件复制
这里我们使用的就是这第三种。
读写
(1)。按字符进行读写操作
fgetc
int fgetc(file *stream);
参数:
@stream 流指针
返回值:
成功 返回对应字符的int值
失败 返回eof(end of file) 实际上是一个结束标志 在文件本身并不存在
fputc
int fputc(int c, file *stream);
参数:
@c 要输出的字符
@stream 指定的输出流
返回值:
成功 返回对应字符的ascii(int)的值
失败 eof
通过 fopen fgetc fputc 实现文件拷贝
#include《stdio.h》
int main(int arg,char* argv[]){
file *fp1;
file *fp2;
fp1 = fopen(argv[1],“r”);
fp2 = fopen(argv[2],“w”);
if(fp1==null||fp2==null){
perror(“file copy error!\n”);
return -1;
}
int ch;
while((ch=fgetc(fp1))!=eof){
fputc(ch,fp2);
}
fclose(fp1);
fclose(fp2);
}
复制文件的思路大概是这样的,如果是文本类型,则可直接使用字符读写的方式,依次读写到另一个文件中。但如果是非字符型文件那应该怎么进行操作呢?我的方法是使用二进制形式打开,然后依次针对字节进行操作,依次从文件第一个字节读写至最后一个字节实现文件的复制,那么由此可得,这种方法同样可以用在远程的操作上,即实现文件的远程传输。
那么问题来了,怎么针对字节来进行读取文件呢?这里我总结了两种办法。
注意:本文针对的解决方案是依字节读取,如果觉得效率低得话可以多字节读取,但这样就存在一个问题,怎么保证正好和源文件大小相同而不是比源文件大。那么推荐的做法是先获取源文件的大小,然后直接读取进行操作。
在c语言系统中void型指针占用一个字节,char型占用一个字节,正好满足我们的要求,所以可以分别使用来完成我们需要的操作。
需要注意,这里我们用到的概念是类型并不是限制了使用的数据类型,不是说char型只能用来存放char型变量,数据类型提供的是一系列针对特定类型的操作,这方便了我们的操作,但不能存在思维定式,一种数据类型提供的是一种可能性,比如char型变量,它给了我们2^8种可能性,如果我们需要表示16种可能的话,完全可以使用一个char型变量来存放,而不是使用一个int型变量,节省了系统开销。但真实情况下,需要考虑到程序的易读性问题,而不是考虑内存的问题,更何况内存已经越来越便宜,空间越来越大,cpu性能越来越好。
源码如下:
#include 《stdio.h》
int main(int argc, char* argv[])
{
file *op,*inp;
op=fopen(“a.png”,“rb”);
inp=fopen(“b.png”,“wb”);
void *buf;
char c;
while(!feof(op))
{
//方法二
fread(&buf,1,1,op);
fwrite(&buf,1,1,inp);
//方法二
fread(&c,1,1,op);
fwrite(&c,1,1,inp);
}
fclose(inp);
fclose(op);
printf(“over”);
return 0;
}
Galaxy Fold还未上市 三星“拉伸屏”专利曝光!
脸书使用人工智能技术,以解决新冠肺炎带来的各种问题
历史遗留矿山核查方法研究-莱森光学
I2C总线协议操作介绍
《大规模图像理解、分割新进展》的主题演讲
利用C语言中的函数实现文件的Copy
劲爆!5G走向现实需快速的可扩展原型验证方法
倍压整流可以提供大电流吗?
钢铁冶炼厂粉尘在线实时监测
fpga工程师的出路在哪里
理性看待智能制造 为智能制造热潮降温
赛灵思增强型实时视频引擎 加速新一代视频处理设备的投产
UVLED光固化在集成电路方面的应用
物联网的应用有哪些?
浅析多相位降压转换器的优势
智能魔镜显示屏将帮助我们“镜”享健康的新生活
嘉宾金句|OpenHarmony技术峰会——生态与互联分论坛
网站部署SSL证书迫在眉睫 HTTPS化全球来袭
能不能设计一种机器学习算法来预测和分析我们的梦境?
冲击试验机,如何对机器进行校准?校准周期需要多久呢?