一、memset
#include<stdio.h> #include<stdlib.h> #include<memory.h>void *mymemset(void *p, int num, int len) {char *px = (char *)p;if (p == NULL)return NULL;while (len>0){*px = (char)num;px++;len--;}return p;//因為上述代碼是對px進行操作,p的地址沒有變化,所以最后返回p }void main() {char str[40]= {"china is great"};int num[5] = { 1,2,3,4,5 };float f[5] = { 1.0,2.0,3.0,4.0,5.0 };//memset(str, '\0', 40);mymemset(str, '\0', 40);printf("%s\n",str);mymemset(num,0,20);mymemset(f,0,20);for (int i = 0; i < 5; i++)printf("%d,%f\n",num[i],f[i]);system("pause"); }
二、Unicode及寬字符
#include<stdio.h> #include<stdlib.h> #include<locale.h>//設置本地化void main0() {//字符串可以顯示漢字,字符不可以,字符連在一起%c%c可以輸出一個漢字char str[10] = "你好中國";char ch = '我';//char只能是字母,數字,字符printf("%s\n", str);printf("%c%c\n",ch);//ch無法正常輸出‘我’,ASCII表里面沒有‘我’printf("%c%c\n",str[0],str[1]);//輸出一個漢字,一個漢字占兩個字節system("pause"); }void main() {wchar_t ch = L'我';//L寬字符或者寬字符串printf("%d\n",sizeof(ch));//2個字節setlocale(LC_ALL,"chs");//簡體中文wprintf(L"%wc\n", ch);//漢字當做一個字符 wchar_t str[100] = L"我是一個好人ABC";wprintf(L"%s\n", str);system("pause"); }
#include<stdio.h> #include<stdlib.h> #include<Windows.h>void main() {//MessageBox(0, "滴,不準用快播飆車!", "360安全衛士", 0);//使用多字節字符集時正常運行//MessageBox(0,L"滴,不準用快播飆車!",L"360安全衛士", 0);//使用Unicode字符集時,需要加‘L’MessageBoxA(0, "滴,不準用快播飆車!", "MessageBoxA", 0);//無論是多字節還是Unicode,始終以多字節運行MessageBoxW(0, L"滴,不準用快播飆車!", L"MessageBoxW", 0);//無論是多字節還是Unicode,始終以Unicode運行MessageBox(0,TEXT("滴,不準用快播飆車!"),TEXT("TEXT"), 0);//自動適應多字節或者Unicode }
三、strset
#define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> #include<string>void mystrset(char *p, char ch) {while (*p){*p = ch;p++;} }void main() {char str[20] = "yincheng8848";printf("before:%s\n", str);//_strset(str, '8');//_strset標準C語言mystrset(str, '9');//_strset標準C語言//_strset(str, '\0');//清空字符串printf("after:%s\n", str);system("pause"); }
?