c语言,为什么用fread 读入文件 链表 每次都会多一个节点?

做文件输入输出的时候,用的是结构体链表,放入的链表只有两个一个是头,
另一个是有内容的(头无内容)。但是每次读出的时候总会多出一个节点,
结构体 和 读入 读出 代码如下

typedef struct vip                                                      //定义VIP用户的结构体
{   
    char card[19];
    char name[11];
    char tel[14];
    int time;
    char date[13];
    char key[11];
    struct vip *next;
}vip;

typedef struct cus                                                      //定义登陆用户的结构体(包括临时和VIP)
{   
    char card[19];
    int lie;                                                            //位置;
    char date[13];                                                      //上机日期
    time_t upt;                                                         //上机时间
    time_t downt;                                                       //下机时间
    int in;                                                             //押金
    int realin;                                                         //实际收入
    int flag;                                                           //1 激活状态 0 未激活(下机)状态
    int identify;                                                       //1 VIP 用户 2 临时用户
    char tel[14];
    struct cus *next;
}cus;

void load(vip *head1,cus *head2,int longth)                                             //装载VIP 和 临时登陆 的 记录
{
    FILE *fp1,*fp2;
    vip *p1,*tail1 = head1;
    cus *p2,*tail2 = head2;

    fp1 = fopen("vip.bin","rb")

    if((fp2 = fopen("day.bin","rb")) == NULL)
    {
        return ;
    }

    while(!feof(fp1))
    {   
        p1 = (vip *)malloc(sizeof(vip)*1);
        fread(p1,sizeof(vip),1,fp1);
        tail1 ->next = p1;
        tail1 = p1;
        tail1 ->next = NULL;
    //  longth ++;
        printf("1");
    }

    while(!feof(fp2))
    {   
        p2 = (cus *)malloc(sizeof(cus)*1);
        fread(p2,sizeof(cus),1,fp2);
        tail2 ->next = p2;
        tail2 = p2;
        tail2 ->next = NULL;
    }
    close(fp1);
    close(fp2);
}
void a(vip *head1,cus *head2)                                           //信息保存
{
    FILE *fp1,*fp2;
    vip *p1 = head1 ->next;
    cus *p2 = head2 ->next;

    fp1 = fopen("vip.bin","wb");

    fp2 = fopen("day.bin","wb");

    while(p1 != NULL)
    {   

        fwrite(p1,sizeof(vip),1,fp1);
        p1 = p1 ->next;
    }
    while(p2 != NULL)
    {   
        fwrite(p2,sizeof(cus),1,fp2);
        p2 = p2 ->next;
    }
    close(fp1);
    close(fp2);
}

当我运行程序时,(保存的时候 只有两个 节点,并且尾next为空),保存两个节点,第二次读取的时候却有三个节点,不知道问题出在了哪里。求大神帮忙看看!!!!!

1个回答

应该是while(!feof(fp))这个使用的问题!
feof判断文件结束是通过读取函数fread/fscanf等返回错误来识别的,故而判断文件是否结束应该是在读取函数之后进行判断。
例如:
int c;
while(!feof(fp))
{
c = fgetc(fp);
printf("%X\n", c);
}
执行结果会发现多输出了一个FF,原因就是在读完最后一个字符后,feof()仍然没有探测到文件结尾,直到再次调用fgetc()执行读操作,feof()才能探测到文件结尾。这样就多输出了一个-1(即FF)。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
c语言怎么把一个双向链表写入文件
用c语言这一个双向链表,然后用fwrite写入文件,用fread读取,这个过程和单链表是一样的吗?
C语言链表文件题请看看这个有什么问题
``` #include<stdio.h> #include<string.h> #include<stdlib.h> struct stu{ int num; char name[20]; int score; };//定义一个学生信息结构体 struct st{ int num; char name[20]; int score; struct st *next; };//定义一个学生信息链表结点 struct st *top,*rear;//定义链表头尾指针 struct st* push (struct stu x) { struct st *p; p=(struct st*)malloc(sizeof(struct st)); p->num=x.num; strcpy(p->name,x.name); p->score=x.score; p->next=NULL; if(rear==NULL) { rear=top=p; } else{ rear->next=p; rear=p; } return p; }//将结构体元素依次放入链表尾 void sort (struct st *top) { int flag; struct st *q,*s; int temp1,temp3; char temp2[20]; for(q=top->next;q->next!=NULL;q=q->next) { flag=0; s=q->next; if(q->num<s->num) { flag=1; temp1=q->num; q->num=s->num;s->num=temp1; temp3=q->score;q->score=s->score;s->score=temp3; strcpy(temp2,q->name);strcpy(q->name,s->name);strcpy(s->name,temp2); } if(flag==0) break; } }//按照学号从大到小的顺序进行排序节点 int main() { FILE *in,*out; in=fopen("in.txt","r"); out=fopen("out.txt","w");//打开文件 int n,m; struct stu card; scanf("%d",&n); m=n; while(m!=0) { fread(&card,sizeof(struct stu),1,in); if(card.num>0) { m--; push(card); } }//若学号符合要求则连人链表 sort(top); struct st *k; for(k=top;k!=NULL;k=k->next) { fwrite(&card,sizeof(struct stu),1,out); }//写入out文件 fclose(in); fclose(out);//关闭文件 return 0; } ``` 为啥运行后没有反应呢 out文件中没有我想要的数据
C语言fread 读不完整,返回值比预计的少,但是文件大小是对的
我用fwrite写的一个文件,用fread读取,写完后文件大小是对的,但是fread只能读出一部分,(一共9k的int,只读出来100多个,fread的返回值也是100多) 以前用fread读几百k的数据都不会出错,请问大神们如何解决?
c语言为什么fread读取失败
#include <stdio.h> #include <string.h> #include <stdlib.h> #define STUDLEN sizeof(student) typedef struct _student { char name[10]; char sex[5]; float weight; float high; struct _student *next; }student; void Free(student *head); void input() { student *head=NULL,*p,*ptemp,*wpoint; char name[10],contin[5]; char sex[5]; float weight; float high; FILE *fp=fopen("student.data","ab+"); if(fp==NULL) { printf("打开文件失败\n"); exit(1); } do{ printf("输入学生姓名:"); scanf("%s",name); printf("输入性别:"); scanf("%s",sex); printf("输入体重:"); scanf("%f",&weight); printf("输入身高:"); scanf("%f",&high); p=(student *)malloc(STUDLEN); strcpy(p->name,name); strcpy(p->sex,sex); p->weight=weight; p->high=high; p->next=NULL; ptemp=head; if(head) { while(ptemp->next) ptemp=ptemp->next; ptemp->next=p; } else head=p; printf("继续录入信息?yes or no\n"); scanf("%s",contin); }while(stricmp(contin,"yes")==0); for(wpoint=head;wpoint;wpoint=wpoint->next) if(fwrite(wpoint,STUDLEN,1,fp)!=1) printf("write error\n"); Free(head); fclose(fp); } void Free(student *head) { for(;head;head=head->next) free(head); } void find() { FILE *fp=fopen("student.data","rb"); char name[10]; student *p; if(fp=NULL) printf("打开文件失败\n"); printf("请输入姓名\n"); scanf("%s",name); while(!feof(fp)) { if(fread(p,STUDLEN,1,fp)!=1) { printf("读取失败\n"); break; } else { if(strcmp(p->name,name)) { printf("姓名:%s\n性别:%s\n身高:%.2fcm\n体重:%.2fkg\n",p->name,p->sex,p->high,p->weight); break; } } } fclose(fp); } void main() { int menu; void input(); void find(); printf("请选择:\n"); do { printf("1.输入学生信息\n"); printf("2.查询学生信息\n"); printf("0.退出系统\n"); scanf("%d",&menu); switch(menu) { case 1:input();break; case 2:find();break; case 0:break; default:printf("error\n");break; } }while(menu!=0); }
怎么用fscanf把文件的数据读入链表?
我下面这段代码是哪里出错了? 写入文件没有问题 把文件里的东西写入链表 之后在输出链表 只输出第一行数据 之后都是0 #include "stdio.h" #include "stdlib.h" int n=0; struct stu { int num; char name[100]; float score; struct stu *next; }; void str(struct stu *h) { while(h!=NULL) { printf("%d %s %f\n",h->num,h->name,h->score); h=h->next; } } void w(struct stu *h) { FILE *file; char fname[100]; int i; struct stu *pthis,*head,*p1,*p2; printf("请输入要写入的文件名\n"); scanf("%s",fname); file=fopen(fname,"w"); if(file==NULL) { printf("打开文件错误\n");return; } printf("\n\n链表内容将被写入文件\n"); if(h==NULL) { printf("错误,没有数据!\n"); return; } pthis=h; while(pthis!=NULL) { fprintf(file,"%d %s %f",pthis->num,pthis->name,pthis->score); //fwrite(pthis,sizeof(struct stu),1,file); pthis=pthis->next; } fclose(file); file=fopen(fname,"r"); p1=p2=(struct stu *)malloc(sizeof(struct stu)); fscanf(file,"%d %s %f",&p1->num,p1->name,&p1->score); head=p1; //fread(p1,sizeof(struct stu),1,file); //printf("%d %s %f",p1->num,p1->name,p1->score); while(n>0) { p1=(struct stu *)malloc(sizeof(struct stu)); p2->next=p1; fscanf(file,"%d %s %f",&p1->num,p1->name,&p1->score); //p2->next=p1; p2=p1; n--; } str(head); fclose(file); } main() { struct stu *head,*p1,*p2; head=NULL; p1=p2=(struct stu *)malloc(sizeof(struct stu)); printf("依次输入学号、姓名、成绩\n"); scanf("%d%s%f",&p1->num,p1->name,&p1->score); head=p1; while(p1->num!=0) { n++; p1=(struct stu *)malloc(sizeof(struct stu)); printf("依次输入学号、姓名、成绩\n"); scanf("%d%s%f",&p1->num,p1->name,&p1->score); p2->next=p1; p2=p1; } str(head); fflush(stdin); w(head); }
C语言中的fread与fwrite问题
我自己自定义了一个结构体 typedef struct histgramData { CString picPath;//图片路径 CvHistogram value;//图片的直方图特征 }CHistogramData; 然后使用fwrite将其写入文件 FILE *fp; if((fp=fopen("histogram.dat","a+b"))==NULL)//以追加方式打开二进制文件 {return false;} CHistogramData hd; hd.value=value; hd.picPath=picPath; fwrite(&hd,sizeof(hd),1,fp); fclose(fp); 接着我用fread函数将其中的数据读出 FILE*fp; CHistogramData histData;//用于保存从文件中读出的模板 CHistogram hist;//直方图对象 fp=fopen("histogram.dat","rb"); int count=0; while(count<=9 && (fread(&histData,sizeof(histData),1,fp)!=0))//先一次性读取前十个模板数据 { double similarity=hist.cmpHistogram(histData.value,*value); CString temp; temp.Format("%s%lf",histData.picPath,similarity); MessageBox(temp); count++;//计数器加1 } 问题是这样的,当我第一次写入一个CHistogramData数据时,能够正常读出来,但当我再次去读时,就出问题了,我怀疑是不是第一次读使用fread对原文件有影响;第二个问题是如果我第一次一次性写入多个CHistogramData数据时,读出数据就会失败,请问这是怎么回事?
c语言中fread与select之比较
请问诸位达人,C语言中的select函数支持超时,那么用select来进行文件的I/O和fread/fwrite相比 速度上有什么区别吗?是否具备更多优势呢? p.s. 一些大的集群用的磁盘都是远程盘阵,都是通过交换机进行文件IO的。
C语言使用fread()函数的时候为什么不是从文档开头读取?
原函数: ![图片说明](https://img-ask.csdn.net/upload/201708/30/1504072304_729154.png) 文件内容: ![图片说明](https://img-ask.csdn.net/upload/201708/30/1504072421_460777.png) 运行结果: ![图片说明](https://img-ask.csdn.net/upload/201708/30/1504072551_117469.png) 函数原型: unsigned fread(void *buffer,unsigned size,unsigned count,FILE *fp); 根据我的理解是从fp指向的文件首部开始读起,再传入buffer所指向的待存入的数据块首址。 另外我试了一下,当文件中只包含一组数据的时候,还会出现乱码情况,如图: ![图片说明](https://img-ask.csdn.net/upload/201708/30/1504072991_198145.png) 新人一个,求各位大神解答
c语言关于fread问题?~~
将文件"125.txt"中15名同学的姓名、成绩读入到结构体数组中,输出平均成绩和最高成绩的同学(要求保留2位小数)。要求定义如下结构体类型: struct student { char name[20]; float mathScore; }; 数据文件:程序目录下 ![图片说明](https://img-ask.csdn.net/upload/201512/24/1450949955_194958.png) 期待输出 平均分:67.03↵ 最高分:luyu 80.66↵ 实际输出![图片说明](https://img-ask.csdn.net/upload/201512/24/1450950098_763726.png) ``` #include<stdio.h> struct student { char name[20]; float mathScore; }stu[15]; int main() {FILE *p;float a[20]={0},s=0,max;int index=0,i; p=fopen("125.txt","r"); fread(stu,sizeof(struct student),15,p); fclose(p); for(i=0;i<15;i++) {if(i==0)max=stu[i].mathScore; s+=stu[i].mathScore; if(stu[i].mathScore>max) max=stu[i].mathScore,index=i;} printf("平均分:%.2f\n最高分:%s %.2f\n",s/15,stu[index].name,stu[index].mathScore); return 0;} ``` 请问这个是fread使用错误吗?正确应该如何使用fread
c 用链表对文件读写错误
#include<stdio.h> #include<string.h> #include<stdlib.h> struct data { int year; int month; int day; }; struct cost{ int yuan; int jiao; int fen; }; struct treatment{ char pname[20]; char pid[19] ; int age; char dname[20]; int did; int office; float money; struct data day0; struct treatment *next; }; //病人名字 int addpname( char y0[]){ int k0=1; int i0; while(k0){ k0=0; printf("请输入病人名字(小写字母)\n"); scanf("%s",y0); for(i0=0;i0<strlen(y0);i0++){ if(y0[i0]<97||y0[i0]>122){ k0=1; printf("输入有误,请重新输入\n"); break; //注意break是否跳出for 对的 } } } return 0; } //病人id void addpid( char y1[20]){ int k1=1; int i1; while(k1){ k1=0; printf("请输入病人身份证号\n"); scanf("%s",y1); for(i1=0;i1<18;i1++){ if(y1[i1]<48||y1[i1]>57&&y1[18]!=120) { k1=1; printf("输入有误,请重新输入\n"); break; } } } } //医生名字 int adddname( char y2[20] ){ int k2=1; int i2; while(k2){ k2=0; printf("请输入医生名字(小写字母)\n"); scanf("%s",y2); for(i2=0;i2<strlen(y2);i2++){ if(y2[i2]<97||y2[i2]>122){ k2=1; printf("输入有误,请重新输入\n"); break; } } } return 0 ; } //医生工作号 int adddid(){ int i3; int k3=1; while(k3){ k3=0; int y3; fflush(stdin); printf("请输入医生工作号\n"); y3=scanf("%d",&i3); if(y3==EOF||0>i3||200<i3){ k3=1; printf("输入有误,请重新输入\n"); // break; //Break使用有误导致缓冲区里有错误数据且给了下一个输入 } } return i3; } //判断日期 int adddata( int ydata[3]){ //存储日期 int i4; //i4表示年 int k4=1; while(k4){ k4=0; printf("请输入年份\n"); scanf("%d",&i4); if(i4>2020||i4<2017){ k4=1; printf("输入有误!请重新输入\n"); } } int k5=1; int i5; //判断月 while(k5){ k5=0; printf("请输入月份(1-12)\n"); scanf("%d",&i5); if(i5>12||i5<1){ printf("输入有误!请重新输入\n"); k5=1; } } int y5; //月份天数上限 switch(i5){ case 1: case 3: case 5:case 7: case 8 : case 10: case 12 :y5=31;break; case 4: case 6: case 9:case 11:y5=30;break; case 2:if(i4%4==0&&i4%100!=0||i4%400==0) y5=29; else y5=28; break; } int k6=1; //判断日期 int i6; while(k6){ k6=0; printf("请输入日期(1-%d)\n",y5);//上限 scanf("%d",&i6); if(i6<1||i6>y5){ k6=1; printf("输入有误!请重新输入\n"); } } ydata[0]=i4; ydata[1]=i5; ydata[2]=i6; return 0; } /*科室处理*/ int addoffice(){ int y7; int k7=1; while(k7){ k7=0; printf("请选择科室\n"); printf("1-神精科 2-精神科\n"); printf("3-内 科 4-外 科\n"); printf("5-小儿科\n"); fflush(stdin); if(scanf("%d",&y7)==EOF||y7>5||y7<1){ printf("输入有误!请重新输入\n"); k7=1; } } return k7; } //钱的处 int addqian(){ //元 int k8=1; int i8; while(k8){ k8=0; fflush(stdin); if( scanf("%d",&i8)==EOF||i8<0||i8>10000000){ k8=1; printf("输入有误,请重新输入\n"); } } return i8; } int addqian2(){ //分 不能大于10 int k10=1; int i10; while(k10){ k10=0; fflush(stdin); if( scanf("%d",&i10)==EOF||i10<0||i10>10){ k10=1; printf("输入有误,请重新输入\n"); } } return i10; } //病人的年龄 int addage(){ int k9=1; int i9; int y9; while(k9){ k9=0; printf("请输入整数\n"); fflush(stdin); //清除缓冲区内容 y9=scanf("%d",&i9); //getchar();只能清除一个字符 if(y9==EOF){ //判断scanf录入的是不是字母 printf("输入有误!请重新输入\n"); k9=1; } if(i9<0||i9>300){ printf("输入有误!请重新输入\n"); k9=1; } } return i9; } //增加函数 int realadd(struct treatment *bus0){ struct cost s; addpname(bus0->pname); addpid(bus0->pid); printf("请输入病人的年龄") ; bus0->age=addage(); adddname(bus0->dname); bus0->did=adddid(); bus0->office=addoffice(); int yy[3]; //年月日 adddata(yy); bus0->day0.year=yy[0]; bus0->day0.month= yy[1]; bus0->day0.day=yy[2]; printf("请输入病人消费情况\n"); printf("请输入元\n"); s.yuan=addqian(); printf("请输入角\n"); s.jiao=addqian2(); printf("请输入分\n"); s.fen=addqian2(); bus0->money=(float)s.yuan+0.1*(float(s.jiao ))+0.01*(float(s.fen )); return 0; } //删除函数 int delete0(struct treatment * top){ ///用delete的话和编译器里的东西重名 char key[6]; addpid(key); //输入关键字 struct treatment *Sqian,*Shou; Shou=top; while(Shou!=NULL){ if(strcmp(key,Shou->pid)==0){ if(Shou==top){ //头 Sqian=Shou; Shou=Shou->next; free(Sqian); } else if(Shou->next==NULL){ //尾 Sqian=Shou; Shou=top; free(Sqian); } else { //中间 Shou=Shou->next; free(Sqian->next); Sqian->next=Shou; } }//第一个if else { //向后走 Sqian=Shou; Shou=Shou->next; } return 0; } } // 打印输出函数 void output0(struct treatment *bus1){ do{ printf("病人的名字%s\n",bus1->pname); printf("病人的身份证%s\n",bus1->pid); printf("病人的年龄%d\n",bus1->age); printf("医生的名字%s\n",bus1->dname); printf("医生的工作号%d\n",bus1->did); printf("科室d%\n",bus1->office); printf("开销总计%f\n",bus1->money); printf("日期:%d 年%d 月%d 日\n",bus1->day0.year,bus1->day0.month,bus1->day0.day ); bus1=bus1->next; }while(bus1!=NULL) ; } //加载文件到链表 -------------------------------------------------------------------------------------------------------------- int wenjian(struct treatment *top0 ,struct treatment *rear){ FILE *fp0; struct treatment *sp11; fp0=fopen("D://source.txt","a+"); if(fp0==NULL){ //判断文件打开是否成功; printf("打开文件错误"); return 0; } else{ if(!feof(fp0)) { //头上加载 fread(top0,sizeof(struct treatment),1,fp0); top0->next=NULL; sp11=top0; while(!feof(fp0)){ //后面加 sp11->next=(struct treatment *)malloc(sizeof(struct treatment )); fread(sp11->next,sizeof(treatment),1,fp0); sp11=sp11->next; sp11->next=NULL; } rear=sp11; } else printf( "文件为空"); fclose(fp0); printf("加载文件成功"); return 1; } } //将链表写入文件-------------------------------------------------------------------------- int addw(struct treatment *head){ //加入尾 FILE *fp1; struct treatment *sp22,*sbing; sp22=head; fp1=fopen("D://source.txt","a"); printf("DFJKL;") ; if(fp1==NULL){ //判断打开是否成功 printf("打开文件有误"); return 0; } else if(strlen(head->pname)!=0){ //加入一个判断来确定链表是否为空 do{ printf("kaishi"); //写入 fwrite(sp22,sizeof( struct treatment),1,fp1); sbing=sp22; sp22=sp22->next; }while(sbing!=NULL);//注意条件是否错误 } else printf("sssssssssssssssssssssssssssssssssssssssss"); fclose(fp1); return 1; } //增加信息到链表-------------------------------------------------------------------------------------- int addolian(struct treatment *head3,struct treatment *rear3){ printf("开始加载信息"); printf( " %d dsfsdgsag ",strlen(head3->pname)) ; if(strlen(head3->pname)==0){ //为什么等于3 realadd(head3); head3->next=NULL; } else{ rear3->next=(struct treatment *)malloc(sizeof(struct treatment)); rear3=rear3->next; realadd(rear3); rear3->next=NULL; } } int main(){ struct treatment *head0,*rear0,*sbing0,*bianli0; head0=(struct treatment *)malloc(sizeof(treatment)); rear0=head0; wenjian(head0,rear0); int i; while(1){ printf("选择相应功能前的数字\n") ; printf("1-增加病人信息 2-输出所有病人信息\n"); printf("3-添加到文件 4-删除某病人的信息 \n"); i=addage(); switch(i){ case 1:addolian(head0,rear0);break; case 2:output0(head0);break; case 3:addw(head0);break; case 4:delete(head0);break; } } return 0; //后面对文件操作的几个函数有问题 ------------------------ // }
请问c语言中fread这么用可以吗
``` /* PRESET CODE BEGIN - NEVER TOUCH CODE BELOW */ #include<stdio.h> #include <stdlib.h> struct Student { char num[10]; char name[10]; float c[3]; }; /* PRESET CODE END - NEVER TOUCH CODE ABOVE */ struct Student stu[30]; int main() {FILE *fp=fopen("cj.txt","rb");struct Student *p; for(p=stu;p<stu+30;p++) {fread(&p,sizeof(struct Student),1,fp); } printf("%s,%s,%.1f,%.1f,%.1f\n",p->num,p->name,p->num[0],p->num[1],p->num[2]); } ``` 从文件cj.txt读入一个班的学生成绩(人数不大于30),用结构体数组保存,并输出到屏幕。 内容包括:学号、姓名、语文、数学、外语。 每个学生输出一行,格式为“0001,niu12,99,99,99” cj.txt的内容 00001 niu34 99 62 95 00002 niu35 97 62.5 93.5 00003 niu36 95 63 92 00004 niu37 93 63.5 90.5 00005 niu38 91 64 89 00006 niu39 89 64.5 87.5 00007 niu40 87 65 86 00008 niu41 85 65.5 84.5 00009 niu42 83 66 83 00010 niu43 81 66.5 81.5 00011 niu44 79 67 80 00012 niu45 77 67.5 78.5 00013 niu46 75 68 77 00014 niu47 73 68.5 75.5 00015 niu48 71 69 74 00016 niu49 69 69.5 72.5 总是会报错,,,,,,,
关于C语言读入文件后 管理存储字符串的问题(问题未确定)
vs2010报错是“Windows 已在 公交查询系统.exe 中触发一个断点。 其原因可能是堆被损坏,这说明 公交查询系统.exe 中或它所加载的任何 DLL 中有 Bug。 原因也可能是用户在 公交查询系统.exe 具有焦点时按下了 F12。” 代码如下: #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include<string.h> #include<ctype.h> #include<stdlib.h> #include<iostream> long long a; #define stop system("pause"); #define home(x) printf("%p\n",x); int j;//控制项目数组 struct item { int number; char*Item; }; int main(int argc,char *argv[]) { system("color f9"); system("title 公交查询系统"); FILE *fp; int i;//线路选择 char c; c=(char)malloc(sizeof(char)); printf("字符变量的地址是:"); home(c); int amount=0;//交通线路的数量 fp=fopen("file.txt","rb+"); if(fp==NULL) { printf("获取失败╮(╯▽╰)╭\n"); system("pause"); return 0; } printf("文件指针的地址是:%p\n",fp);//确保文件指针分配到了内存 fseek(fp,0,SEEK_END); int file_size=ftell(fp);//计算文件的大小 fseek(fp,0,SEEK_SET); char *str=NULL;//不知道有没有分配内存 str=(char*)malloc(sizeof(*fp));//分配一个文件大小的内存给指针 printf("指针str的地址是:"); home(str);//用C语言宏 确认str指针分配到了地址 str[file_size]='\0';//用空字符结尾 防止字符串乱码 fread((void*)str,file_size,1,fp);//把文件内容读给str printf("文件大小:%d\n",file_size);//确认文件大小正确 不为零 int seek=0;//设置循环变量 while(seek<file_size) { if(str[seek]=='.')//检索项 用数组运算符 遇到'.'分为一项 { amount++;//amount是项目数 static char*one=NULL;//静态变量 作为str的副本╮(╯▽╰)╭ one=(char*)malloc(sizeof(*fp)); static int one_1=1; static int seek_1=seek; while(one_1<=seek) { sprintf(one,"%c",str[one_1]); } } seek++; } if((c=getc(fp))!=NULL) { printf("读入到文件尾!\n"); } puts(str);//检查文件内容是否不存在 std::cout<<amount<<std::endl; fclose(fp); fp=NULL; struct item ch[5]; {//使自动变量在代码块结尾 退出堆 int i=1; char*ch_1=NULL;//存储项的内容 ch_1=(char*)malloc(sizeof(char*)); printf("临时字符串的地址:%p\n",ch_1);//确保字符串分配到了地址 stop;//C语言宏 system("pause"); while(i<amount) { do{ c=str[a]; sprintf(ch_1,"%c",c,'\0'); }while(a==1); std::cout<<ch_1<<"\n"<<c<<"\n";//确保临时字符串有内容 ch[j].Item=NULL; ch[j].Item=(char*)malloc(sizeof(*fp)); printf("项目的地址:%p\n",ch[j].Item);//确保存储项的结构数组中的指针分配到了内存 std::cout<<j<<"\n";//确保下标未越界 stop; while(ch_1!="。") { ch[j].number=i;//此时 第一项 用number标识这是第几项 strcat(ch[j].Item,ch_1);//把ch_1的内容给连接在指针的末尾 if(c==0) { std::cout<<"读取失败\n"; stop; std::cout<<ch[j].Item<<"\n"; stop; } c=str[a];//继续获取文件内容 sprintf(ch_1,"%c",c); a++; } strcat(ch[j].Item,"。"); j++; i++; } free(ch_1); } printf("1.数据维护(增加项、删除项)\n2.查询\n3.退出\n"); scanf("%d",&i); switch(i) { case 1: int a; printf("你真的做决定了吗?如果你确定的话请选择:\n1.增加项\n2.退出\n"); scanf("%d",&a); if(a==1) { fp=fopen("file.txt","w+");//以读模式来覆盖文本 方便添加项目 char*add_1=(char*)malloc(sizeof(*fp)); sprintf(add_1,"%d.",++amount);//add_1存储文件的序号 如当前有5项 char*add_2=(char*)malloc(sizeof(*fp));//add_2是要添加的文本 printf("在此处添上你要添加的文本\n"); scanf("%s",add_2); strcat(add_1,add_2); strcat(add_1,"。"); strcat(str,add_1);//把文本添加到末尾 puts(str); stop; fprintf(fp,"\n"); fprintf(fp,str);//确认添加成功 fclose(fp); fp=NULL; add_1=add_2=NULL; free(add_1); free(add_2); } else if(a==2) { fp=fopen("file.txt","w+"); int d; printf("请选择你要删除第几项\n"); scanf("%d",&d); ch[d].Item=""; str=""; for(j=1;;j++) { strcat(str,ch[j].Item); } fprintf(fp,str); fclose(fp); fp=NULL; for(seek=0;seek<amount;seek++) { free(ch[seek].Item); } } break; case 2: puts(str); break; case 3: system("pause"); return 0; break; default: break; } str=NULL; free(str); system("pause"); return 0; } ![图片说明](https://img-ask.csdn.net/upload/201510/01/1443664194_232169.jpg) ![图片说明](https://img-ask.csdn.net/upload/201510/01/1443664424_429320.jpg) 运行结果在附属的图片中 还请帮忙看看是什么地方出了错误..
C语言拷贝大文件问题?
``` #include<stdio.h> #pragma warning(disable:4996) #include<time.h> int main(void) { unsigned int start = time(NULL); char arr[1024]; FILE * fp = fopen("D:\\1.avi", "rb"); FILE * fp1 = fopen("D:\\2.avi", "wb"); if (!fp) { printf("文件打开失败!"); return -1; } while (!feof(fp)) //如果文件结束返回非0值,否则返回0; { memset(arr, 0, 1024); fgets(arr, 1024, fp); fputs(arr, fp1); } fclose(fp); fclose(fp1); unsigned int end = time(NULL); printf("%d(s)\n", end - start); return 0; } ``` 为什么用上面fgets和fputs拷贝一个视频文件,300多兆的视频只能拷贝80多兆,而用fgets、fputs与fread、fwrite都能够完全拷贝下来。上面代码哪错了吗?
c语言中关于fread函数与feof函数
``` int Load_1()//把文件中的数据读取到链表中 { FILE* pf = fopen("d:\\Stu.lp", "rb"); Stu* pTemp; while (!feof(pf)) { pTemp = (Stu*)malloc(sizeof(Stu)); fread(pTemp, sizeof(Stu),1, pf); pTemp->pNext = pHead; pHead = pTemp; } return 0; } void Save_1()//把程序中用的数据保存到文件中 { FILE* pf = fopen("d:\\Stu.lp", "wb"); struct Stu* pTemp = pHead; while (pTemp) { fwrite(pTemp, sizeof(Stu),1, pf); pTemp = pTemp->pNext; } } ``` 这是定义的两个结构体: ``` typedef struct Stu_Data { char S_Name[20]; size_t S_Num; float S_Score; }Data; struct Stu { Data D; struct Stu* pNext; }; ``` 新手代码写的不好, 这个 load()函数总是多循环一次打出乱码 ![图片说明](https://img-ask.csdn.net/upload/201607/15/1468585049_52618.png)
fread读取文件内容读到一半出错了,输出为0???
用fread每次读取一定长度的文件大小,读到前面一部分还好好的,后面就开始报错,输出为0,首先已经采用"rb"形式打开文件了,其次也对缓冲区初始化了,为什么还不行呢?代码如下: ![图片说明](https://img-ask.csdn.net/upload/201612/28/1482896003_553754.png)
为什么我这个函数对文件的读写不符合预期?
```C #include<stdio.h> #include<stdlib.h> int main() { FILE *fp; char buff[1]; int count; fp = fopen("abc.txt","rb+"); while((count = fread(buff,1,1,fp))>0) { buff[0] +=1; fseek(fp,-1,SEEK_CUR); fwrite(buff,1,1,fp); } return 0; } ``` 这段代码本来是想把文件每个字节都加1。用文件指针的移动来控制读写的位置,fopen读一个字节,文件指针加1,之后把文件指针减1回到原来的位置,fwrite用处理后的字节覆盖原字节,文件指针加1指向下一个字节循环操作。但是实际出现的结果是从第二个字节开始会出现问题,比如原来txt文件的内容是“12345”,经过三次循环变成"23245"。 实在想不出出了什么问题,可能是我对文件指针和读写操作的理解出了偏差,希望有人指点一二。
c语言运行出错 是链表哪里出错了吗
![图片说明](https://img-ask.csdn.net/upload/201806/13/1528859680_335574.png) ![图片说明](https://img-ask.csdn.net/upload/201806/13/1528859695_89773.png) ![图片说明](https://img-ask.csdn.net/upload/201806/13/1528859715_415797.png) #include <stdio.h> #include <malloc.h> #include <string.h> #include <stdlib.h> #define MAXSIZE 100 typedef struct NODE { char name[MAXSIZE]; int p_num; double p_price; char kind[MAXSIZE]; struct NODE *next; }node; //下面这部分是啥??? typedef struct { char name[MAXSIZE]; int p_num; double p_price; }str; #if 0 void create(node *head); /*创建货物 main 194line*/ void del(node *head); /*删除指定货物*/ void find(node *head) /*查找货物*/ void all_delete(node *head); /*清空全部货物*/ void change(node *head); /*修改货物信息*/ int display() /*菜单*/ #endif void create(node *head) /*创建货物 main 194line*/ { node *p; /*判断货物是否存在的指针变量*/ int i = 1; char name[MAXSIZE]; int p_num; double p_price; char kind[MAXSIZE]; printf("*****************请输入货物名称:************\n"); scanf("%s",name); //getchar(); p = head->next; while(p != NULL) { if(strcmp(p->name,name) == 0) { printf("*********货物已存在************\n"); p = NULL; i = 0; /* 货物已存在,不执行输入货物命令*/ } else { p = p->next; } } while( 1 == i) { node *q; printf("**************请输入货物单位价格:**************\n"); scanf("%lf",&p_price); printf("**************请输入货物数量:**************\n"); scanf("%d",&p_num); printf("*****************请输入货物所属类型:************\n"); scanf("%s",kind); q = (node*)malloc(sizeof(node)); if(NULL == q) { printf("error2\n"); } strcpy(q->name,name); //strcpy(q->p_num,p_num); q->p_num=p_num; q->p_price=p_price; strcpy(q->kind,kind); q->next = head->next; head->next = q; /*头插法*/ i = 0; } } //我的代码跟这个的区别:没有在函数内重新定义变量 然后使用strcpy这些赋值 void order(node *head,int len1) //给货物排序 { node *p; /*用来排序的变量*/ node *q; /*同上*/ p = head->next; while(len1 > 0) /*实现货物按字母排列*/ { while(p != NULL && p->next!= NULL) { char tempname[MAXSIZE]; /*相当于中间变量用来存储货物信息*/ int tempp_num; double tempp_price; char tempkind[MAXSIZE]; if(strcmp(p->name,p->next->name) > 0) { strcpy(tempname, p->next->name); tempp_price=p->next->p_price; tempp_num=p->next->p_num; strcpy(tempkind,p->next->kind); strcpy(p->next->name,p->name); p->next->p_price=p->p_price; p->next->p_num=p->p_num; strcpy(p->next->kind,tempkind); strcpy(p->name,tempname); p->p_price=tempp_price; p->p_num=tempp_num; strcpy(p->kind,tempkind); } else { p=p->next; } } len1--; } } void print(node *head) /*打印联系人的函数*/ { int i = 1; node *p; p = head->next; printf("现在货物为:\n"); printf("编号 名称 价格 数量 所属类型\n"); while(p != NULL) { printf("%d %s %.2lf %d %s\n", i,p->name,p->p_price,p->p_num,p->kind); p = p->next; i++; } } void del(node *head) /*删除指定货物函数*/ { node *p; node *q; q = head; p = q->next; char name[MAXSIZE]; printf("************请输入要删除的货物名称:*********\n"); scanf("%s",name); while((p != NULL) && (strcmp(p->name,name) != 0)) { q = p; p = p->next; } if(NULL == p) { printf("************未查找到***************\n"); } else { q->next = p->next; free(p); printf("***********删除成功****************\n"); } } void find(node *head) //查找货物 { node *p; char name[MAXSIZE]; printf("*******请输入要查找货物名称:**********\n"); scanf("%s",name); p = head->next; while(p != NULL && strcmp(p->name,name) != 0) { p = p->next;//为什么del函数里面还定义了一个指针q } if(NULL == p) { printf("********没有这个货物*********\n"); } else { printf(" 名称:%s\n 价格:%.2lf 数量:%d 所属类型:%s", p->name,p->p_price,p->p_num,p->kind); } } void all_delete(node *head) //清空全部货物 { while(head->next != NULL) { node *q; q = head->next; head->next = q->next; free(q); } if(NULL == head->next) { printf("*********清除所有货物成功*********\n"); } } void change(node *head) //修改货物信息 { node *p; char name[MAXSIZE]; double p_price; int p_num; char kind[MAXSIZE]; p = head->next; printf("请输入要修改的货物名称\n"); scanf("%s",name); while( p != NULL) { if(strcmp(p->name,name) == 0) { printf("请输入要修改的货物价格\n"); scanf("%lf",p_price); p->p_price=p_price; printf("修改成功\n"); break; } else { p = p->next; } } if(p == NULL) { printf("未查找到此联系人!\n"); } } int sum(node *head) //求链表中有多少货物 { int count_node = 0; node *p; p = head->next; if(p != NULL) { count_node++; p = p->next; } return count_node; } /*void write_to_file(node *head,int len) //链表中的货物信息写到文件 { int i; str string[100]; FILE *fp = fopen("a2","wb"); if(NULL == fp) { printf("open error\n"); exit(1); } //printf("1111\n"); while( head->next != NULL) { for(i = 0;i < len;i++) { strcpy(string[i].name,head->next->name); strcpy(string[i].p_num,head->next->p_num); fwrite(&string[i],sizeof(str),1,fp); //依次将结构体数组写到文件 head = head->next; } } fclose(fp); } void read_to_linklist(node *head) //将文件中的数据读到链表中 { int i; int m; int j = 0; node *p; node *q; p = head; FILE *fp; fp = fopen("a2","rb"); fseek(fp,0,SEEK_END); i = ftell(fp); fseek(fp,0,SEEK_SET); m = (i/(sizeof(str))); // m :文件中有多少个联系人 str string[100]; //结构体数组,存放所有联系人 fread(string,sizeof(str),m,fp); while(m > 0) { q = (node*)malloc(sizeof(node)); strcpy(q->name,string[j].name); strcpy(q->p_num,string[j].p_num); m--; j++; p->next = q; p = q; } fclose(fp); }*/ int display() //菜单 { printf( "\n**************请选择要进行的操作***********\n"); printf("-----------------------------------------------\n"); printf("*|************* 1 .添加货物******************|*\n"); printf("*|************* 2 .删除货物******************|*\n"); printf("*|**************3 .查找货物******************|*\n"); printf("*|**************4 .显示货物******************|*\n"); printf("*|**************5 .修改货物******************|*\n"); printf("*|**************6 .清空货物******************|*\n"); printf("*|**************7 .退 出******************|*\n"); printf("-----------------------------------------------"); } int main() { int a; int n = 1; node *head; node *q; head = (node*)malloc(sizeof(node)); if(NULL == head) { printf("error\n"); } q = head; head->next = NULL; //read_to_linklist(q); while(n == 1) { printf("\n",display()); printf("\n**********************请输入要进行的操作**********\n\n"); scanf("%d",&a); switch(a) { case 1: while(getchar() != '\n'); create(q); order(q,sum(q)); a = 0; break; case 2: while(getchar() != '\n'); del(q); getchar(); print(q); break; case 3: find(q); break; case 4: while(getchar() != '\n'); print(q); break; case 5: while(getchar() != '\n'); change(q); break; case 6: all_delete(q); break; case 7: //write_to_file(q,sum(q)); n = 0; break; default: { printf("*****输入错误,请重新选择指令:******\n"); } while(getchar() != '\n'); break; } } free(head); }
C语言中select函数 应用于网络存储中配合fread/fwrite是否存在阻塞问题
利用fread fwrite 读写网络存储上的文件时,是否会出现阻塞问题? 我的感觉是会出现但是无法通过select判断,因为select判断的是内容是否存在,就是文件是否存在,而对于文件fread fwrite没有发现文件也会报错 但是一旦文件存在开始读写以后发生了网络传输中断引起阻塞 那么还是会挂住 而所谓的非阻塞机制无法发挥作用 不知道我的理解是否正确? 谢谢大家发表看法。
为什么链表在文件中输出后显示的是乱码?
int ListInsert( linklist *&head) { system("cls"); char ch[2]; linklist *r,*s; FILE *fp; r=head; s=LEN; printf("是否添加学生成绩信息(Y/N):"); scanf("%s",ch); printf("请输入商品的id号:"); scanf("%s",s->id); while(strcmp(ch,"Y")==0 || strcmp(ch,"y")==0) { system("cls"); if((fp=fopen("data.txt","r"))==NULL) { printf("打开文件失败,可能是此文件不存在\n"); return false; } if(head->next==NULL) { linklist *p,*k; k=p; while(!feof(fp)) { p=LEN; fread(p,sizeof(linklist),1,fp); //将数据读入新链 r->next=p; r=p; p=p->next; r->next=NULL; } } while(r->next!=0) { r=r->next; if(strcmp(r->id,s->id)==0) { printf("该商品已经存在\n"); return false; } } system("cls"); printf("请输入商品条码号:"); scanf("%s",s->id); s->id[4]='\0'; printf("请输入商品名称:"); scanf("%s",s->sname); s->sname[14]='\0'; printf("请输入供应商:"); scanf("%s",s->sup); s->sup[17]='\0'; printf("请输入进货价:"); scanf("%f",&s->price1); printf("请输入销售价:"); scanf("%f",&s->price2); printf("请输入进货数量:"); scanf("%",&s->num); fwrite(s,1,sizeof(linklist),fp); r->next=s; r=s; fclose(fp); printf("保存成功\n"); system("cls"); printf("是否继续添加(Y/N):"); scanf("%s",ch); } r->next=NULL; } /*---------------------显示信息----------------------*/ void view(int n) { FILE *fp; int m=0; linklist *head,*r,*p; if(n==0) return; system("cls"); if((fp=fopen("data.txt","r"))==NULL) { printf("打开文件失败,可能是此文件不存在\n"); return; } head=LEN; r=head; while(!feof(fp)) { p=LEN; fread(p,sizeof(linklist),1,fp); //将数据读入新链 r->next=p; r=p; p=p->next; r->next=NULL; m++; } fclose(fp); if(m==0) { printf("目前尚未添加记录\n"); return; } PRINTF; p=head->next; while(p) { printf("%s%s%s",p->id,p->sname,p->sup); printf("%f%f%d",p->price1,p->price2,p->num); printf("\n"); p=p->next; } }
相见恨晚的超实用网站
相见恨晚的超实用网站 持续更新中。。。
字节跳动视频编解码面经
三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时想着能进去就不错了,管他哪个岗呢,就同意了面试...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
python学习方法总结(内附python全套学习资料)
不要再问我python好不好学了 我之前做过半年少儿编程老师,一个小学四年级的小孩子都能在我的教学下独立完成python游戏,植物大战僵尸简单版,如果要肯花时间,接下来的网络开发也不是问题,人工智能也可以学个调包也没啥问题。。。。。所以python真的是想学就一定能学会的!!!! --------------------华丽的分割线-------------------------------- ...
python 简易微信实现(注册登录+数据库存储+聊天+GUI+文件传输)
socket+tkinter详解+简易微信实现 历经多天的努力,查阅了许多大佬的博客后终于实现了一个简易的微信O(∩_∩)O~~ 简易数据库的实现 使用pands+CSV实现数据库框架搭建 import socket import threading from pandas import * import pymysql import csv # 创建DataFrame对象 # 存储用户数据的表(...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小型人工智障。 知识可以运用在不同地方,不一定非是天气预报。
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
Python实例大全(基于Python3.7.4)
博客说明: 这是自己写的有关python语言的一篇综合博客。 只作为知识广度和编程技巧学习,不过于追究学习深度,点到即止、会用即可。 主要是基础语句,如三大控制语句(顺序、分支、循环),随机数的生成,数据类型的区分和使用; 也会涉及常用的算法和数据结构,以及面试题相关经验; 主体部分是针对python的数据挖掘和数据分析,主要先攻爬虫方向:正则表达式匹配,常用数据清洗办法,scrapy及其他爬虫框架,数据存储方式及其实现; 最后还会粗略涉及人工智能领域,玩转大数据与云计算、进行相关的预测和分析。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看...
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
JavaScript 为什么能活到现在?
作者 | 司徒正美 责编 |郭芮 出品 | CSDN(ID:CSDNnews) JavaScript能发展到现在的程度已经经历不少的坎坷,早产带来的某些缺陷是永久性的,因此浏览器才有禁用JavaScript的选项。甚至在jQuery时代有人问出这样的问题,jQuery与JavaScript哪个快?在Babel.js出来之前,发明一门全新的语言代码代替JavaScript...
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Python 编程开发 实用经验和技巧
Python是一门很灵活的语言,也有很多实用的方法,有时候实现一个功能可以用多种方法实现,我这里总结了一些常用的方法和技巧,包括小数保留指定位小数、判断变量的数据类型、类方法@classmethod、制表符中文对齐、遍历字典、datetime.timedelta的使用等,会持续更新......
吐血推荐珍藏的Visual Studio Code插件
作为一名Java工程师,由于工作需要,最近一个月一直在写NodeJS,这种经历可以说是一部辛酸史了。好在有神器Visual Studio Code陪伴,让我的这段经历没有更加困难。眼看这段经历要告一段落了,今天就来给大家分享一下我常用的一些VSC的插件。 VSC的插件安装方法很简单,只需要点击左侧最下方的插件栏选项,然后就可以搜索你想要的插件了。 下面我们进入正题 Material Theme ...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
相关热词 c#委托 逆变与协变 c#新建一个项目 c#获取dll文件路径 c#子窗体调用主窗体事件 c# 拷贝目录 c# 调用cef 网页填表c#源代码 c#部署端口监听项目、 c#接口中的属性使用方法 c# 昨天
立即提问