做为一名Java程序员,为了能顺利得到offer,不得不掌握C和C++的一些基础知识,以防止寻职时笔试被送。如下介绍了一些常用的C、C++函数,希望对各位有用。
(1)
函数原型:extern char strstr(char *haystack,char *needle);
用法:#include
功能:从字符串haystack中寻找needle第一次出现的位置(不比较结束符NULL)返回指向第一次出现needle位置的指针,如果没有找到则返回NULL。 (2) 函数原型:extern float pow(float x, float y); 用法:#include
功能:x应该大于0,返回幂指数的结果
printf(%f,pow(3,3));// 必须使用%f,使用%d不允许 printf(%f,pow(-3,-3));//在自己实现的时候必须要考虑到正负数的情况(3) 函数原型:const char *c_str(); 功能:c_str()函数返回一个指向正规C语言字符串的指针
string s=ssss;
printf(%s,s.c_str()); (4) 函数原型:gets(char *str) 说明:从stdin流中读取字符串,直至接受到换行符(换行符好像并不能退出)或EOF时停止,并将读取的结果存放在buffer指针所指向的字符数组中。换行符不作为读取串的内容,读取的换行符被转换为null值,并由此来结束字符串。
int main(){
char str[101];
gets(str);// 按行进行参数的获取
//cout<
(5)
函数原型:char * strncpy(char *dest, char *src,size_t num);
功能:将字符串src中最多num个字符复制到字符数组dest中(它并不像strcpy一样遇到NULL才停止复制,而是等凑够num个字符才开始复制),返回指向dest的指针。
注意:
如果num > dest串长度,dest栈空间溢出产生崩溃异常。否则:
1)src串长度<=dest串长度,(这里的串长度包含串尾NULL字符)
如果num =(0, src串长度),src的前num个字符复制到dest中。但是由于没有NULL字符,所以直接访问dest串会发生栈溢出的异常情况。如果num = src串长度,与strcpy一致。如果num = dest串长度,[0,src串长度]处存放于desk字串,(src串长度, dest串长度]处存放NULL。
2)src串长度>dest串长度
如果num =dest串长度,则dest串没有NULL字符,会导致输出会有乱码。如果不考虑src串复制完整性,可以将dest最后一字符置为NULL。
综上,一般情况下,使用strncpy时,建议将num置为dest串长度(除非你将多个src串都复制到dest数组,并且从dest尾部反向操作),复制完毕后,为保险起见,将dest串最后一字符置NULL,避免发生在第2)种情况下的输出乱码问题。所以,无论是strcpy还是strncpy,保证src串长度
再来看一个类似的函数: 函数原型:char *strcpy(char *dest, char *src); 功能:把src所指由''结束的字符串复制到dest所指的数组中。src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。最后返回指向dest的指针。 注意:当src串长度>dest串长度时,程序仍会将整个src串复制到dest区域,可是dest数组已发生溢出。因此会导致dest栈空间溢出以致产生崩溃异常。如果不考虑src串的完整性,可以把dest数组最后一元素置为NULL,从dest串长度处插入NULL截取字串。 Strcpy和Strncpy正确使用示例:
char* p=how are you ;
char name[20]=ABCDEFGHIJKLMNOPQRS;
strcpy(name,p); //name改变为how are you
strncpy(name,p, sizeof(name));//name改变为how are you 后续的字符将置为NULL
可以看到,在使用strncpy()函数时,最后一个参数取的是目标串的长度。
如果拷贝的串的长度大于目标串长度时,两者的处理方式:
char* p=how are you ;
char name[10];
strcpy(name,p); //目标串长度小于源串,错误!
name[sizeof(name)-1]=''; //和上一步组合,弥补结果,但是这种做法并不可取,因为上一步出错处理方式并不确定
strncpy(name,p,sizeof(name)); //源串长度大于指定拷贝的长度sizeof(name),注意在这种情况下不会自动在目标串后面加''
name[sizeof(name)-1]=''; //和上一步组合,弥补结果
(6) 函数原型:void *memset(void *s, int ch, size_t n); 功能:将s中前n个字节 (typedef unsigned int size_t)用 ch 替换并返回 s 。 在使用之前,C中引入string.h,而C++中引入cstring (7) 函数原型:FILE * fopen(const char * path,const char * mode); 说明:参数path字符串包含欲打开的文件路径及文件名,参数mode字符串则代表着流形态。 mode最常见的参数就是r,表示只读方式打开文件,该文件必须存在。 (8) 函数原型:int fclose(FILE *stream); 说明:关闭一个流。 注意:使用fclose()函数就可以把缓冲区内最后剩余的数据输出到磁盘文件中,并释放文件指针和有关的缓冲区。
#include
void main(){
FILE *fp;
int i,a[2];
fp=fopen(C:\text.txt,r);
for(i=0;i<2;i++){
fscanf(fp,%d,&a[i]);
}
for(i=0;i<2;i++){
printf(%d,a[i]);
}
fclose(fp);
return ;
}
如上的例子演示了如何从文件中读入参数为数组赋值的例子。这样就可以将大量的测试参数写到文本中,以方便读取。
上面是一个一维数组赋值的例子,下面来看一个二维的:
FILE *fp;
fp=fopen(C:\text.txt,r);
int i,j;
for(i=1; i<=4; i++){
for(j=1; j<=4; j++){
fscanf(fp,%d,&b[i][j]);
printf(%d
,b[i][j]);
}
}
printf(%d ,b[1][2]);
fclose(fp);
return 0;
(9)
函数原型:extern int strcmp(const char *s1,const char * s2);
功能:比较两个字符串的大小
说明:
当s1
当s1=s2时,返回值=0
当s1>s2时,返回值>0
即:两个字符串自左向右逐个字符相比(按ASCII值大小相比较),直到出现不同的字符或遇''为止。如:
AA computer>compare
注意:strcmp(const char *s1,const char * s2)这里面只能比较字符串,不能比较数字等其他形式的参数。