////////————strtok(切割字符串,切割出我们想要的字符串)
////strtok函数有记忆功能
////char* strtok(char* str,const char* sep)
////char* str:要求被切割的源字符串。第一个参数str是源字符串,它里面包含的是分割符
////const char* sep:要被进行切割的总字符串。第二个参数sep是总字符串
//#define _CRT_SECURE_NO_WARNINGS 1
//#include <stdio.h>
//#include <string.h>
//int main()
//{
// char email[] = "kkk@qq.com";//“@”“.”.....叫做分割符
// const char* str = "qq";
// char cp[30] = { 0 };
// strcpy(cp, email);
// //char* ret = strtok(cp, str);
// //if(ret != NULL)//判断空指针不打印,即加了if语句后就不会再打印出NULL
// // printf("%s\n", ret);//此处用cp而不是email,是因为我们要求不改变总字符串的内容
// //ret = strtok(NULL, str);//传空指针的目的是,看到空指针NULL就意味着我们要从保存好的位置逐渐的往后找
// //if (ret != NULL)
// // printf("%s\n", ret);
// //ret = strtok(NULL, str);
// //if (ret != NULL)
// // printf("%s\n", ret);
// //优化此部分
// char* ret = NULL;
// for (ret = strtok(cp, str); ret != NULL; ret = strtok(NULL, str))
// {
// printf("%s\n",ret);
// }
// return 0;
//}
////“strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针”的意思是:
//// 在总字符串中找到一个标记,并把标记(分割符)的位置改成\0(把标记换成\0),换成\0就意味着更改了总字符串
//// 因此strtok函数会改变被操作的字符串。
//// 所以在使用strtok函数切割的字符串时,创建变量并拷贝总字符串一个同于总字符串的可以修改的变量
//
////“返回一个指向这个标记的指针”的意思是:
//// 返回一个从被替换为\0的位置向左直至总字符串开头的位置中的这段字符串中的首字符的地址(即示例的z的地址)
//
////1.strtok函数的第一个参数不为 NULL(同理于总字符串不是NULL) ,
//// 函数将找到str中第一个标记(首字符到第一个被换成\0的字符段),
//// strtok函数将保存它在字符串中的位置(第一个换成\0的位置的地址)。
//
////2.strtok函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置(第一个换成\0的位置的地址)开始,
//// 查找下一个标记(第一个替换为\0的位置的后面那位字符到第二个被换为\0的字符段)。
//
////综上所述,只有在第一字符段的时候第一个参数传cp,后续再次调用strtok函数时,第一参数传空指针NULL即可
////如果字符串中不存在更多的标记,则返回 NULL 指针(总字符串中无要求切割的字符串)。
//
////1.如何切割,是根据源字符串的字符来决定的,
////2.分割符是根据源字符串定义的,源字符串中有什么,什么就是分割符。
////3.分割顺序:依据源字符中的字符顺序从左至右依次分割(为了避免分割符在总字符串虽然挨着但是顺序颠倒)
////4.源字符串中每一个字符串都是分割符,若分割符挨着或相等,就以第二个为准(分割符都不会被打印)。
////注意:由于分割符被替换成了\0,因此也就等同于分割符不会被打印,打印的只是分割符互相之间的字符
//// strerror(错误报告函数)
////1.只要C语言中调用库函数时发生错误,就会把错误码放进变量里去
////2.变量errno是C语言设置的一个全局的错误码存放的变量,使用errno需引用头文件<errno.h>
////3.想知道错误原因就打印错误信息,打印的错误信息来自strerror,并把错误码errno传给strerror
////4.作用:返回错误码所对应的信息(把错误码传给函数,函数再返回错误码所对应信息的字符串的首字符的地址)
////5.C语言的库函数再执行失败的时候都会设置错误码,例如0,1,2,3...分别代表一种错误
////6.注意:当有多个错误时,遇到第一个错误就会停下来,所以记录并打印的是第一个错误。
//// 如果错误发生了,程序并没有停下来,仍继续执行,则始终记录最新的错误
//#define _CRT_SECURE_NO_WARNINGS
//#include <stdio.h>
//#include <string.h>
//#include <errno.h>//必须包含的头文件
//int main ()
//{
// FILE* p=fopen("C:\\Users\\HONOR\\Desktop\\tr","r");//文件test.txt要放到相应的代码路径(与程序代码所放路径相同)才运行成功,
// //("test.txt","r")的意思是只能在自己的工程目录下寻找
// //若放到其他地方就要写绝对路径;例如放到桌面上,就要右击文件找到属性里的绝对路径才可以运行成功
// //打开文件专用函数fopen ,返回的是FILE*的指针,打开成功返回一个有效的地址,打开失败就会返回一个空指针NULL
// // "test.txt":文件名,"r":以"读"的形式打开。
// if (p == NULL)//判断,打开文件失败。
// {
// printf("%s\n", strerror(errno));
// return 1;
// }
// else//判断,打开文件成功。
// {
// printf("s");//
// }
// return 0;
//}