打印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);

 

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