打印vdbench數據,分析數據一致性問題

 

將字符串轉爲16進制ascii碼並輸入到另一個字符串中

 

#include<stdio.h>
#include<stdlib.h>
#include<memory.h>

char src[256] = "/home/inspur";

void main(int argc, char *argv[])
{
 snprintf(src ,sizeof(src), "%s", argv[1]);
 printf("The file :%s ", src);
 int fd1 = open(src , "rw");
 //加上異常判斷
 char buffer[65536] = {0};
//memset(buffer ,0 ,sizeof(buffer));
 char b[65536*5] = {0};
 //lseek(fd1,40960 ,SEEK_SET);
 read(fd1,buffer,65536);
 
 char *p = buffer;
 
 int j,t=0;
 for(;t<64;t++)
{ 
 j+=sprintf(b+j,"%x",buffer[t]);
}
 printf("%s\n",b);

} 
#include<stdio.h>
#include<stdlib.h>
#include<memory.h>

char src[256] = "/home/inspur";

void main(int argc, char *argv[])
{
 snprintf(src ,sizeof(src), "%s", argv[1]);
 printf("The file :%s ", src);
 FILE *fd1 =fopen(src ,"rw");//a+
 //加上異常判斷
 char buffer[65536] = {0};
//memset(buffer ,0 ,sizeof(buffer));
 char buffer2[65536] = {0};
 
fgets(buffer2 ,64,fd1);
 
 char *p = (char  *)malloc(sizeof(char)*65536);
 char *point = p;
 int j,t=0;
 for(;t<64;t++)
{ 
 printf(ponit,"%04x",buffer2[t]);
 for(;*point;)
   point++;
}
 printf("%s\n",p);

} 

 

 

 

#include<stdio.h>
void main()
{
 char a[9]="a1234",b[20], *p=a;
 int j=0;
 while(*p!=0){ j+=sprintf(b+j,"%x",*p++);}
 printf("%s\n",b);

} 

 

 

 

memset

 

功 能: 將s所指向的某一塊內存中的每個字節的內容全部設置爲ch指定的ASCII值,塊的大小由第三個參數指定,這個函數通常爲新申請的內存做初始化工作。

void *memset(void *schar ch, unsigned n);

總的作用:將已開闢內存空間 s 的首 n 個字節的值設爲值 ch。

main(){
  char *s="Golden Global View";
  clrscr();
  memset(s,'G',6);//貌似這裏有點問題//
  printf("%s",s);
  getchar();
  return 0;
  } 
  

【這個問題相當大,程序根本就運行不下去了,你這裏的S志向的是一段只讀的內存,而你memset又試圖修改它,所以運行時要出錯,修改辦法char *s修改爲char s[]】

 

1
2
3
4
5
6
7
8
9
10
11
int main()
{
    char *s="GoldenGlobalView";
    clrscr();
    memset(s,'G',6);//這裏沒有問題,可以編譯運行,在這裏將右括號和分號變成了中文輸入法
                    //單步運行到這裏會提示內存訪問衝突
                   //肯定會訪問衝突,s指向的是不可寫空間。
    printf("%s",s);
    getchar();
    return 0;
}
【以上例子出現內存訪問衝突應該是因爲s被當做常量放入程序存儲空間,如果修改爲 char s[]="Golden Global View";則沒有問題了。】
【應該是沒有問題的,字符串指針一樣可以,並不是只讀內存,可以正常運行】
【此實例可以正常編譯運行,並不需要char s[]】
【memset(s,'G',6)這樣是存在內存訪問衝突的,因爲s爲常量字符串,不能修改的】
【的確需要改爲char s[],否則s不能修改】

 

4。memset()的深刻內涵:用來對一段內存空間全部設置爲某個字符,一般用在對定義的字符串進行初始化爲‘memset(a, '/0', sizeof(a));

 

  memcpy用來做內存拷貝,你可以拿它拷貝任何數據類型的對象,可以指定拷貝的數據長度;例:char a[100],b[50]; memcpy(b, a, sizeof(b));注意如用sizeof(a),會造成b的內存地址溢出。

  strcpy就只能拷貝字符串了,它遇到'/0'就結束拷貝;例:char a[100],b[50];strcpy(a,b);如用strcpy(b,a),要注意a中的字符串長度(第一個‘/0’之前)是否超過50位,如超過,則會造成b的內存地址溢出。

  5.補充:某人的一點心得

  memset可以方便的清空一個結構類型的變量或數組。

  如:

  struct sample_struct

  {

  char csName[16];

  int iSeq;

  int iType;

  };

  對於變量

  struct sample_strcut stTest;

  一般情況下,清空stTest的方法:

  stTest.csName[0]='/0';

  stTest.iSeq=0;

  stTest.iType=0;

  用memset就非常方便:

  memset(&stTest,0,sizeof(struct sample_struct));

  如果是數組:

  struct sample_struct TEST[10];

  則

  memset(TEST,0,sizeof(struct sample_struct)*10);

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章