c语言指针 指针数组 函数数组

图片说明
图片说明
图片说明
图片说明
图片说明
图片说明
想请教各位大佬这几个题中指针所代表的含义
如果能解释一下题目的解题过程就更好了 最近学指针 真的是被它搞得有点晕

4个回答

1.
1.1 解题思路:定义一个字符串数组,数组内依次存放12个月份的英文名称,通过数组索引可将月份号与月份英文名称对应起来,即通过月份号-1对名称数组进行索引便可得到月份名称。
1.2 指针含义:
const char* months[] = {…}
char const* months[] = {…}
char* const months[] = {…}
去掉const应该很容易理解,就是字符串指针数组,字符串通过字符串指针的形式表示。然后,再加上const进一步理解。Const表示常量,相当于限定符。Const加在类型变量定义前面,表示该类型变量是常量。
第一个,加在char*前面,表示字符串指针指向的内容是常量,即字符串是常量,不能通过该指针修改字符串。第二个含义与第一个相同,但第一种形式更易理解,推荐第一种形式。第三个const在months前面,表示字符串指针months是常量,不能修改指针。
Static表示变量为静态变量,其生存周期与全局变量相同。对于初学者记住其特性就行,即static变量只初始化一次,存在于整个程序运行期间。深层次理解,static变量存放于代码区,而不像局部变量那样生存于堆栈上。局部静态变量生存期不变,只是仅在局部可见。对于本例中,GetMonthName函数中的static变量尽在该函数中可见,外部无法访问该变量。相对于全局变量,其不会与外部区域定义的同名变量发生冲突。若两个全局变量同名,则编译时会发生错误。
3.
3.1 解题思路:排序采用经典的冒泡算法,即2遍扫描一个数组,比较相邻的两个数组元素,若不满足预设条件(如前一个小于后一个),则两者交换。
Main()函数的过程为,先利用库函数strcmp作为预设条件,对strs[]数组前6个元素进行排序,然后输出排序后的结果。接着利用自定义函数str_cmp_n作为预设条件进行排序输出。
程序中出现有两种指针类型,第一种与题1中的相同,即const char * valuename类型的指针,含义与题1相同。另外,若valuename后面有[], 即const char * valuename[]形式,表示是指针数组,指针数组中每个元素是一个指针,每一个指针指向一个字符串。第二种是一种比较高级的指针-函数指针,即int (*cmp),函数名称相当于一个全局变量,函数指针指向函数代码段的索引地址,通过函数指针,程序可以调到相应的代码区域执行代码。对于初学者,了解即可。

2.
2.1 解题思路:main()函数的思路题目中已经介绍,不再赘述。介绍一下Sort函数的思路,Sort函数仍然采用冒泡算法,只不过元素交换采用交换指针的方式,即通过交换指向两个元素的指针实现元素交换。
本题中出现了字符串指针、指针数组以及const指针数组,其都可以看作字符串指针的变形。
Char * str为字符串指针,未加const限制,指针值和指针指向的内容都可以改变;
Const char* str加了const限制,指针值可以改变,但指针指向的字符串不可以改变;
Const char* str[]为字符串指针数组,数组的每一个元素是一个指针,指针指向的字符串不能改变;但指针的值是可以改变的。
Char str[][]为二维指针数组,数组元素的索引只能通过str指针加上偏移量实现,意味着无法实现指针值的改变。
在Sort函数中,元素交换的代码是
const char* t = strs[i];
strs[i] = strs[j];
strs[j] = t;
这里strs[i], strs[j], t都是指针,交换的是指针的值,并不是指针指向的字符串。

实际上是定义了char型的指针数组,通过char * months[]将十二个月份的字符串首地址保存在了这个数组中。另外关于const有个口诀是左数右指,意思是const在 * 左边那么数值是常量,如果const在 * 右边,那么指针是常量

这里的指针基本都是说char类型的,只不过书本上是一个变量,而这里用的数组形式而已

把指针p也当作一个变量,只是里面的值是地址。p=&a; 他指向a,他的内容就是存储a的地址。假如a是一个数组,因为数组的地址连续,所以p++
能指向数组的下一个元素

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
C语言中指针数组作为函数参数传递的地址问题?

如下代码和结果 指针数据作为函数的形参和实在的时候,形参指针p和实参指针name指向同一个地址是没问题的,可为什么用&去他自身变量的地址的时候取出来的也是同一的地址呢? ``` int main() { void print(char *p[]); char *name[] = { "11111","2222222","33333333" }; printf("name[0]的地址为:%d\n", &name[0]); printf("name[0]指向的地址为:%d\n", name[0]); printf("name[0]的值为:%s\n", name[0]); printf("\n"); printf("\n"); print(name); return 0; } void print(int *p[]) { printf("p[0]的地址为:%d\n", &p[0]); printf("p[0]指向的地址为:%d\n", p[0]); printf("p[0]的值为:%s\n", p[0]); } ``` 下图为输出结果: ![图片说明](https://img-ask.csdn.net/upload/201910/17/1571290590_733033.jpg) 为了区别问题,特写了一个用指针作为参数的函数做了对比,如下: ``` int main() { void print(char *p); int name = 5; int *n; n = &name; printf("n的地址为:%d\n", &n); printf("n指向的地址为:%d\n", n); printf("name的地址为:%d\n", &name); printf("n指向的地址的值为:%d\n", name); printf("\n"); printf("\n"); print(n); return 0; } void print(int *p) { printf("p的地址为:%d\n", &p); printf("p指向的地址为:%d\n", p); printf("p的值为:%d\n", *p); printf("\n"); printf("\n"); } ``` 下图为输出结果: ![图片说明](https://img-ask.csdn.net/upload/201910/17/1571291266_40842.jpg) 为什么这里实参指针n和形参指针p自身地址是不一样的,而上面用指针数据的时候,实参指针数组name和形参指针数组p是一样的。这里有什么区别吗?

c语言用指针实现删除数组中的数字,并且统计数字个数。求大神纠错!

#include <stdio.h> #define N 80 void lszcy(char *oldstr,char *newstr); int main(){ char a[N],b[N]; printf("Input a string:"); gets(a); lszcy(a,b); printf("The new string is:"); puts(b); return 0; } //删除字符串中数字,并且统计数字个数 void lszcy(char *oldstr,char *newstr){ int i=0,j=0,m=0; while(*oldstr != '\0'){ while(!(*oldstr >= '0' && *oldstr <= '9')){ *newstr = *oldstr; newstr++; i++; } oldstr++; j++; } *newstr = '\0'; m = j-i; printf("The number of figures are:"); printf("%d\n",m); } ``` ```

c语言结构体中指针数组怎样赋值

定义一个结构体 struct AS { char *p[1]; }; 怎样用gets函数给指针数组赋值呢?

C语言的函数,指针,数组,结构体

如何才能学好C语言中的函数,指针,数组,结构体,并且能够灵活快速的编写程序。

C语言指针数组输出时的问题

![为什么printf *ptr【k】输出时就什么都打印不出](https://img-ask.csdn.net/upload/201609/03/1472908433_58587.png)

c语言关于二维数组名和二维指针的问题,求帮忙看下,谢谢

定义如下函数 void fun(int **array, int m, int n); 在调用这样的函数的时候,需要注意一下,如下面的例子: int a[3][3] = { {1, 1, 1}, {2, 2, 2}, {3, 3, 3}}; fun(a, 3, 3); 根据不同编译器不同的设置,可能出现warning 或者error,可以进行强制转换如下调用: fun((int**)a, 3, 3); 为什么 不能直接用数组名,它和二维指针有什么区别?

【c语言】2维数组求平均值,指针出问题了

double average(double (*p)[],double *q,int n,int m) { int i,j; double NU,AE;//每列总和与每行总和 for(i=0;i<n;i++) { for(NU=0,j=0;j<m;j++) { NU+=(*p+i)[j];//每列的和 } q[i]=NU/m;//每行的平均值 AE+=NU;//每行的和 } return AE/(n*m);//总平均值 } ``` ``` 第一行的平均值没错!第2行开始的平均值有错! 猜测NU+=(*p+i)[j];这出错了!试过NU+=p[i][j];无法编译! 也是个改参数!把(*p)[]改成**p,把NU+=(*p)[j]改成NU+=(*(*p+i)+j); 无法编译! 需求是求2次平均值! 1个是行的平均值, 1个是总平均值!

用指针逆序输出数组,for循环打印不完全

![图片说明](https://img-ask.csdn.net/upload/201902/06/1549443842_560434.png) 用for循环次数少一个,打印不出第一个元素。 ![图片说明](https://img-ask.csdn.net/upload/201902/06/1549443855_480625.png)

c语言中数组的指针表示法

数组有数组表达法和指针表达法 假设一个数组double target[5] 当我在函数的形参部分声明这个数组时 我可以写double target[5] 但是用指针表达的时候应该写double * target 我想问的是这里的指针表达法应该是表达了数组首元素的地址 也就是其类型应该是整型 所以不是应该写int * target吗

c语言 指针数组作为函数参数问题

``` #include<stdio.h> #include<stdlib.h> void init_rec(day_record *arr[],FILE *file) { char temp[80]; int index=0; while((fscanf(file,"%s",temp))!=EOF) { arr[index]=NULL; arr[index]=(day_record * )malloc(sizeof(day_record)); if(arr[index]==NULL) { printf("结构地址分配错误\n"); exit(1); } replace(',',' ',temp); inputrc(arr[index],temp); index++; } } ``` 在gcc中编译 总是提示错误发生在void init_rec(day_record *arr[],FILE *file)这一行 **错误内容是 pay.c:6: 错误:expected ‘)’ before ‘*’ token ** 结构体是这么写的 ``` //每日记录临时存储结构 typedef struct day_record { int worker_nu; char date[DATE_LEN]; char * loca; int work_nu; char * worker[WORK_LEN]; } day_record; ``` 调用是这样的 ``` #include<stdio.h> #include<stdlib.h> #include"pay.h" #include"pay.c" int main() { FILE * fp; day_record * record[31]; fp = fopen("pay","r"); if(fp==NULL) { printf("open failed\n"); exit(1); } init_rec(record,fp); putdr(record[0]); fclose(fp); return 0; } ``` 想不明白是怎么回事 求指教 谢谢大家

【c语言】一维数组的倒序输出

``` #include <stdio.h> int *inverse(int *p,int n); void main(){ int a[4]={1,2,3,4},*p,i; p=inverse(a,4); for(i=0;i<4;i++) printf("%d",*p); } int *inverse(int *p,int n){ int temp[4],i; while(*p)++p;//找到p所指的最后一个元素 for(i=0;i<n;i++,--p) temp[i]=*p;//将p的值赋给temp[i] p=temp; return p; } ``` 不知道错哪里了,输出一串奇怪的数字???

【C语言】有关数组转置与指针应用的题目,求大佬解答

编写函数实现矩阵(4行4列)的转置。要求函数的实参为数组名,形参为指针形式。

c语言三维数组做函数输入变量,函数的形参怎么写?

比如uint8_t cube[5][5][5];要在函数内处理数组内的数据并能返回值,肯定是传入三维数组的地址。函数定义时形参不知道怎么写才行??void process(uint8_t ????);

c语言中两个数组相乘的问题

#include<stdio.h> #include<stdlib.h> #define OK 1 #define ERROR 0 #define MAXSIZE 100 //最多非0元素的个数 #define MAXR 50 //rpos所能处理的最大行数 #define MAXC 50 //系数矩阵相乘时,保留临时列结果的数组temp[MAXC] typedef struct NODE{ //定义稀疏矩阵结点 int i; int j; int data; } Node; typedef struct MATRIX{ //定义稀疏矩阵(可以快速访问) int mu, nu, tu; Node matrix[MAXSIZE+1]; int rpos[MAXR+1]; } Matrix; int CreatSMatrix( Matrix* M ); //创建一个矩阵(由用户输入原始矩阵,转化为稀疏矩阵方式储存) int Print( Matrix M ); //打印一个稀疏矩阵 int Mul_SMatrix( Matrix M, Matrix N, Matrix *Q); //两个稀疏矩阵相乘 main(){ Matrix A1, A2, A3; //定义矩阵 CreatSMatrix( &A1 ); CreatSMatrix( &A2 ); if( A1.nu==A2.mu ){ //判断能否相乘 Mul_SMatrix( A1, A2, &A3 ); printf("两矩阵相乘得:\n"); Print(A3); } else printf("两矩阵不能相乘"); system("pause"); return 0; } //稀疏矩阵相乘 int Mul_SMatrix( Matrix M, Matrix N, Matrix *Q) { int i,Mj; int arow, Mlim, Nlim, Mcol, Nrow; int ctemp[MAXC]; Q->tu=0; //初始化Q Q->mu=M.mu; Q->nu=M.nu; if(M.tu*N.tu!=0){ //非零矩阵 for(arow=1; arow<=M.mu; arow++){ for(i=1; i<=M.nu; i++)//清空累加器 ctemp[i]=0; Q->rpos[arow]=Q->tu+1; //给Q->rpos[]数组赋值 Mlim = arow<M.mu ? M.rpos[arow+1] : M.tu+1; //M中第arow行在结点数组中的范围 for( Mcol=M.rpos[arow]; Mcol<Mlim; Mcol++ ){ //遍历M中第arow行的每一个j Mj=M.matrix[Mcol].j; Nlim = Mj<N.mu ? N.rpos[Mj+1] : N.tu+1;//在N中找到行号i等于M中的列号j的位置 for( Nrow=N.rpos[Mj]; Nrow<Nlim; Nrow++ )//乘积元素在Q中的列号 ctemp[N.matrix[Nrow].j] += M.matrix[Mcol].data * N.matrix[Nrow].data; } for(i=1; i<=Q->nu; i++){//列号对应元素不为零,赋值 if( ctemp[i] ){ if( ++Q->tu > MAXSIZE ) return 0; Q->matrix[Q->tu].i = arow; Q->matrix[Q->tu].j = i; Q->matrix[Q->tu].data = ctemp[i]; } } } } return 1; } //构建稀疏矩阵 int CreatSMatrix( Matrix* M ){ int temp, i,j; printf("输入矩阵的行列数:"); scanf("%d%d", &M->mu, &M->nu); M->tu=0; printf("按行序输入矩阵:\n"); for( i=1; i<=M->mu; i++){ M->rpos[i]=M->tu+1; //每计算完一行,给rpos[]赋值 for( j=1; j<=M->nu; j++){ scanf("%d",&temp ); if( temp ){ //非0值保存 M->matrix[M->tu+1].i= i; M->matrix[M->tu+1].j= j; M->matrix[M->tu+1].data=temp; M->tu++; } } } return OK; } //打印稀疏矩阵 int Print( Matrix M){ int i; if(M.tu==0){ printf("空矩阵\n\n"); return ERROR; } printf("i\tj\tdata\n"); for( i=1; i<=M.tu; i++ ) printf("%d\t%d\t%d\n", M.matrix[i].i,M.matrix[i].j,M.matrix[i].data); return OK; } 中int rpos[MAXR+1]这个是干啥用的啊?

用c语言编写一个数组排序函数 要求如下

1.既能从小到大也能从大到小 2.对int,unsigned int,const int,double 等类型数组都适用 3.尽量简洁

C语言数组作为参数传入子函数

对不起,可能我没表达清楚,我想问,数组作为参数传入子函数为什么不是作为形式参数传入,请你看程序运行结果,如果数组作为形式参数传入子函数,那么形式参数的值并不会影响原来main函数中的值,但是实际上,main函数中数组原来的值已经被修改了,这是因为数组传入的是地址(指针),我的问题就在这里,传入的是指针为什么不是用完就扔的形式参数。 这与c语言的设计有关是吗?内部有什么机制吗?

C语言关于二维数组指针求解

下面是程序运行结果 ![图片说明](https://img-ask.csdn.net/upload/201907/16/1563245789_656376.png) 关于*zippo的地址和和zippo【0】的地址一样我没问题,可是为什么zippo的值 和Zippo【0】的值一样呢?zippo不是因该是Zippo【0】的地址吗?

如何在C语言中以数组指针作为形参输出数组

#include "stdafx.h" void cmdsend(unsigned int * info); int main() { unsigned int senddata[5]; senddata[0] = 8; senddata[1] = 2; senddata[2] = 0; senddata[3] = 4; senddata[4] = 5; cmdsend( senddata ); while(1){;} } void cmdsend(unsigned int * info) { unsigned int k; for (k = 0; ((*info) != '\0') && (info != NULL); *info++, k++) printf("senddata is %d\r\n", *info); } 如上面程序所示,我想将数组sendata完整的输出,现在只能打印出8,2.即在sendata[2]处结束,好像判断为 info == NULL了,请问应该怎样修改,才能输出完整数组?在使用 *info 指针作为形参的前提下。

关于c语言中二维数组形参的问题

对于二维数组比如一个double number[m][n] 既然number 和number[0]的值都是number[0][0]的地址 那么这两者有什么区别呢 当我定义了一个函数 这个函数用来把一个二维数组的值copy到另一个二维数组 这个函数的形参为什么只能写double number[][n]而不能直接写double * number呢

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

CSDN:因博主近期注重写专栏文章(已超过150篇),订阅博主专栏人数在突增,近期很有可能提高专栏价格(已订阅的不受影响),提前声明,敬请理解!

CSDN:因博主近期注重写专栏文章(已超过150篇),订阅博主专栏人数在突增,近期很有可能提高专栏价格(已订阅的不受影响),提前声明,敬请理解! 目录 博客声明 大数据了解博主粉丝 博主的粉丝群体画像 粉丝群体性别比例、年龄分布 粉丝群体学历分布、职业分布、行业分布 国内、国外粉丝群体地域分布 博主的近期访问每日增量、粉丝每日增量 博客声明 因近期博主写专栏的文章越来越多,也越来越精细,逐步优化文章。因此,最近一段时间,订阅博主专栏的人数增长也非常快,并且专栏价

我说我不会算法,阿里把我挂了。

不说了,字节跳动也反手把我挂了。

培训班出来的人后来都怎么样了?(二)

接着上回说,培训班学习生涯结束了。后面每天就是无休止的背面试题,不是没有头脑的背,培训公司还是有方法的,现在回想当时背的面试题好像都用上了,也被问到了。回头找找面试题,当时都是打印下来天天看,天天背。 不理解呢也要背,面试造飞机,上班拧螺丝。班里的同学开始四处投简历面试了,很快就有面试成功的,刚开始一个,然后越来越多。不知道是什么原因,尝到胜利果实的童鞋,不满足于自己通过的公司,嫌薪水要少了,选择...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

工作八年,月薪60K,裸辞两个月,投简历投到怀疑人生!

近日,有网友在某职场社交平台吐槽,自己裸辞两个月了,但是找工作却让自己的心态都要崩溃了,全部无果,不是已查看无回音,就是已查看不符合。 “工作八年,两年一跳,裸辞两个月了,之前月薪60K,最近找工作找的心态崩了!所有招聘工具都用了,全部无果,不是已查看无回音,就是已查看不符合。进头条,滴滴之类的大厂很难吗???!!!投简历投的开始怀疑人生了!希望 可以收到大厂offer” 先来看看网...

97年世界黑客编程大赛冠军作品(大小仅为16KB),惊艳世界的编程巨作

这是世界编程大赛第一名作品(97年Mekka ’97 4K Intro比赛)汇编语言所写。 整个文件只有4095个字节, 大小仅仅为16KB! 不仅实现了3D动画的效果!还有一段震撼人心的背景音乐!!! 内容无法以言语形容,实在太强大! 下面是代码,具体操作看最后! @echo off more +1 %~s0|debug e100 33 f6 bf 0 20 b5 10 f3 a5...

不要再到处使用 === 了

我们知道现在的开发人员都使用 === 来代替 ==,为什么呢?我在网上看到的大多数教程都认为,要预测 JavaScript 强制转换是如何工作这太复杂了,因此建议总是使用===。这些都...

什么是a站、b站、c站、d站、e站、f站、g站、h站、i站、j站、k站、l站、m站、n站?00后的世界我不懂!

A站 AcFun弹幕视频网,简称“A站”,成立于2007年6月,取意于Anime Comic Fun,是中国大陆第一家弹幕视频网站。A站以视频为载体,逐步发展出基于原生内容二次创作的完整生态,拥有高质量互动弹幕,是中国弹幕文化的发源地;拥有大量超粘性的用户群体,产生输出了金坷垃、鬼畜全明星、我的滑板鞋、小苹果等大量网络流行文化,也是中国二次元文化的发源地。 B站 全称“哔哩哔哩(bilibili...

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

MySQL性能优化(五):为什么查询速度这么慢

前期回顾: MySQL性能优化(一):MySQL架构与核心问题 MySQL性能优化(二):选择优化的数据类型 MySQL性能优化(三):深入理解索引的这点事 MySQL性能优化(四):如何高效正确的使用索引 前面章节我们介绍了如何选择优化的数据类型、如何高效的使用索引,这些对于高性能的MySQL来说是必不可少的。但这些还完全不够,还需要合理的设计查询。如果查询写的很糟糕,即使表结构再合理、索引再...

用了这个 IDE 插件,5分钟解决前后端联调!

点击上方蓝色“程序猿DD”,选择“设为星标”回复“资源”获取独家整理的学习资料!作者 |李海庆我是一个 Web 开发前端工程师,受到疫情影响,今天是我在家办公的第78天。开发了两周,...

大厂的 404 页面都长啥样?最后一个笑了...

每天浏览各大网站,难免会碰到404页面啊。你注意过404页面么?猿妹搜罗来了下面这些知名网站的404页面,以供大家欣赏,看看哪个网站更有创意: 正在上传…重新上传取消 腾讯 正在上传…重新上传取消 网易 淘宝 百度 新浪微博 正在上传…重新上传取消 新浪 京东 优酷 腾讯视频 搜...

【高并发】高并发秒杀系统架构解密,不是所有的秒杀都是秒杀!

网上很多的文章和帖子中在介绍秒杀系统时,说是在下单时使用异步削峰来进行一些限流操作,那都是在扯淡! 因为下单操作在整个秒杀系统的流程中属于比较靠后的操作了,限流操作一定要前置处理,在秒杀业务后面的流程中做限流操作是没啥卵用的。

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

代码注释如此沙雕,会玩还是你们程序员!

某站后端代码被“开源”,同时刷遍全网的,还有代码里的那些神注释。 我们这才知道,原来程序员个个都是段子手;这么多年来,我们也走过了他们的无数套路… 首先,产品经理,是永远永远吐槽不完的!网友的评论也非常扎心,说看这些代码就像在阅读程序员的日记,每一页都写满了对产品经理的恨。 然后,也要发出直击灵魂的质问:你是尊贵的付费大会员吗? 这不禁让人想起之前某音乐app的穷逼Vip,果然,穷逼在哪里都是...

Java14 新特性解读

Java14 已于 2020 年 3 月 17 号发布,官方特性解读在这里:https://openjdk.java.net/projects/jdk/14/以下是个人对于特性的中文式...

爬虫(101)爬点重口味的

小弟最近在学校无聊的很哪,浏览网页突然看到一张图片,都快流鼻血。。。然后小弟冥思苦想,得干一点有趣的事情python 爬虫库安装https://s.taobao.com/api?_ks...

疫情后北上广深租房价格跌了吗? | Alfred数据室

去年3月份我们发布了《北上广深租房图鉴》(点击阅读),细数了北上广深租房的各种因素对租房价格的影响。一年过去了,在面临新冠疫情的后续影响、城市尚未完全恢复正常运转、学校还没开学等情况下...

面试官给我挖坑:a[i][j] 和 a[j][i] 有什么区别?

点击上方“朱小厮的博客”,选择“设为星标”后台回复&#34;1024&#34;领取公众号专属资料本文以一个简单的程序开头——数组赋值:int LEN = 10000; int[][] ...

又一起程序员被抓事件

就在昨天互联网又发生一起让人心酸的程序员犯罪事件,著名的百度不限速下载软件 Pandownload PC 版作者被警方抓获。案件大致是这样的:软件的作者不仅非法盗取用户数据,还在QQ群进...

应聘3万的职位,有必要这么刁难我么。。。沙雕。。。

又一次被面试官带到坑里面了。面试官:springmvc用过么?我:用过啊,经常用呢面试官:springmvc中为什么需要用父子容器?我:嗯。。。没听明白你说的什么。面试官:就是contr...

太狠了,疫情期间面试,一个问题砍了我5000!

疫情期间找工作确实有点难度,想拿到满意的薪资,确实要点实力啊!面试官:Spring中的@Value用过么,介绍一下我:@Value可以标注在字段上面,可以将外部配置文件中的数据,比如可以...

Intellij IDEA 美化指南

经常有人问我,你的 IDEA 配色哪里搞的,我会告诉他我自己改的。作为生产力工具,不但要顺手而且更要顺眼。这样才能快乐编码,甚至降低 BUG 率。上次分享了一些 IDEA 有用的插件,反...

【相亲】96年程序员小哥第一次相亲,还没开始就结束了

颜值有点高,条件有点好

太厉害了,终于有人能把TCP/IP 协议讲的明明白白了

一图看完本文 一、 计算机网络体系结构分层 计算机网络体系结构分层 计算机网络体系结构分层 不难看出,TCP/IP 与 OSI 在分层模块上稍有区别。OSI 参考模型注重“通信协议必要的功能是什么”,而 TCP/IP 则更强调“在计算机上实现协议应该开发哪种程序”。 二、 TCP/IP 基础 1. TCP/IP 的具体含义 从字面意义上讲,有人可能会认为...

腾讯面试题: 百度搜索为什么那么快?

我还记得去年面腾讯时,面试官最后一个问题是:百度/google的搜索为什么那么快? 这个问题我懵了,我从来没想过,搜素引擎的原理是什么 然后我回答:百度爬取了各个网站的信息,然后进行排序,当输入关键词的时候进行文档比对……巴拉巴拉 面试官:这不是我想要的答案 我内心 这个问题我一直耿耿于怀,终于今天,我把他写出来,以后再问,我直接把这篇文章甩给他!!! 两个字:倒排,将贯穿整篇文章,也是面试官...

相关热词 c# 开发接口 c# 中方法上面的限制 c# java 时间戳 c#单元测试入门 c# 数组转化成文本 c#实体类主外键关系设置 c# 子函数 局部 c#窗口位置设置 c# list 查询 c# 事件 执行顺序
立即提问
相关内容推荐