用函数指针做另一个函数的形参

我不把compare函数写在Locate函数的形参里有什么坏处么?
为什么数据结构的书上要把用到的compare函数利用函数指针写在形参里呢?
图片说明
图片说明

1个回答

没什么明显的坏处,到时觉得你的这个比较函数的参数有问题。
你需要清楚什么时候回发生复制构造,复制的代价有多大。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
c/c++ 函数调用中形参为指针或者引用对栈操作问题
问题引出: 当我们的函数参数为普通变量或指针时,我们在调用过程中会拷贝一个副本,而当形参为引用时不会拷贝一个副本。 当形参为普通变量时,会拷贝一个变量备份,当为指针时会拷贝一个指针备份,指针指向的内容不会拷贝 问题来了: 查看使用指针和使用引用的方式调用的函数的汇编代码,会发现在汇编代码层面实现方式是一模一样的,都是: lea eax,[i](假设i是整形变量) push eax 而使用值传递方式是: mov eax,dword ptr [i] (假设i是整形变量) push eax -----但是为什么使用指针传递需要拷贝一个指针的备份(4个字节),而使用引用不会产生拷贝。。
不能通过改变指针形参的值而使指针实参的值改变
#include<stdio.h> int s(int *a,int *b) { int t; t=*a; *a=*b; *b=t; } main() { int a,b; int *p1,*p2; scanf("%d,%d",&a,&b); p1=&a; p2=&b; if (a<b) s(p1,p2); printf("%d,%d",*p1,*p2); } 这是代码1。 ``` swap(int *p1,int *p2) {int *p; p=p1; p1=p2; p2=p; } main() { int a,b; int *pointer_1,*pointer_2; scanf("%d,%d",&a,&b); pointer_1=&a;pointer_2=&b; if(a<b) swap(pointer_1,pointer_2); printf("\n%d,%d\n",*pointer_1,*pointer_2); } 这是代码2。 ``` #include<stdio.h> int s(int a,int b) { int temp; temp=a; a=b; b=temp; } main() { int a,b; a=3;b=4; s(a,b); printf("%d,%d",a,b); } 这是代码3。 下面的是我对这三个代码的理解 代码1和代码2的区别是,代码1指针地址不变,而指针地址里的内容发生了改变。代码2的地址里的内容不发生改变而是两个指针交换地址。 代码3没有指针只是一般的交换。 然后我就不理解了,如果说是形参在函数调用完毕就释放而且没有return语句的话,主函数的值应当不发生改变。这样的话,代码1的主函数的实参数值交换没法解释。当然代码2和3按照这个逻辑是可以解释的。还有代码1的swap函数里的间接调用 和代码3的直接调用这样有区别吗?
关于链表节点,作为函数形参,*node和*&node的区别
关于链表节点,作为函数形参,*node和*&node的区别,*node不相当于是个指针变量吗?为什么还要加上&
声明函数时候,形参为什么有时候用指针对象,有时候使用普通类对象?
声明函数时候,形参为什么有时候用指针对象,有时候使用普通类对象?为什么不能像java都使用普通类对象?难道类对象作用不能实现到指针对象功能?比如代码如下: class A { } class B( public: B(A* aaa);//这里为什么不用A aaa去掉指针 //普通类传参有什么区别 B(A aaa); }
指针形参返回时并未更改实参的地址c++
如果使用指针作为形参,在对形参进行更改时,实参不是也应该同时更改吗,我这个方法为什么没有改变实参的地址? 我用引用形参得到的结果是正确的,所以,请教大神,这么做的误区![图片说明](https://img-ask.csdn.net/upload/201703/19/1489891030_175412.png)![图片说明](https://img-ask.csdn.net/upload/201703/19/1489891054_933267.png)
此函数的形参是个结构变量,而不是指针,所以给形参赋值可以修改实参的值吗?
根据KNking现代方法一书中所述,int big,small; max_min(&big,&small)以指向实参的指针作为参数才能改变实参的值(找最大最小数) 而以下程序片段以结构变量而非指针作为参数,调用后可以改变相应实参的值吗? void update(struct part inv[], int np) { int i, number, change; printf("Enter part number: ");    scanf("%d", &number); i = find_part(number, inv, np);    if (i >= 0) { printf("Enter change in quantity on hand: ");     scanf("%d", &change); inv[i].on_hand+=change;//给形参(一个结构变量的元素)赋值可以修改实参对应元素的值??? } else printf("Part not found.");
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语言,形参是指针的引用,和形参是指针,两者结果不同,求指点
自定义的头文件 ``` typedef struct BiTNode { int data; struct BiTNode *lchild, *rchild; }BiTNode, *BiTree; ``` 如下是使用形参是指针的引用的函数,结果是正确的 ``` #include "BiTree.h" #include "stdlib.h" #include "stdio.h" bool Delete(BiTree &p) { BiTree q = (BiTree)malloc(sizeof(BiTNode)); q = p; p = p->lchild; free(q); return true; } bool DeleteBST(BiTree &T, int key) { if (!T)return false; else if (key==T->data) { return Delete(T); } else if (key < T->data) { return DeleteBST(T->lchild, key); } } int main() { BiTree t1 = (BiTree)malloc(sizeof(BiTNode)); BiTree t2 = (BiTree)malloc(sizeof(BiTNode)); BiTree t3 = (BiTree)malloc(sizeof(BiTNode)); t1->data = 3; t2->data = 2; t3->data = 1; t1->lchild = t2; t1->rchild = NULL; t2->lchild = t3; t2->rchild = NULL; DeleteBST(t1, 2); printf("%d\n", t1->lchild->data); system("PAUSE"); return 0; } ``` 结果 ![图片说明](https://img-ask.csdn.net/upload/201605/26/1464229127_799521.png) 然后如下是形参为指针的,其实函数是一样的,只是形参从上面的接收指针的引用改为了接收指针 ``` #include "BiTree.h" #include "stdlib.h" #include "stdio.h" bool Delete(BiTree p) { BiTree q = (BiTree)malloc(sizeof(BiTNode)); q = p; p = p->lchild; free(q); return true; } bool DeleteBST(BiTree T, int key) { if (!T)return false; else if (key==T->data) { return Delete(T); } else if (key < T->data) { return DeleteBST(T->lchild, key); } } int main() { BiTree t1 = (BiTree)malloc(sizeof(BiTNode)); BiTree t2 = (BiTree)malloc(sizeof(BiTNode)); BiTree t3 = (BiTree)malloc(sizeof(BiTNode)); t1->data = 3; t2->data = 2; t3->data = 1; t1->lchild = t2; t1->rchild = NULL; t2->lchild = t3; t2->rchild = NULL; DeleteBST(t1, 2); printf("%d\n", t1->lchild->data); system("PAUSE"); return 0; } ``` 结果 ![图片说明](https://img-ask.csdn.net/upload/201605/26/1464229251_539966.png) 结果明显是有问题的,原因应该在free了第2个结点,却没把第一个结点的lchild改为指向第3个结点。可是为什么前一个(即接收指针的引用那个)却没问题呢?两个的区别仅仅在于接收的参数,可是前一个没问题而后一个出了问题。我想不明白前一个为什么会没出问题,求大神指点
C语言函数的形参(结构体类型)和实参类型(指针)可以不同吗?
int numstus; int lens; student *pointer; void main() { int i=1; char str[2]; lens=100; pointer=(student *)malloc(lens*LEN); /*分配内存*/ numstus=0; welcome(); /*欢迎界面*/ while(i>0) { i=menu_select(); /*控制菜单*/ switch(i) { case 1:addrecord(pointer);break; /*增加学生信息*/ 。。。省略 而当调用addrecord函数的定义是 void addrecord(student stud[]) {...} pointer是个结构体指针 addrecord参数是 结构体类型 程序无错,传递可行 真是怎么回事
一个现成的二维数组,如何定义一个 指针的指针 来指向这个二维数组?
例:这样一个数组,想定义一个指针的指针,指向它。 int arr1[4][4] ={ {1,2,3,4}, {5,6,7,8}, {9,10,11,12}, {13,14,15,16} }; ps. 这个指针的指针 是 用来传递个函数的。 因为某种要求,需要向函数传递一个二维数组,函数的形参表中定义了 int **。 因此 这个指针的指针一定要能够传递函数,并且函数能够通过它操作二维数组元素。
该题目中c选项不明白,什么是类A对象呢
已知类A中的一个成员函数的说明如下:vodi Function(A &a);,则该函数的参数“A &a”的含义是( )。 A、指向A的指针为a B、将变量a的地址赋给类A C、类A对象引用a用作函数的形参 D、变量A与a按位与后做函数参数 已知答案选c ,但是不明白c什么意思
交换两个int指针形参类型为什么是int*&?
![图片说明](https://img-ask.csdn.net/upload/201610/27/1477564346_752167.png) 如图,想交换两个指针,为什么swap函数的形参要加上引用?把引用去了得到的结果不能交换?
c语言中函数形参为空指针,调用时可以不用带实参吗?
最近在看代码,有地方不太懂 void map_hash_init(void) { map_hash_head = hash_create ((uint32_t (*)(void *))(con_key), (int (*)(void *, void *))(Con_comp)); } 这是一个hash表的初始化 hash_creat的原型: hash_create (uint32_t (*hash_key) (), int32_t (*hash_cmp) ()) { return hash_create_size (HASHTABSIZE, hash_key, hash_cmp); } con_key函数: uint32_t con_key(void *data) { uint32_t key; T_ConnectionId *pData = (T_ConnectionId *)data; key = ((pData->srcNeId + pData->tunnelId) * HASHNUM + (pData->desNeId + pData->lspId)) % HASHTABSIZE; return key; } 为什么在hash初始化的时候,直接(uint32_t (*)(void *))(con_key)就可以?con_key不是要带实参的吗?
C语言关于指针的一个编程
Exercise 6-1 已给程序: • statistics.h • my_pointerFun.h 需要完成并提交的程序: • statistics.c • my_pointerFun.c • my_pointerFun.h • main.c • 1. 完成函数my_pointerFun(顾名思义,指针函数),该函数需有两个整型参数(x and y )且没有返回值. 要求完成的功能在my_pointerFun.h有详细描述。注意在文件头需进行正确的函数声明。 2.按照statistics.h 中的要求完成statistics.c文件 3. 写出测试程序main.c以测试你的程序是否正确。 注意: • my_pointerFun部分占成绩的20%,main 部分占%10, statistics 部分占70%。 • 这里考察的是将指针作为函数参数问题。 • my_pointerFun.h #ifndef _POINTERFUN_H #define _POINTERFUN_H /** Set values by pointers * If param x and y point to the same variable, output value 1 + 2 to it, otherwise: * param x pass-by-pointer: output value 1 * param y pass-by-pointer: output value 2 **/ //注意此处的output并不是输出到屏幕上, 而是对函数而言,函数通过形参可以进行输入, 也可以通过形参返回值(输出) void my_pointerFun( double* x, double* y); #endif • statistics.h #ifndef C_STATISTICS_H #define C_STATISTICS_H #include <stddef.h> /** Read doubles from stdin and calculate statistics of them. * Reading terminates after enough values have been read or when reading a value fails. * If no values are read, nothing is returned via min/max. * param count pass-by-pointer: input max amount of values to read, output actual count of values read, cannot be NULL * param min pass-by-pointer: input none, output min value, nothing if NULL * param max pass-by-pointer: input none, output max value, nothing if NULL * param sum pass-by-pointer: input old sum, output updated sum, nothing if NULL * return the last value read successfully (0.0 if no values were read) **/ double statistics(size_t* count, double* min, double* max, double* sum); #endif
Qt中的connect函数参数形式的区别
比如有个Qtimer类timer,一个QMwidget类Mwidget,widget定义了一个animate方法,那么有以下几种connect调用方式,且都测试可用: 第一种: ``` connect(timer,timer->timeout,Mwidget,Mwidget->animate); ``` 第二种: ``` connect(timer,&QTimer::timeout,widget,&QMwidget::animate); ``` 第三种: ``` connect(timer,QTimer::timeout,widget,QMwidget::animate); ``` 我觉得第一种和第三种比较好理解。connect的原型是 ``` connect(QObject* sender,const char* signal,QObject* receiver,const char* method); ``` 我的理解是因为对象并不保存类函数的代码,因此调用timer->timeout和Mwidget->animate都是调用的Qtimer类和QMwidget类的方法,也就是QTimer::timeout和QMwidget::animate。 但是第二种和第三种就有点不懂了,在类方法的前面加了&,因为QMwidget::animate本身表示函数名,也就是函数的指针,和形参类型相符。但是加&应该是函数指针的地址,但是也能使用,这是为什么呢?
C++中以数组指针为函数参数,为什么可以修改该数组指针的值?
* 刚学习C++,对立面的指针作为参数,有点不明白。 * 按照C++函数参数传递的说法,在调用函数时,将实参赋值,传递赋值的值给形参,就是值传递,那么在函数内改变参数的值,不影响实参的值。 * 比如在下面代码的第一段,把两个指向整数的指针传递给void sort(int* pint1, * int* pint2); 在sort(...)函数中调换两个指针的地址,但是不会改变实参的值。(这段和上一段是一行) * 但是如果把数组数组作为参数,如下面代码第二段,在函数void sort(int* pintA[]);中调换前两个元素的值,实参也随之改变。这是为什么呢? 这个例子里,指针数组实际上就是指针的数组,当这个数组作为参数传递给形参是,理论上也应该是赋值一个样本,然后改变其中两个元素的地址,改变的也应该是形参的地址,不会影响到实参啊。 这个问题实在想不明白,如果知道,还请指点一下,十分感谢!!!! ``` int int1 = 11; int int2 = 22; int* pint1 = &int1; //第一段,将指针作为参数 int* pint2 = &int2; cout<<endl <<"*pint1:"<<*pint1<<endl <<"*pint2:"<<*pint2<<endl; void sort(int* pint1, int* pint2); //交换两个指针指向的地址 sort(pint1,pint2); cout<<"After sort:" <<endl <<"*pint1:"<<*pint1<<endl <<"*pint2:"<<*pint2<<endl; int* pintArray[] = {&int1,&int2}; //第二段,把指针数组作为参数 cout<<endl <<"*pintArray[0]:"<<*pintArray[0]<<endl <<"*pintArray[1]:"<<*pintArray[1]<<endl; void sort(int* pintA[]); //交换第0、1两个元素的地址 sort(pintArray); cout<<"After sort:" <<endl <<"*pintArray[0]:"<<*pintArray[0]<<endl <<"*pintArray[1]:"<<*pintArray[1]<<endl; ``` ![图片说明](https://img-ask.csdn.net/upload/201606/22/1466610095_659964.png)
c++语言出栈Pop函数调用时参数&e为什么跟定义时形参不一样,形参是指针啊
函数声明: void Pop(SqStack*s, char* e) { if (s->top == s->base)return; *e = *--(s->top); } 调用: char e; Pop(&s,&e);
我想用指针作为函数形参,实参为数组 实现数组元素反序存放。可是只能交换前五个
#include<iostream> using namespace std; void invert(int *A,int); int main() { int A[10],n; cout<<"Please input 10 number:"<<endl; for(n=0;n<10;n++) cin>>A[n]; invert(A,10); return 0; } void invert(int *A,int n) { int temp,j; for(n=0,j=9;n<5;n++,A++) {temp=*A;*A=*(A+j);*(A+j)=temp;j=j-2;} for(n=0;n<10;n++) cout<<A[n]<<'\t'; cout<<endl; }![图片说明](https://img-ask.csdn.net/upload/201511/28/1448714703_809989.png)
int A, int &A, int *A作为函数参数的区别?
请问: int fun(int A) int fun(int &A) Int fun(int *A) 其中 A的区别 有答 int A 是定义一个整形变量 int &A是定义一个存放整形变量的地址 一个传递的是值 函数对形参进行的操作不会影响实参 一个传递的是地址 可以通过函数对地址指向的变量进行修改 int *A比较清楚,我在函数中,A可以作为一个int指针,*p可以作为一个数值调用 那么 int fun(int &A) &A是个什么东西,感觉和*p是一样的
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
【JSON解析】浅谈JSONObject的使用
简介 在程序开发过程中,在参数传递,函数返回值等方面,越来越多的使用JSON。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,同时也易于机器解析和生成、易于理解、阅读和撰写,而且Json采用完全独立于语言的文本格式,这使得Json成为理想的数据交换语言。 JSON建构于两种结构: “名称/值”对的集合(A Collection of name/va...
《MySQL 性能优化》之理解 MySQL 体系结构
本文介绍 MySQL 的体系结构,包括物理结构、逻辑结构以及插件式存储引擎。
程序员请照顾好自己,周末病魔差点一套带走我。
程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。
卸载 x 雷某度!GitHub 标星 1.5w+,从此我只用这款全能高速下载工具!
作者 | Rocky0429 来源 | Python空间 大家好,我是 Rocky0429,一个喜欢在网上收集各种资源的蒟蒻… 网上资源眼花缭乱,下载的方式也同样千奇百怪,比如 BT 下载,磁力链接,网盘资源等等等等,下个资源可真不容易,不一样的方式要用不同的下载软件,因此某比较有名的 x 雷和某度网盘成了我经常使用的工具。 作为一个没有钱的穷鬼,某度网盘几十 kb 的下载速度让我...
只因接了一个电话,程序员被骗 30 万!
今天想给大家说一个刚刚发生在我身边的一起真实的诈骗经历,我的朋友因此被骗走30万。注:为了保护当事人隐私,部分情节进行了修改。1平安夜突来的电话开始以为就像普通的诈骗一样,想办法让你把钱...
我一个37岁的程序员朋友
周末了,人一旦没有点事情干,心里就瞎想,而且跟几个老男人坐在一起,更容易瞎想,我自己现在也是 30 岁了,也是无时无刻在担心自己的职业生涯,担心丢掉工作没有收入,担心身体机能下降,担心突...
python自动下载图片
近日闲来无事,总有一种无形的力量萦绕在朕身边,让朕精神涣散,昏昏欲睡。 可是,像朕这么有职业操守的社畜怎么能在上班期间睡瞌睡呢,我不禁陷入了沉思。。。。 突然旁边的IOS同事问:‘嘿,兄弟,我发现一个网站的图片很有意思啊,能不能帮我保存下来提升我的开发灵感?’ 作为一个坚强的社畜怎么能说自己不行呢,当时朕就不假思索的答应:‘oh, It’s simple. Wait for me for a ...
一名大专同学的四个问题
【前言】   收到一封来信,赶上各种事情拖了几日,利用今天要放下工作的时机,做个回复。   2020年到了,就以这一封信,作为开年标志吧。 【正文】   您好,我是一名现在有很多困惑的大二学生。有一些问题想要向您请教。   先说一下我的基本情况,高考失利,不想复读,来到广州一所大专读计算机应用技术专业。学校是偏艺术类的,计算机专业没有实验室更不用说工作室了。而且学校的学风也不好。但我很想在计算机领...
复习一周,京东+百度一面,不小心都拿了Offer
京东和百度一面都问了啥,面试官百般刁难,可惜我全会。
Java 14 都快来了,为什么还有这么多人固守Java 8?
从Java 9开始,Java版本的发布就让人眼花缭乱了。每隔6个月,都会冒出一个新版本出来,Java 10 , Java 11, Java 12, Java 13, 到2020年3月份,...
达摩院十大科技趋势发布:2020 非同小可!
【CSDN编者按】1月2日,阿里巴巴发布《达摩院2020十大科技趋势》,十大科技趋势分别是:人工智能从感知智能向认知智能演进;计算存储一体化突破AI算力瓶颈;工业互联网的超融合;机器间大规模协作成为可能;模块化降低芯片设计门槛;规模化生产级区块链应用将走入大众;量子计算进入攻坚期;新材料推动半导体器件革新;保护数据隐私的AI技术将加速落地;云成为IT技术创新的中心 。 新的画卷,正在徐徐展开。...
轻松搭建基于 SpringBoot + Vue 的 Web 商城应用
首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行用户代码,而用户只需根据实际代码运行所消耗的资源进行付费。Fun: Fun 是一个用于支持 Serverless 应用部署的工具,能帮助您便捷地管理函数计算、API ...
Python+OpenCV实时图像处理
目录 1、导入库文件 2、设计GUI 3、调用摄像头 4、实时图像处理 4.1、阈值二值化 4.2、边缘检测 4.3、轮廓检测 4.4、高斯滤波 4.5、色彩转换 4.6、调节对比度 5、退出系统 初学OpenCV图像处理的小伙伴肯定对什么高斯函数、滤波处理、阈值二值化等特性非常头疼,这里给各位分享一个小项目,可通过摄像头实时动态查看各类图像处理的特点,也可对各位调参、测试...
2020年一线城市程序员工资大调查
人才需求 一线城市共发布岗位38115个,招聘120827人。 其中 beijing 22805 guangzhou 25081 shanghai 39614 shenzhen 33327 工资分布 2020年中国一线城市程序员的平均工资为16285元,工资中位数为14583元,其中95%的人的工资位于5000到20000元之间。 和往年数据比较: yea...
为什么猝死的都是程序员,基本上不见产品经理猝死呢?
相信大家时不时听到程序员猝死的消息,但是基本上听不到产品经理猝死的消息,这是为什么呢? 我们先百度搜一下:程序员猝死,出现将近700多万条搜索结果: 搜索一下:产品经理猝死,只有400万条的搜索结果,从搜索结果数量上来看,程序员猝死的搜索结果就比产品经理猝死的搜索结果高了一倍,而且从下图可以看到,首页里面的五条搜索结果,其实只有两条才是符合条件。 所以程序员猝死的概率真的比产品经理大,并不是错...
害怕面试被问HashMap?这一篇就搞定了!
声明:本文以jdk1.8为主! 搞定HashMap 作为一个Java从业者,面试的时候肯定会被问到过HashMap,因为对于HashMap来说,可以说是Java集合中的精髓了,如果你觉得自己对它掌握的还不够好,我想今天这篇文章会非常适合你,至少,看了今天这篇文章,以后不怕面试被问HashMap了 其实在我学习HashMap的过程中,我个人觉得HashMap还是挺复杂的,如果真的想把它搞得明明白...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
推荐10个堪称神器的学习网站
每天都会收到很多读者的私信,问我:“二哥,有什么推荐的学习网站吗?最近很浮躁,手头的一些网站都看烦了,想看看二哥这里有什么新鲜货。” 今天一早做了个恶梦,梦到被老板辞退了。虽然说在我们公司,只有我辞退老板的份,没有老板辞退我这一说,但是还是被吓得 4 点多都起来了。(主要是因为我掌握着公司所有的核心源码,哈哈哈) 既然 4 点多起来,就得好好利用起来。于是我就挑选了 10 个堪称神器的学习网站,推...
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了????,这可都是提升你幸福感的高效率生产力工具哦! 走起!???? NO、1 ScreenToGif 屏幕,摄像头和白板...
阿里面试,面试官没想到一个ArrayList,我都能跟他扯半小时
我是真的没想到,面试官会这样问我ArrayList。
曾经优秀的人,怎么就突然不优秀了。
职场上有很多辛酸事,很多合伙人出局的故事,很多技术骨干被裁员的故事。说来模板都类似,曾经是名校毕业,曾经是优秀员工,曾经被领导表扬,曾经业绩突出,然而突然有一天,因为种种原因,被裁员了,...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
良心推荐,我珍藏的一些Chrome插件
上次搬家的时候,发了一个朋友圈,附带的照片中不小心暴露了自己的 Chrome 浏览器插件之多,于是就有小伙伴评论说分享一下我觉得还不错的浏览器插件。 我下面就把我日常工作和学习中经常用到的一些 Chrome 浏览器插件分享给大家,随便一个都能提高你的“生活品质”和工作效率。 Markdown Here Markdown Here 可以让你更愉快的写邮件,由于支持 Markdown 直接转电子邮...
看完这篇HTTP,跟面试官扯皮就没问题了
我是一名程序员,我的主要编程语言是 Java,我更是一名 Web 开发人员,所以我必须要了解 HTTP,所以本篇文章就来带你从 HTTP 入门到进阶,看完让你有一种恍然大悟、醍醐灌顶的感觉。 最初在有网络之前,我们的电脑都是单机的,单机系统是孤立的,我还记得 05 年前那会儿家里有个电脑,想打电脑游戏还得两个人在一个电脑上玩儿,及其不方便。我就想为什么家里人不让上网,我的同学 xxx 家里有网,每...
史上最全的IDEA快捷键总结
现在Idea成了主流开发工具,这篇博客对其使用的快捷键做了总结,希望对大家的开发工作有所帮助。
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
谁是华为扫地僧?
是的,华为也有扫地僧!2020年2月11-12日,“养在深闺人不知”的华为2012实验室扫地僧们,将在华为开发者大会2020(Cloud)上,和大家见面。到时,你可以和扫地僧们,吃一个洋...
Idea 中最常用的10款插件(提高开发效率),一定要学会使用!
学习使用一些插件,可以提高开发效率。对于我们开发人员很有帮助。这篇博客介绍了开发中使用的插件。
AI 没让人类失业,搞 AI 的人先失业了
最近和几个 AI 领域的大佬闲聊 根据他们讲的消息和段子 改编出下面这个故事 如有雷同 都是巧合 1. 老王创业失败,被限制高消费 “这里写我跑路的消息实在太夸张了。” 王葱葱哼笑一下,把消息分享给群里。 阿杰也看了消息,笑了笑。在座几位也都笑了。 王葱葱是个有名的人物,21岁那年以全额奖学金进入 KMU 攻读人工智能博士,累计发表论文 40 余篇,个人技术博客更是成为深度学习领域内风向标。 ...
立即提问