linux常用c函數 記憶體及字串操作篇

來源:互聯網
上載者:User

bcmp(比較記憶體內容)

  相關函數  bcmp,strcasecmp,strcmp,strcoll,strncmp,strncasecmp

  表標頭檔  #include<string.h>

  定義函數  int bcmp ( const void *s1,const void * s2,int n);

  函數說明  bcmp()用來比較s1和s2所指的記憶體區間前n個位元組,若參數n為0,則返回0。

  傳回值  若參數s1 和s2 所指的記憶體內容都完全相同則返回0 值,否則返回非零值。

  附加說明  建議使用memcmp()取代。

  範例  參考memcmp()。

  bcopy(拷貝記憶體內容)

  相關函數  memccpy,memcpy,memmove,strcpy,ctrncpy

  表標頭檔  #include <string.h>

  定義函數  void bcopy ( const void *src,void *dest ,int n);

  函數說明  bcopy()與memcpy()一樣都是用來拷貝src所指的記憶體內容前n個位元組到dest所指的地址,不過參數src與dest在傳給函數時是相反的位置。

  傳回值

  附加說明  建議使用memcpy()取代

  範例  #include<string.h>

  main()

  {

  char dest[30]=”string(a)”;

  char src[30]=”string\0string”;

  int i;

  bcopy(src,dest,30);/* src指標放在前*/

  printf(bcopy(): “)

  for(i=0;i<30;i++)

  printf(“%c”,dest[i]);

  memcpy(dest src,30); /*dest指標放在錢*/

  printf(‘\nmemcpy() : “);

  for(i=0;i<30;i++)

  printf(“%c”,dest[i]);

  執行  bcopy() : string string

  memcpy() :string sring

  bzero(將一段記憶體內容全清為零)

  相關函數  memset,swab

  表標頭檔  #include<string.h>

  定義函數  void bzero(void *s,int n);

  函數說明  bzero()會將參數s所指的記憶體地區前n個位元組,全部設為零值。相當於調用memset((void*)s,0,size_tn);

  傳回值

  附加說明  建議使用memset取代

  範例  參考memset()。

  index(尋找字串中第一個出現的指定字元)

  相關函數  rindex,srechr,strrchr

  表標頭檔  #include<string.h>

  定義函數  char * index( const char *s, int c);

  函數說明  index()用來找出參數s字串中第一個出現的參數c地址,然後將該字元出現的地址返回。字串結束字元(NULL)也視為字串一部分。

  傳回值  如果找到指定的字元則返回該字元所在地址,否則返回0。

  範例  #include<string.h>

  main()

  {

  char *s =”0123456789012345678901234567890”;

  char *p;

  p =index(s,’5’);

  printf(%s\n”,p);

  }

  執行  5.68E+25

  memccpy(拷貝記憶體內容)

  相關函數  bcopy,memcpy,memmove,strcpy,strncpy

  表標頭檔  #include<string.h>

  定義函數  void * memccpy(void *dest, const void * src, int c,size_t n);

  函數說明  memccpy()用來拷貝src所指的記憶體內容前n個位元組到dest所指的地址上。與memcpy()不同的是,memccpy()會在複製時檢查參數c是否出現,若是則返回dest中值為c的下一個位元組地址。

  傳回值  返回指向dest中值為c的下一個位元組指標。傳回值為0表示在src所指記憶體前n個位元組中沒有值為c的位元組。

  範例  #include<string.h>

  main()

  {

  char a[]="string[a]";

  char b[]="string(b)";

  memccpy(a,b,'B',sizeof(b));

  printf("memccpy():%s\n",a);

  }

  執行  memccpy():string(b)

  memchr(在某一記憶體範圍中尋找一特定字元)

  相關函數  index,rindex,strchr,strpbrk,strrchr,strsep,strspn,strstr

  表標頭檔  #include<string.h>

  定義函數  void * memchr(const void *s,int c,size_t n);

  函數說明  memchr()從頭開始搜尋s所指的記憶體內容前n個位元組,直到發現第一個值為c的位元組,則返回指向該位元組的指標。

  傳回值  如果找到指定的位元組則返回該位元組的指標,否則返回0。

  範例  #include <string.h>

  main()

  {

  char *s="0123456789012345678901234567890";

  char *p;

  p=memchr(s,'5',10);

  printf("%s\n",p);

  }

  執行  5.68E+25

memcmp(比較記憶體內容)

  相關函數  bcmp,strcasecmp,strcmp,strcoll,strncmp,strncasecmp

  表標頭檔  #include<string.h>

  定義函數  int memcmp (const void *s1,const void *s2,size_t n);

  函數說明  memcmp()用來比較s1和s2所指的記憶體區間前n個字元。字串大小的比較是以ASCII碼錶上的順序來決定,次順序亦為字元的值。memcmp()首先將s1第一個字元值減去s2第一個字元的值,若差為0則再繼續比較下個字元,若差值不為0則將差值返回。例如,字串"Ac"和"ba"比較則會返回字元'A'(65)和'b'(98)的差值(-33)。

  傳回值  若參數s1和s2所指的記憶體內容都完全相同則返回0值。s1若大於s2則返回大於0的值。s1若小於s2則返回小於0的值。

  範例  #include<string.h>

  main()

  {

  char *a ="aBcDeF";

  char *b="AbCdEf";

  char *c="aacdef";

  char *d="aBcDeF";

  printf("memcmp(a,b):%d\n",memcmp((void*)a,(void*) b,6));

  printf("memcmp(a,c):%d\n",memcmp((void*)a,(void*) c,6));

  printf("memcmp(a,d):%d\n",memcmp((void*)a,(void*) d,6));

  執行  memcmp(a,b):1 /*字串a>字串b,返回1*/

  memcmp(a,c):-1 /* 字串a<字串c,返回-1*/

  memcmp(a,d):0 /*字串a=字串d,返回0*/

  memcpy(拷貝記憶體內容)

  相關函數  bcopy,memccpy,memcpy,memmove,strcpy,strncpy

  表標頭檔  #include<string.h>

  定義函數  void * memcpy (void * dest ,const void *src, size_t n);

  函數說明  memcpy()用來拷貝src所指的記憶體內容前n個位元組到dest所指的記憶體位址上。與strcpy()不同的是,memcpy()會完整的複製n個位元組,不會因為遇到字串結束'\0'而結束。

  傳回值  返回指向dest的指標。

  附加說明  指標src和dest所指的記憶體地區不可重疊。

  範例  #include<string.h>

  main()

  {

  char a[30]="string (a)";

  char b[30]="string\0string";

  int i;

  strcpy(a,b);

  printf("strcpy():");

  for(i=0;i<30;i++)

  printf("%c",a[i]);

  memcpy(a,b,30);

  printf("\nmemcpy() :");

  for(i=0;i<30;i++)

  printf("%c",a[i]);

  }

  執行  strcpy() : string a )

  memcpy() : string string

  memmove(拷貝記憶體內容)

  相關函數  bcopy,memccpy,memcpy,strcpy,strncpy

  表標頭檔  #include<string.h>

  定義函數  void * memmove(void *dest,const void *src,size_t n);

  函數說明  memmove()與memcpy()一樣都是用來拷貝src所指的記憶體內容前n個位元組到dest所指的地址上。不同的是,當src和dest所指的記憶體地區重疊時,memmove()仍然可以正確的處理,不過執行效率上會比使用memcpy()略慢些。

  傳回值  返回指向dest的指標。

  附加說明  指標src和dest所指的記憶體地區可以重疊。

  範例  參考memcpy()。

  memset(將一段記憶體空間填入某值)

  相關函數  bzero,swab

  表標頭檔  #include<string.h>

  定義函數  void * memset (void *s ,int c, size_t n);

  函數說明  memset()會將參數s所指的記憶體地區前n個位元組以參數c填入,然後返回指向s的指標。在編寫程式時,若需要將某一數組作初始化,memset()會相當方便。

  傳回值  返回指向s的指標。

  附加說明  參數c雖聲明為int, 但必須是unsigned char ,所以範圍在0到255之間。

  範例  #include <string.h>

  main()

  {

  char s[30];

  memset (s,'A',sizeof(s));

  s[30]='\0';

  printf("%s\n",s);

  }

  執行  AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA

  rindex(尋找字串中最後一個出現的指定字元)

  相關函數  index,memchr,strchr,strrchr

  表標頭檔  #include<string.h>

  定義函數  char * rindex( const char *s,int c);

  函數說明  rindex()用來找出參數s字串中最後一個出現的參數c地址,然後將該字元出現的地址返回。字串結束字元(NULL)也視為字串一部分。

  傳回值  如果找到指定的字元則返回該字元所在的地址,否則返回0。

  範例  #include <string.h>

  mian()

  {

  char *s ="0123456789012345678901234567890";

  char *p;

  p=rindex(s,'5');

  printf("%s\n",p);

  }

  執行  567890

strcasecmp(忽略大小寫比較字串)

  相關函數  bcmp,memcmp,strcmp,strcoll,strncmp

  表標頭檔  #include<string.h>

  定義函數  int strcasecmp (const char *s1, const char *s2);

  函數說明  strcasecmp()用來比較參數s1和s2字串,比較時會自動忽略大小寫差異。

  傳回值  若參數s1和s2字串相同則返回0。s1長度大於s2長度則返回大於0 的值,s1 長度若小於s2 長度則返回小於0的值。

  範例  #include <string.h>

  main()

  {

  char *a="aBcDeF";

  char *b="AbCdEf";

  if(!strcasecmp(a,b))

  printf("%s=%s\n",a,b);

  }

  執行  aBcDeF=AbCdEf

  strcat(串連兩字串)

  相關函數  bcopy,memccpy,memcpy,strcpy,strncpy

  表標頭檔  #include <string.h>

  定義函數  char *strcat (char *dest,const char *src);

  函數說明  strcat()會將參數src字串拷貝到參數dest所指的字串尾。第一個參數dest要有足夠的空間來容納要拷貝的字串。

  傳回值  返回參數dest的字串起始地址

  範例  #include <string.h.>

  main()

  {

  char a[30]="string(1)";

  char b[]="string(2)";

  printf("before strcat() : %s\n",a);

  printf("after strcat() : %s\n",strcat(a,b));

  }

  執行  before strcat () : string(1)

  after strcat () : string(1)string(2)

  strchr(尋找字串中第一個出現的指定字元)

  相關函數  index,memchr,rinex,strbrk,strsep,strspn,strstr,strtok

  表標頭檔  #include<string.h>

  定義函數  char * strchr (const char *s,int c);

  函數說明  strchr()用來找出參數s字串中第一個出現的參數c地址,然後將該字元出現的地址返回。

  傳回值  如果找到指定的字元則返回該字元所在地址,否則返回0。

  範例  #include<string.h>

  main()

  {

  char *s=0123456789012345678901234567890”;

  char *p;

  p=strchr(s,'5');

  printf("%s\n",p);

  }

  執行  5.68E+25

  strcmp(比較字串)

  相關函數  bcmp,memcmp,strcasecmp,strncasecmp,strcoll

  表標頭檔  #include<string.h>

  定義函數  int strcmp(const char *s1,const char *s2);

  函數說明  strcmp()用來比較參數s1和s2字串。字串大小的比較是以ASCII 碼錶上的順序來決定,此順序亦為字元的值。strcmp()首先將s1第一個字元值減去s2第一個字元值,若差值為0則再繼續比較下個字元,若差值不為0則將差值返回。例如字串"Ac"和"ba"比較則會返回字元"A"(65)和'b'(98)的差值(-33)。

  傳回值  若參數s1和s2字串相同則返回0。s1若大於s2則返回大於0的值。s1若小於s2則返回小於0 的值。

  範例  #include<string.h>

  main()

  {

  char *a="aBcDeF";

  char *b="AbCdEf";

  char *c="aacdef";

  char *d="aBcDeF";

  printf("strcmp(a,b) : %d\n",strcmp(a,b));

  printf("strcmp(a,c) : %d\n",strcmp(a,c));

  printf("strcmp(a,d) : %d\n",strcmp(a,d));

  }

  執行  strcmp(a,b) : 32

  strcmp(a,c) :-31

  strcmp(a,d) : 0

  strcoll(採用目前地區的字元排列次序來比較字串)

  相關函數  strcmp,bcmp,memcmp,strcasecmp,strncasecmp

  表標頭檔  #include<string.h>

  定義函數  int strcoll( const char *s1, const char *s2);

  函數說明  strcoll()會依環境變數LC_COLLATE所指定的文字流向次序來比較s1和s2 字串。

  傳回值  若參數s1和s2字串相同則返回0。s1若大於s2則返回大於0的值。s1若小於s2則返回小於0 的值。

  附加說明  若LC_COLLATE為"POSIX"或"C",則strcoll()與strcmp()作用完全相同。

  範例  參考strcmp()。

  strcpy(拷貝字串)

  相關函數  bcopy,memcpy,memccpy,memmove

  表標頭檔  #include<string.h>

  定義函數  char *strcpy(char *dest,const char *src);

  函數說明  strcpy()會將參數src字串拷貝至參數dest所指的地址。

  傳回值  返回參數dest的字串起始地址。

  附加說明  如果參數dest所指的記憶體空間不夠大,可能會造成緩衝溢出(buffer Overflow)的錯誤情況,在編寫程式時請特別留意,或者用strncpy()來取代。

  範例  #include<string.h>

  main()

  {

  char a[30]="string(1)";

  char b[]="string(2)";

  printf("before strcpy() :%s\n",a);

  printf("after strcpy() :%s\n",strcpy(a,b));

  }

  執行  before strcpy() :string(1)

  after strcpy() :string(2)

strcspn(返回字串中連續不含指定字串內容的字元數)

  相關函數  strspn

  表標頭檔  #inclued<string.h>

  定義函數  size_t strcspn ( const char *s,const char * reject);

  函數說明  strcspn()從參數s字串的開頭計算連續的字元,而這些字元都完全不在參數reject 所指的字串中。簡單地說,若strcspn()返回的數值為n,則代表字串s開頭連續有n個字元都不含字串reject內的字元。

  傳回值  返回字串s開頭連續不含字串reject內的字元數目。

  範例  #include <string.h>

  main()

  {

  char *str="Linux was first developed for 386/486-based pcs.";

  printf("%d\n",strcspn(str," "));

  printf("%d\n",strcspn(str,"/-"));

  printf("%d\n",strcspn(str,"1234567890"));

  }

  執行  5 /*只計算到“ ”的出現,所以返回“Linux”的長度*/

  33 /*計算到出現“/”或“-”,所以返回到“6”的長度*/

  30 /* 計算到出現數字字元為止,所以返回“3”出現前的長度*/

  strdup(複製字串)

  相關函數  calloc,malloc,realloc,free

  表標頭檔  #include<string.h>

  定義函數  char * strdup( const char *s);

  函數說明  strdup()會先用maolloc()配置與參數s字串相同的空間大小,然後將參數s字串的內容複寫到該記憶體位址,然後把該地址返回。該地址最後可以利用free()來釋放。

  傳回值  返回一字串指標,該指標指向複製後的新字串地址。若返回NULL表示記憶體不足。

  範例  #include<string.h>

  main()

  {

  char a[]="strdup";

  char *b;

  b=strdup(a);

  printf("b[ ]=\"%s\"\n",b);

  }

  執行  b[ ]="strdup"

  strlen(返回字串長度)

  相關函數

  表標頭檔  #include<string.h>

  定義函數  size_t strlen (const char *s);

  函數說明  strlen()用來計算指定的字串s的長度,不包括結束字元"\0"。

  傳回值  返回字串s的字元數。

  範例  /*取得字串str的長度*/

  #include<string.h>

  main()

  {

  char *str = "12345678";

  printf("str length = %d\n", strlen(str));

  }

  執行  str length = 8

  strncasecmp(忽略大小寫比較字串)

  相關函數  bcmp,memcmp,strcmp,strcoll,strncmp

  表標頭檔  #include<string.h>

  定義函數  int strncasecmp(const char *s1,const char *s2,size_t n);

  函數說明  strncasecmp()用來比較參數s1和s2字串前n個字元,比較時會自動忽略大小寫差異。

  傳回值  若參數s1和s2 字串相同則返回0。s1 若大於s2則返回大於0的值,s1若小於s2則返回小於0 的值。

  範例  #include<string.h>

  main()

  {

  char *a="aBcDeF";

  char *b="AbCdEf";

  if(!strncasecmp(a,b))

  printf("%s =%s\n",a,b);

  }

  執行  aBcDef=AbCdEf

  strncat(串連兩字串)

  相關函數  bcopy,memccpy,memecpy,strcpy,strncpy

  表標頭檔  #inclue <string.h>

  定義函數  char * strncat(char *dest,const char *src,size_t n);

  函數說明  strncat()會將參數src字串拷貝n個字元到參數dest所指的字串尾。第一個參數dest要有足夠的空間來容納要拷貝的字串。

  傳回值  返回參數dest的字串起始地址。

  範例  #include <string.h>

  main()

  {

  char a[30]="string(1)";

  char b[]="string(2)";

  printf("before strnact() :%s\n", a);

  printf("after strncat() :%s\n", strncat(a,b,6));

  }

  執行  before strnact() : string(1)

  after strncat() : string(1) string

  strncpy(拷貝字串)

  相關函數  bcopy,memccpy,memcpy,memmove

  表標頭檔  #include<string.h>

  定義函數  char * strncpy(char *dest,const char *src,size_t n);

  函數說明  strncpy()會將參數src字串拷貝前n個字元至參數dest所指的地址。

  傳回值  返回參數dest的字串起始地址。

  範例  #inclue <string.h>

  main()

  {

  char a[30]="string(1)";

  char b[]="string(2)";

  printf("before strncpy() : %s\n",a);

  printf("after strncpy() : %s\n",strncpy(a,b,6));

  }

  執行  before strncpy() : string(1)

  after strncpy() : string(1)

strpbrk(尋找字串中第一個出現的指定字元)

  相關函數  index,memchr,rindex,strpbrk,strsep,strspn,strstr,strtok

  表標頭檔  #include <include.h>

  定義函數  char *strpbrk(const char *s,const char *accept);

  函數說明  strpbrk()用來找出參數s 字串中最先出現存在參數accept 字串中的任一字元。

  傳回值  如果找到指定的字元則返回該字元所在地址,否則返回0。

  範例  #include <string.h>

  main()

  {

  char *s="0123456789012345678901234567890";

  char *p;

  p=strpbrk(s,"a1 839"); /*1會最先在s字串中找到*/

  printf("%s\n",p);

  p=strprk(s,"4398");/*3 會最先在s 字串中找到*/

  printf("%s\n",p);

  執行  1.23E+29

  strrchr(尋找字串中最後出現的指定字元)

  相關函數  index,memchr,rindex,strpbrk,strsep,strspn,strstr,strtok

  表標頭檔  #include<string.h>

  定義函數  char * strrchr(const char *s, int c);

  函數說明  strrchr()用來找出參數s字串中最後一個出現的參數c地址,然後將該字元出現的地址返回。

  傳回值  如果找到指定的字元則返回該字元所在地址,否則返回0。

  範例  #include<string.h>

  main()

  {

  char *s="0123456789012345678901234567890";

  char *p;

  p=strrchr(s,'5');

  printf("%s\n",p);

  }

  執行  567890

  strspn(返回字串中連續不含指定字串內容的字元數)

  相關函數  strcspn,strchr,strpbrk,strsep,strstr

  表標頭檔  #include<string.h>

  定義函數  size_t strspn (const char *s,const char * accept);

  函數說明  strspn()從參數s 字串的開頭計算連續的字元,而這些字元都完全是accept 所指字串中的字元。簡單的說,若strspn()返回的數值為n,則代表字串s 開頭連續有n 個字元都是屬於字串accept內的字元。

  傳回值  返回字串s開頭連續包含字串accept內的字元數目。

  範例  #include<string.h>

  main()

  {

  char *str="Linux was first developed for 386/486-based PCs.";

  char *t1="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";

  printf("%d\n",strspn(str,t1));

  }

  執行  5 /*計算大小寫字母。不包含“ ”,所以返回Linux的長度。*/

  strstr(在一字串中尋找指定的字串)

  相關函數  index,memchr,rindex,strchr,strpbrk,strsep,strspn,strtok

  表標頭檔  #include<string.h>

  定義函數  char *strstr(const char *haystack,const char *needle);

  函數說明  strstr()會從字串haystack 中搜尋字串needle,並將第一次出現的地址返回。

  傳回值  返回指定字串第一次出現的地址,否則返回0。

  範例  #include<string.h>

  main()

  {

  char * s="012345678901234567890123456789";

  char *p;

  p= strstr(s,"901");

  printf("%s\n",p);

  }

  執行  9.01E+21

  strtok(分割字串)

  相關函數  index,memchr,rindex,strpbrk,strsep,strspn,strstr

  表標頭檔  #include<string.h>

  定義函數  char * strtok(char *s,const char *delim);

  函數說明  strtok()用來將字串分割成一個個片段。參數s指向欲分割的字串,參數delim則為分割字串,當strtok()在參數s的字串中發現到參數delim的分割字元時則會將該字元改為\0 字元。在第一次調用時,strtok()必需給予參數s字串,往後的調用則將參數s設定成NULL。每次調用成功則返回下一個分割後的字串指標。

  傳回值  返回下一個分割後的字串指標,如果已無從分割則返回NULL。

  範例  #include<string.h>

  main()

  {

  char s[]="ab-cd : ef;gh :i-jkl;mnop;qrs-tu: vwx-y;z";

  char *delim="-: ";

  char *p;

  printf("%s ";strtok(s,delim));

  while((p=strtok(NULL,delim)))printf("%s ",p);

  printf("\n");

  }

  執行  ab cd ef;gh i jkl;mnop;qrs tu vwx y;z /*-與:字元已經被\0 字元取代*/

PS:makefile中初學碰到CFLAGS-----MARK下

setenv(set environment variable)

功能說明:查詢或顯示環境變數。

語  法:setenv [變數名稱][變數值]

補充說明:setenv為tsch中查詢或設定環境變數的指令。

setenv(改變或增加環境變數),相關函數 getenv,putenv,unsetenv

表標頭檔#include<stdlib.h>   

定義函數 int setenv(const char *name,const char * value,int overwrite);   

函數說明 setenv()用來改變或增加環境變數的內容。參數name為環境變數名稱字串。參數 value則為變數內容,參數overwrite用來決定是否要改變已存在的環境變數。如果overwrite不為0,而該環境變數原已有內容,則原內容會被改為參數value所指的變數內容。如果overwrite為0,且該環境變數已有內容,則參數value會被忽略。傳回值 執行成功則返回0,有錯誤發生時返回-1。   

錯誤碼 ENOMEM 記憶體不足,無法配置新的環境變數空間 

_____________________________________________________

PS:很久沒看LINUX 了 :自我反省後  繼續2011.5.12

exec函數族的作用是根據指定的檔案名稱找到可執行檔,並用它來取代調用進程的內容,換句話說,就是在調用進程內部執行一個可執行檔。這裡的可執行檔既可以是二進位檔案,也可以是任何Linux下可執行檔指令檔

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.