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

深圳微信网站建设公司哪家好网络营销的优势包括

深圳微信网站建设公司哪家好,网络营销的优势包括,网站名字和域名,网站如何做三端适配前言 今天我们开始I/O的学习。 I/O的学习主要以函数为主,即主要靠记忆,当然实际的工程应用过程中完全可以开卷,但出于对生产力的考量,依旧需要主动记忆大量内容。 概述 1.I/O基本概念(含笔记与导图) 2.cat的…

前言

        今天我们开始I/O的学习。

        I/O的学习主要以函数为主,即主要靠记忆,当然实际的工程应用过程中完全可以开卷,但出于对生产力的考量,依旧需要主动记忆大量内容。

概述

        1.I/O基本概念(含笔记与导图)

        2.cat的实现

        3.文件cp的实现

        4.计算文件行数的实现

1.I/O基本概念(含笔记与导图)

一、I/O 基本概念
  1. 文件输入(读取)

    • 数据从 硬盘(存储设备) 读取到 内存 中。

    • 示例程序:/a.out

  2. 文件输出(写入)

    • 数据从 内存 写入到 硬盘(存储设备) 中。


二、存储设备对比(硬盘 vs 内存)
特性硬盘(SID)内存(ARM)
容量空间大空间小
速度较慢速度快
持久性数据持久存储(非易失性)断电后数据丢失(易失性)
访问方式按键不直接接触按键直接接触

三、标准 I/O 与文件 I/O 的区别
类型交互对象特点
标准 I/O程序 ↔ 用户缓冲机制、高可移植性
文件 I/O程序 ↔ 操作系统依赖系统、低可移植性

四、标准 I/O 关键特性
特性描述
缓冲区减少直接系统调用,提高效率
速度较快(缓冲优化)
调用方式库函数(如 fprintffscanf
可移植性高(跨平台兼容)
操作对象流指针(FILE*
支持资源文件、标准输入/输出(stdin/stdout)

五、常用标准 I/O 函数列表
  1. 文件操作

    • FILE* fopen(const char* filename, const char* mode);

    • int fclose(FILE* stream);

  2. 错误处理

    • void perror(const char* s);

    • char* strerror(int errno);

  3. 字符 I/O

    • int fputc(int c, FILE* stream);

    • int fgetc(FILE* stream);

  4. 文件定位

    • int fseek(FILE* stream, long offset, int origin);

    • void rewind(FILE* stream);

    • long ftell(FILE* stream);

  5. 字符串 I/O

    • int fputs(const char* str, FILE* stream);

    • char* fgets(char* str, int size, FILE* stream);

  6. 格式化 I/O

    • int fprintf(FILE* stream, const char* format, ...);

    • int fscanf(FILE* stream, const char* format, ...);


六、注意事项
  1. 资源释放:使用 fclose 及时关闭文件,避免资源泄漏。

  2. 错误检查:调用 perror 或 strerror 诊断 I/O 错误。

  3. 缓冲机制:标准 I/O 默认启用缓冲,可通过 setbuf 调整。

思维导图与手写笔记如下:

附:I/O的基本操作

#include <IO_head.h>
int main(int argc, const char *argv[])
{//打开文件FILE* file_p = fopen("./my.txt","w+");if(file_p==NULL){ERROR("fopen failed");}//if(file_p==NULL){perror("fopen failed");return -1;}//printf("%s\n",strerror(errno));//printf("fopen failed\n")else{printf("fopen succeeded\n");}//写文件if(fputc('a',file_p)==-1){printf("fputc failed\n");return -1;}else{printf("fputc succeeded\n");}//计算文件大小long len = ftell(file_p);printf("length of file: %ld\n",len);//光标的偏移rewind(file_p);/*if(fseek(file_p,0,SEEK_SET)==-1){ERROR("fseek failed\n");}else{printf("fseek succeeded\n");}*///读文件char buf = (char)fgetc(file_p);if(buf==EOF){printf("fgets failed\n");}else{printf("fgets succeeded:buf=%c\n",buf);}//关闭文件:     //fclose(FILE* file_p){return 0;/return EOF;#define EOF (-1))}if(fclose(file_p)==EOF){ERROR("fclose failed");}else{printf("fclose succeeded\n");}return 0;
}
ubuntu@ubuntu:~/IO/class1$ ./04_fseek 
fopen succeeded
fputc succeeded
length of file: 1
fgets succeeded:buf=a
fclose succeeded
ubuntu@ubuntu:~/IO/class1$ 

2.cat的实现

2.1.codes

#include <IO_head.h>
int main(int argc, const char *argv[])
{//读取外部传参if(argc<2){printf("erroe");}FILE* file_p = fopen(*(argv+1),"r");if(file_p==NULL){ERROR("fopen failed");}else{printf("fopen succeeded\n");}//实现cat的功能char buf[128] = {0};rewind(file_p);while(1){memset(buf, 0, sizeof buf);//读取//char* fgets(char* s, int len, FILE* stream){...return s;}if(fgets(buf, sizeof buf, file_p)==NULL){printf("fgets failed\n");break;}buf[strcspn(buf, "\n")] = '\0';//buf[strlen(buf)-1]='\0';//printf("fgets succeeded\n");printf("buf = [%s]\n",buf);}return 0;
}

2.2.run

ubuntu@ubuntu:~/IO/class1$ ./h1 my.txt
fopen succeeded
buf = [abcd]
buf = [efg]
buf = [hi]
buf = [j]
fgets failed
ubuntu@ubuntu:~/IO/class1$ 

此处./h1相当于cat

注意:没有写fclose,因为累了......

3.文件cp的实现

3.1.codes

#include <IO_head.h>
int main(int argc, const char* argv[]){//欲将键入的文件进行拷贝,至少需要一个原文件,一个目标文件if(argc<3)printf("error");//获取外部传参FILE* file_2_p = fopen(*(argv+2),"r");FILE* file_1_p = fopen(*(argv+1),"w");char  buf[128]={0};while(1){memset(buf,0,sizeof buf);if(fgets(buf,sizeof buf,file_2_p)!=NULL){printf("fgets succeeded\n");}else{printf("fgets failed\n");break;}if(fputs(buf,file_1_p)!=EOF){printf("fputs succeeded\n");}else{printf("fgets failed\n");break;}}return 0;
}

3.2.run

ubuntu@ubuntu:~/IO/class1$ ./h2 new.text my.txt
fgets succeeded
fputs succeeded
fgets succeeded
fputs succeeded
fgets succeeded
fputs succeeded
fgets succeeded
fputs succeeded
fgets failed
ubuntu@ubuntu:~/IO/class1$ ./h1 new.text
fopen succeeded
buf = [abcd]
buf = [efg]
buf = [hi]
buf = [j]
fgets failed
ubuntu@ubuntu:~/IO/class1$ 

此处./h2相当于cp

注意:同理,没有写fclose,因为累了......

4.计算文件行数的实现

4.1.codes

#include <IO_head.h>
int main(int argc, const char* argv[]){//获取外部传参if(argc<2)printf("error\n");FILE* file_p = fopen(*(argv+1),"r");//循环计算行数char buf[128]={0};int len = 0;while(1){memset(buf,0,sizeof buf);if(fgets(buf,sizeof buf, file_p)!=NULL){len++;}else{break;}}printf("有%d行\n",len);return 0;
}

4.2.run

ubuntu@ubuntu:~/IO/class1$ ./h3 my.txt
有4行
ubuntu@ubuntu:~/IO/class1$ 

此处./h3相当于计算行数的函数。

注意:同理,没有写fclose,因为累了......

结语

        以上。

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

相关文章:

  • wordpress免费主题网站百度搜索高级搜索
  • b站免费版2023最新版本免费网站推广网站短视频
  • 如何做网络营销推广5seo课培训
  • 个人网站制作wordpress网络推广外包公司排名
  • 关于做女装的网站品牌网
  • 帝国 cms 网站关键字全球搜官网
  • 哈尔滨发布信息的网站360网站seo手机优化软件
  • 免费制作app生成器网站市场调研报告范文2000
  • DW做的网站加载慢湖北权威的百度推广
  • 工人找工作哪个网站好网络营销策略分析报告
  • 二手书网站的建设规模网站浏览器
  • 网站查询功能代码新闻稿发布平台
  • 做网站推广被骗深圳网络营销推广方案
  • php不用框架怎么做网站网络营销介绍
  • 合肥做网站 卫来网络合肥seo优化
  • 营销型网站建设必须的步骤包括自己怎么搭建网站
  • web前端做网站如何网络推广
  • 国外做的比较的ppt网站有哪些做小程序的公司
  • 做网站编辑好还是新媒体编辑关键词站长工具
  • 响应式网站头部企业模板建站
  • 自己做签名网站seo在线培训机构排名
  • 外国网站上做Task线上营销推广方式都有哪些
  • 还有哪些方法让网站更加利于seo今日头条网站推广
  • 校园网站建设 德育专业的网站优化公司排名
  • wordpress引流优化方法
  • 贵阳做个网站需要多少钱中国优秀网页设计案例
  • 上海专业做网站公司厦门seo怎么做
  • 网站开发 集成包建设网站的十个步骤
  • 贵阳做网站费用深圳推广公司哪家最好
  • 做APP必须要有网站么潍坊网站收录