Windows系统下,c语言、c++语言中的给变量赋值,也是最终通过API实现的吗? 10C

①例如程序中有一个赋值语句 a=100; 程序执行时,也是转化为调用系统API来将变量a所代表的存储区域赋值100吗?
②对于程序,即是在程序中没有直接使用Windows API ,例如,main函数只包括printf,即只是使用 printf 输出一个内容时,那么程序执行时,也是最终调用系统API来完成输出的吗?

③Windows API是不是可以这样理解:像scanf printf等是建立在API函数的基础上的,是封装了API函数的集合,换句话说,是别人为了方便而写的一些常用的功能,但是如果有自己的特定需求,就需要自己在代码中直接调用API函数?即printf是别人从Windows几万个API函数中找了一些函数,组装成了 printf,而我在程序中调用API是我自己直接使用API函数,组装printf使用的API函数与我可以直接调用的API函数没有什么特别之处,都是这几万个API函数 ——这样理解API对吗

8个回答

(1)
当然不是,直接cpu拷贝值。
具体来说就是
mov ptr[变量a的地址], 100
(2)(3)
api是几个动态链接库的函数库。和你自己定义一个函数其实没有什么区别。scanf printf是c的函数库中的函数,它们在底层调用不同的操作系统调用,对于windows来说,就是api函数。
有自己的特定需求,就需要自己在代码中直接调用API函数。前提是api函数中有这个需求的函数调用。
windows api是面向操作系统的,比如读写文件、输出控制台、创建用户界面,这些api有函数。但是你说,你要写一个算圆周率的,api函数也没有,还得自己写。api函数不是万能的。

如果问题解决,麻烦点下回答右边的采纳,谢谢

api 就是功能接口的意思。你要是做了一个很牛逼的模块,专门实现某方面的一系列功能(比如抓取某个网站,或者任何矩阵计算),
然后要让别人用你的模块,你就要定义好几个 api 函数,用户只要通过调用这些 api 函数,就能完成这类事情。调用 api 的时候,
一般会涉及资源分配啥的,总之一般不是很简单的操作。而你说的赋值(内存读写),或者简单的加减乘除,这些都是很原子级的操作。
任何 api 函数最终无非都是由一系列运算或者内存读写构成,而不是赋值由 api 构成……

api是几个动态链接库的函数库。和你自己定义一个函数其实没有什么区别。scanf printf是c的函数库中的函数,它们在底层调用不同的操作系统调用,对于windows来说,就是api函数。

Windows API是不是可以这样理解:像scanf printf等是建立在API函数的基础上的,是封装了API函数的集合,换句话说,是别人为了方便而写的一些常用的功能,但是如果有自己的特定需求,就需要自己在代码中直接调用API函数?即printf是别人从Windows几万个API函数中找了一些函数,组装成了 printf,而我在程序中调用API是我自己直接使用API函数,组装printf使用的API函数与我可以直接调用的API函数没有什么特别之处,都是这几万个API函数 ——这样理解API对吗

任何语言的赋值都是用寄存器和汇编语言进行的,通过汇编指令MOV编写赋值语句MOV ax,bx,给变量赋值。你了解下汇编语言和计算机组成原理就会明白了,至于API,它的全称是Application Programming Interface,翻译过来就是应用程序编程接口,和语言的底层无关

只要在程序中你没调用windows api 编译执行的时候就不会用到。

不会用到,楼上已经解释的很清楚了,

程序中没调用Windows API编译执行的时候不会用到,这么想吧,c/c++可以用在linux系统,而如果你的系统里没有api库(因为不是Windows,所以没有Windows库),printf等就没有用了吗?所以说是不会用到api的

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Windows系统下,c语言、c++语言中的给变量赋值,也是最终通过API实现的吗?
①例如程序中有一个赋值语句 a=100; 程序执行时,也是转化为调用系统API来将变量a所代表的存储区域赋值100吗? ②对于程序,即是在程序中没有直接使用Windows API ,例如,main函数只包括printf,即只是使用 printf 输出一个内容时,那么程序执行时,也是最终调用系统API来完成输出的吗? ③Windows API是不是可以这样理解:像scanf printf等是建立在API函数的基础上的,是封装了API函数的集合,换句话说,是别人为了方便而写的一些常用的功能,但是如果有自己的特定需求,就需要自己在代码中直接调用API函数?即printf是别人从Windows几万个API函数中找了一些函数,组装成了 printf,而我在程序中调用API是我自己直接使用API函数,组装printf使用的API函数与我可以直接调用的API函数没有什么特别之处,都是这几万个API函数 ——这样理解API对吗
c语言数据变量赋值类型
假定有一个程序,它把一个long整型变量赋值给一个short整型变量。当你编译程序的时候会发生什么情况?当你运行程序时会发生什么情况?你认为其他编译器的结果是否也是如此?
c语言的声明变量和赋值问题
c语言下声明的 sec和min 是秒和分钟,这两个申明是本身就有它的数值吗,为什么没有看到给他们赋值,初学,指教一下
变量赋值的底层实现。
C语言中,相同类型的变量赋值底层是怎么实现的比如: int a=3; int b; b=a; 内存操作的实现
c语言指针变量赋值左值右值得问题
c和指针一书提到了 左值与右值 , 左值是地址 右值是变量内容,如下的代码 第三行与第四行 中, 第三行 *cp 左值代表的是指针cp 指向的地址 ,赋值ch变量对应的地址,但是第四行同样是*cp作为左值 ,但是 为什么这里如果赋值&ch2就会编译错误呢,为什么*cp 同样作为左值,赋值给字符的地址,第三行通过,第四行 就会报错呢? 再加一句啊,*cp是指针指向的内容那个,所以需要用变量的内容来赋值,这个我也是一直这么来理解的,没问题,我更想知道的是书中所说的左右值问题,左值都是代表地址, 右值代表的是变量的值,而且c和指针一书说到*cp时也是说 作为左值时代表的是指向内容的地址,而作为右值时,代表的是指向的内容,是否可以理解为这句话只是在声明指针变量时有效? 如果在后面使用的时候 无论*cp 作为左值还是右值代表的都是指向的内容? char ch='a'; char ch2='b'; char *cp=&ch; *cp=ch2;
C语言新手在指针(数组)方面遇到的一些问题
![图片说明](https://img-ask.csdn.net/upload/202002/15/1581765888_977519.png) 在主函数中对一个数组赋值可以这样操作:a[10]={0,0,0,0,0,0,0,0,0,0}; 但为什么在int *get(int *p,int *b, int n)函数中无法这样直接赋值(会显示初始值设置项值太多),是不是因为*b这个指针变量只能存放数组的首地址。 但如果是这个原因的话,为什么用for循环的方法却可以正常赋值,for循环方法不也是在数组中赋值吗
C语言全局变量和静态全局变量和局部变量和静态局部变量在初始化和未初始化时生存期和作用域的具体情况怎么样?
最近看《C程序设计》第五版唐浩强著对静态局部变量有这样一段: > 对静态局部变量是在编译时赋初值的,即只赋初值一次,在程序运行时它已有初值。以后每次调用函数时不再重新赋初值而只是保留上次函数调用结束时的值。 >如果在定义局部变量时不赋初值的话,则对静态局部变量来说,编译时自动赋初植 0(对数值型交量)或空字符'\0'(对字符变量)。 这里讲静态局部变量在编译赋初值,没有初值自动赋初植 0(对数值型交量)或空字符'\0'(对字符变量)。应该是在编译就分配了空间 在对生存期和作用域解释时又有这样的例子,如图 ![图片说明](https://img-ask.csdn.net/upload/201909/15/1568503873_431314.jpg) 这里讲静态局部变量c的生存期从它所在的函数开始,书上讲“如果一个变量值在某一时刻是存在的,则认为这一时刻属于该变量的生存期,获称该变量在此时刻“存在”“,似乎是说这个静态局部变量从它所在的函数开始才开始在内存分配空间。 是不是赋初值和在内存开辟空间是两个过程,网上有些东西好像是这个意思。还有对全局变量是不是也是编译赋初值?没有初值是不是自动给它赋值(网上好像有这么讲的),那什么时候在内存开辟空间呢(这个图上的生存期从main函数就开始)? 这些可能涉及计算机组成原理,我没学过,希望哪位高手能详细解释下,万分感谢!!!
C语言char类型变量为什么赋值中文输出乱码?
char类型变量a声明后直接赋值,可以正常输出。 ![图片说明](https://img-ask.csdn.net/upload/201903/08/1552009333_832502.png) 然而这样赋值却会输出乱码。 ![图片说明](https://img-ask.csdn.net/upload/201903/08/1552009485_330651.png) 这是为什么?想了很久都没想通,是不是我代码写错了? 小白求教!
c语言,每次执行到给结构体内的二维数组成员变量赋值时程序就崩溃了,有大佬知道原因吗
结构体的声明 ``` struct IMPERIAL{ int **my_map; int numVar; void(*initialMap)(int **, int ); void(*clearMap)(int **, int ); }; void myInitialMap(int **my_map, int n) { my_map = (int **)malloc(sizeof(int*) * n); for(int i=0;i<n;++i){ my_map[i] = (int*)malloc(sizeof(int) * n); } int count=0; } void myClearMap(int **my_map, int n) { for(int i=0;i<=n;i++) free(*(my_map + i)); free(my_map); } ``` 初始化 ``` int node; char myInput[10]; for(int j=2;j<=item.numVar;j++) for(int i=1;i<j;i++){ scanf("%s",myInput); int b; if(myInput[0]!='x') { sscanf(myInput,"%d",&node); item.my_map[j][i]=node; item.my_map[i][j]=item.my_map[j][i]; } } ``` 每次一到 item.my_map[j][i]=node; 程序就崩溃了,不知道什么原因啊 编译过了,没有报错,执行到这一步程序就会直接卡住
C语言中的链表赋值问题
我写了一个存储电影名字以及评级的链表,不理解其中以下三点 1.prev->next=current, 2.prev=current, 3.current=current->next 我目前的理解是:1.把current这个结构体指针变量的地址赋值给prev中的结构体指针变量next;2.把current这个结构体指针变量的地址赋值给结构体指针变量prev;3.令结构体指针变量current的值等于结构体指针变量next的值 不知道对吗? 以下是我的源代码: #include<stdio.h> #include<stdlib.h> //malloc();原型 #include<string.h> //strcpy();原型 #define SIZE 20 //最大字数 typedef struct film { char title[SIZE]; int rating; struct film * next; }Film; int main() { Film *head=NULL; Film *prev,*current; char title2[SIZE]; //写入 puts("Scan first title(0-20 charecter)"); while(gets(title2)!=EOF&&title2[0]!='\0') { current = (Film *)malloc(sizeof(Film)); //存第一个指针head if(head==NULL) { head=current; } //current's address 赋给next else prev->next=current; strcpy(current->title,title2); puts("Rating is...(0-10)"); scanf("%d",&current->rating); getchar(); //节点更换 puts("Enter next movie title"); prev=current; } //显示 if(head) { current=head; while(current!=NULL) { printf("the title is %s,the rating is %d\n",current->title,current->rating); current=current->next; //把下一个结构体指针的地址给current } } else puts("Not find any dota..."); //清内存 current=head; while(current) { free(current); current=current->next; } puts("OK!"); return 0; } 十分感谢
被注释的地方如果给定义任何一个无关变量并赋值,程序的运算结果就不一样了,这是为什么?求赐教
被注释的地方如果给定义任何一个无关变量并赋值,程序的运算结果就不一样了,这是为什么? #include<stdio.h> main()//冒泡排序 { int a[5],i,t; printf("请输入五个数:\n"); for(i=0;i<5;i++) scanf("%d",&a[i]); for(int j=5;j>1;j--) { // int m=1; for(i=0;i<j;i++) { if(a[i]>a[i+1]) { t=a[i]; a[i]=a[i+1]; a[i+1]=t; } } } for(i=0;i<5;i++) printf(" %d",a[i]); } ![图片说明](https://img-ask.csdn.net/upload/201912/26/1577343525_128514.jpg)![图片说明](https://img-ask.csdn.net/upload/201912/26/1577343541_254902.jpg)
C语言,从文件中读取数据给结构体变量赋值,不知道哪里错了
#include <stdio.h> #include <stdlib.h> #include <string.h> struct student { int number; }num; int main() { struct student s1, *s2; s2 = &s1; FILE *fp = fopen("test.txt", "r"); fscanf(fp, "%d", s2->number); return 0; }![图片说明](https://img-ask.csdn.net/upload/201603/10/1457580600_112754.png)
C语言中结构体中的数组,不能直接赋值吗
设有定义:struct{char mark[12];intnum1;double num2;}t1,t2;若变量均已正确赋初值,则以下语句中错误的是(C) (A) t1=t2; (B) t2.num1=t1.num1; (C) t2.mark=t1.mark;//mark为结构体中的数组,不能直接赋值?? (D) t2.num2=t1.num2; ​====如题参考答案说为结构体中的数组,不能直接赋值,为什么呢?那应该怎么赋值呢?求大侠指教
关于MATLAB中if语句内赋值问题
目标:截取整个矩阵中指定部分并保存,指定坐标在.mat文件position中,矩阵名mat,坐标名pos。 问题:未定义函数或变量 'mat'。或者 引用了已清除变量'mat'。 ``` clear; clc; path = 'D:\Workspace\name'; mat_list = dir(path); mat_list(1:2)=[]; for para = 1:length(mat_list) if contain('mat', para) load(cat(2, path, '\', mat_list(para).name)); end end target = mat(pos(2):pos(2)+pos(4),pos(1):pos(1)+pos(3),:); save([path, '\', mat_list(para).name, 'Final.mat'], 'target'); ``` pos 是一个1*4的矩阵,里面的元素指定的位置按照代码中的逻辑运算后,就是需要截取另存为的部分。 上面就是代码大致逻辑。 但是这个代码不是说mat未定义就是说mat已清除。。 查了一天的百度也没查到,看提示似乎是因为if函数内赋值和加载文件都是局部变量 然后我百度怎么局部转全局,结果只有global函数,如果可以赋值变量就可以,但是我有两个需要加载的.mat文件。。找不到办法赋值 有没有老师教教我这关怎么过。
C#中如何构造一个兼容多种参数类型的类用以传递不同类型的消息?
大家好!设有一个类Hero,现在需在多个不同的Hero实例之间传递消息,为此我的实现方式是:为Hero实现1个专门接收消息的方法OnMessage(),并定义1个专门携带消息的类Telegram。当A要向B发送消息时,把消息内容写在Telegram中,并调用B.OnMessage(Telegram)进行消息传递。 **现在遇到的困难是:当可能发送的消息内容包含多种变量类型(例如,可能是int、string、List<string>、string数组等)时,如何编写代码使得程序更简洁?** 具体请看我目前的实现(代码不够简洁): 1、首先在Hero类中,增加专门接收并处理消息的方法OnMessage() ``` class Hero() { public void OnMessage(Telegram t)//t携带了具体的消息,详见下文 { //t.index标识了应该调用哪个方法处理这条消息,例如: switch(t.index) { case 1: //方法1 case 2: //方法2 } } } ``` 2、其次,定义1个结构体Telegram,专门用来携带具体消息内容,它有2个成员变量:index(标识应调用哪个方法处理本消息)和info(携带具体消息内容) ``` struct Telegram { public int index;//用来标识应调用哪个方法处理本消息,每个index都对应着Hero类中一个具体的处理方法 //注:由于不同的方法对应的参数类型是不同的,例如,方法1的参数是int、方法2的参数是string、方法3的参数是string数组……,所以我的实现方式比较繁琐,如下 public int info_int;//当这条消息打算发给方法1进行处理时,把消息内容赋值给这个变量,其他的info变量不赋值 public string info_string;//当这条消息打算发给方法2进行处理时,把消息内容赋值给这个变量,其他的info变量不赋值 public string[] info_stringArray;//当这条消息打算发给方法3进行处理时,把消息内容赋值给这个变量,其他的info变量不赋值 } ``` 3、因此,OnMessage()的内容实际上是这样的: ``` class Hero() { public void OnMessage(Telegram t) { switch(t.index) { case 1://调用方法1,且参数类型为int func1(t.info_int); break; case 2://调用方法2,且参数类型为string func2(t.info_string); break; case 3://调用方法3,且参数类型为string数组 func3(t.info_stringArray); break; default: } } } ``` **情况描述完毕了,主要想请教的就是:以上Telegram中几个不同的info变量,能否统一成1个变量?** ``` //期望能做到这样的效果: class Hero() { public void OnMessage(Telegram t) { switch(t.index) { case 1: func1(t.info);//该方法的输入参数为int,而且会把t.info当做int进行处理 break; case 2: func2(t.info);//该方法的输入参数为string,而且会把t.info当做string进行处理 break; case 3: func3(t.info);//该方法的输入参数为string数组,而且会把t.info当做string数组进行处理 break; default: } } } ``` 对了,截至目前为止我尝试的思路有以下几种,在此列出也是希望大家能帮忙指点一下(尤其是思路2和思路3是否可行),十分感谢: 1、将info定义为Object,赋值、传参时全部以Object进行操作。但存在问题是:反复的装箱、拆箱操作影响效率(程序运行时消息传递非常频繁)。因此该方案放弃了。 2、将info定义为自定义格式文本或json,传参之后再自行解析。但这块我还没有深入学习,此外担心json转换过程中是否存在类似于Object装箱拆箱影响效率的问题? 3、利用C#的泛型。但这块我学习的也不足,目前的尝试仍然失败了,如下所示 (3.1)定义1个泛型类MsgInfo<T> ``` public class MsgInfo<T> { public T obj; public MsgInfo(T objInput) { this.obj = objInput; } } ``` (3.2)在Telegram中使用它,结果出错了 ``` struct Telegram { public int index; public MsgInfo<T> info;//注:此处是会报错的,因为泛型类在实例化时必须制定变量类型,因此这里是不能写T的,只能写int、string等等 } ``` 由于没有余额了,无法发起悬赏,非常抱歉~
这是关于C语言调试的问题
![图片说明](https://img-ask.csdn.net/upload/201910/13/1570981043_338554.png) 我用F10调试,想看一些变量的值。结果就比较奇怪,比如,我发的那个图,第一个变量有字符串和他的阿斯卡码了。第一呢,我没给这个变量赋值,第二呢,这个是字符型的,显示整数型的阿斯卡码干嘛呢,第三呢,感觉同时显示这两个,没有必要。第二个变量,整数型的,我想看看他的整数值,他竟然给个地址,神奇了。(PS 截取的图已经是全部代码了)
getchar()函数中对回车符的一些疑问
![图片说明](https://img-ask.csdn.net/upload/202002/15/1581766559_268565.png) 在主函数中对一个数组赋值可以这样操作:a[10]={0,0,0,0,0,0,0,0,0,0}; 但为什么在int *get(int *p,int *b, int n)函数中无法这样直接赋值(会显示初始值设置项值太多),是不是因为*b这个指针变量只能存放数组的首地址。 但如果是这个原因的话,为什么用for循环的方法却可以正常赋值,for循环方法不也是在数组中赋值吗
为什么调用函数参与运算再给变量赋值,数就不对了
求线性回归方程a和b值,结果明显不对 代码如下 #include <stdio.h> //调用库函数 int main() //主函数 { float aver(float a[],int); //声明求均值函数 float Temp_X[96] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1.46667, 11.4667, 31.6, 52.7333, 80.3333, 116.333, 156.6, 199.4, 242.2, 283.4, 329.2, 379.333, 431.333, 482.6, 541, 594.4, 643.533, 692.133, 736.267, 772.667, 810.133, 841.867, 868.2, 892.4, 917.667, 939.8, 954.667, 969, 976.8, 983.4, 987.467, 994.933, 1023.67, 875.2, 873.933, 758.8, 678.2, 515.867, 782.533, 908.8, 779.2, 831.4, 645.533, 734.067, 679.533, 610.267, 565.067, 512.467, 462, 405.2, 354.133, 302, 247.8, 191.533, 140, 94.2667, 57.5333, 25.9333, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; //定义初始化数组X float Temp_Y[96] = {0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 1.785, 2.57833, 3.927, 5.79233, 7.379, 9.48133, 11.1473, 12.4167, 13.6627, 16.193701, 18.248699, 19.042, 19.042, 19.105301, 16.6383, 17.240999, 14.631, 11.8217, 11.663, 12.155, 15.488, 21.859301, 19.32, 19.042, 19.6133, 21.105, 22.9937, 20.827299, 23.858299, 23.0333, 19.2883, 15.6937, 21.5893, 23.802999, 20.518299, 21.5893, 17.907301, 17.971001, 17.574301, 16.781, 15.5513, 12.3773, 10.2747, 8.60867, 6.86333, 5.39567, 3.88767, 2.856, 2.142, 2.142, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952 }; //定义初始化数组Y float a,b,sum1=0,sum2=0; //定义变量,a,b为线性回归方程y=ax+b中a,b的值,sum1,sum2,为求a时分步求解用的变量 int i,j; //i,j为循环时使用的变量 for(i=0;i<96;i++) { sum1+=(Temp_X[i]*Temp_Y[i]); sum2+=(Temp_X[i]*Temp_X[i]); } a=(sum1-96*aver(Temp_X,96)*aver(Temp_Y,96))/(sum2-96*aver(Temp_X,96)*aver(Temp_X,96)); //通过线性回归方程公式求出a值 b=aver(Temp_Y,96)-(a*aver(Temp_X,96)); printf("a=%f,b=%f",a,b); } float aver(float a[],int n) //求均值的函数 { //用for循环求出所有值的和,再除以个数n int i; float sum; for(i=0;i<n;i++) { sum+=a[i]; } return sum/n; //返回结果 }
这是一个关于C语言引用的问题
我想测试引用的用法,敲了以下代码 ``` int main() { /*List tou; InitList(tou); List shou; InitList(shou); */ int &a=1; int b=2; int &c=b; getch(); return 0; } ``` 编译后出现下面错误 --------------------Configuration: 线性表 - Win32 Debug-------------------- Compiling... 线性表.cpp E:\数据结构\线性表.cpp(46) : error C2440: 'initializing' : cannot convert from 'const int' to 'int &' A reference that is not to 'const' cannot be bound to a non-lvalue Error executing cl.exe. 线性表.exe - 1 error(s), 0 warning(s) 我感觉非常奇怪的,首先这个转换错误出现一次,证明只有一次赋值出错。根据以往经验,我判断是&a=1出错。出错原因就是整型变量转化成引用整型,不合法。 &c=b也是整型变量转化成引用变量,为啥就合法了呢?
C语言BOOL变量是不是用枚举更好一些?
我是写单片机C语言程序的。 我看一般定义BOOL是: typedef unsigned int BOOL; #define TRUE 1 #define FALSE 0 我自己一般是用枚举定义BOOL: typedef enum{ FALSE; TRUE; } BOOL; 实际应用中两者没发现啥区别,都是 BOOL flag=TRUE; 我自己感觉用枚举的更好一些,能够避免对BOOL变量赋值时出现FALSE和TRUE以外的数值,因为是枚举嘛,会报错,能够提醒程序员。 想看看大家意见,枚举的这种方法有没有我没想到的隐患?为啥VC6这些大平台都不用这种呢?
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
【搞定 Java 并发面试】面试最常问的 Java 并发基础常见面试题总结!
本文为 SnailClimb 的原创,目前已经收录自我开源的 JavaGuide 中(61.5 k Star!【Java学习 面试指南】 一份涵盖大部分Java程序员所需要掌握的核心知识。欢迎 Star!)。 另外推荐一篇原创:终极推荐!可能是最适合你的Java学习路线 方法 网站 书籍推荐! Java 并发基础常见面试题总结 1. 什么是线程和进程? 1.1. 何为进程? 进程是程...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
shell脚本:备份数据库、代码上线
备份MySQL数据库 场景: 一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求: 1)每天备份一次,需要备份所有的库 2)把备份数据存放到/data/backup/下 3)备份文件名称格式示例:dbname-2019-11-23.sql 4)需要对1天以前的所有sql文件压缩,格式为gzip 5)本地数据保留1周 6)需要把备份的数据同步到远程备份中心,假如...
iOS Bug 太多,苹果终于坐不住了!
开源的 Android 和闭源的 iOS,作为用户的你,更偏向哪一个呢? 整理 | 屠敏 出品 | CSDN(ID:CSDNnews) 毋庸置疑,当前移动设备操作系统市场中,Android 和 iOS 作为两大阵营,在相互竞争的同时不断演进。不过一直以来,开源的 Android 吸引了无数的手机厂商涌入其中,为其生态带来了百花齐放的盛景,但和神秘且闭源的 iOS 系统相比,不少网友...
神经⽹络可以计算任何函数的可视化证明
《Neural Networks and Deep Learning》读书笔记第四篇本章其实和前面章节的关联性不大,所以大可将本章作为小短文来阅读,当然基本的深度学习基础还是要有的。主要介绍了神经⽹络拥有的⼀种普遍性,比如说不管目标函数是怎样的,神经网络总是能够对任何可能的输入,其值(或者说近似值)是网络的输出,哪怕是多输入和多输出也是如此,我们大可直接得出一个结论:不论我们想要计算什么样的函数,...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
为什么你学不过动态规划?告别动态规划,谈谈我的经验
动态规划难吗?说实话,我觉得很难,特别是对于初学者来说,我当时入门动态规划的时候,是看 0-1 背包问题,当时真的是一脸懵逼。后来,我遇到动态规划的题,看的懂答案,但就是自己不会做,不知道怎么下手。就像做递归的题,看的懂答案,但下不了手,关于递归的,我之前也写过一篇套路的文章,如果对递归不大懂的,强烈建议看一看:为什么你学不会递归,告别递归,谈谈我的经验 对于动态规划,春招秋招时好多题都会用到动态...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
为什么要推荐大家学习字节码?
配套视频: 为什么推荐大家学习Java字节码 https://www.bilibili.com/video/av77600176/ 一、背景 本文主要探讨:为什么要学习 JVM 字节码? 可能很多人会觉得没必要,因为平时开发用不到,而且不学这个也没耽误学习。 但是这里分享一点感悟,即人总是根据自己已经掌握的知识和技能来解决问题的。 这里有个悖论,有时候你觉得有些技术没用恰恰是...
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
活到老,学到老,程序员也该如此
全文共2763字,预计学习时长8分钟 图片来源:Pixabay 此前,“网传阿里巴巴要求尽快实现P8全员35周岁以内”的消息闹得沸沸扬扬。虽然很快被阿里辟谣,但苍蝇不叮无缝的蛋,无蜜不招彩蝶蜂。消息从何而来?真相究竟怎样?我们无从而知。我们只知道一个事实:不知从何时开始,程序猿也被划在了“吃青春饭”行业之列。 饱受“996ICU”摧残后,好不容易“头秃了变强了”,即将步入为“高...
Vue快速实现通用表单验证
本文开篇第一句话,想引用鲁迅先生《祝福》里的一句话,那便是:“我真傻,真的,我单单知道后端整天都是CRUD,我没想到前端整天都是Form表单”。这句话要从哪里说起呢?大概要从最近半个月的“全栈工程师”说起。项目上需要做一个城市配载的功能,顾名思义,就是通过框选和拖拽的方式在地图上完成配载。博主选择了前后端分离的方式,在这个过程中发现:首先,只要有依赖jQuery的组件,譬如Kendoui,即使使用...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
【图解】记一次手撕算法面试:字节跳动的面试官把我四连击了
字节跳动这家公司,应该是所有秋招的公司中,对算法最重视的一个了,每次面试基本都会让你手撕算法,今天这篇文章就记录下当时被问到的几个算法题,并且每个算法题我都详细着给出了最优解,下面再现当时的面试场景。看完一定让你有所收获 一、小牛试刀:有效括号 大部分情况下,面试官都会问一个不怎么难的问题,不过你千万别太开心,因为这道题往往可以拓展出更多有难度的问题,或者一道题看起来很简单,但是给出最优解,确实很...
关于裁员几点看法及建议
最近网易裁员事件引起广泛关注,昨天网易针对此事,也发了声明,到底谁对谁错,孰是孰非?我们作为吃瓜观众实在是知之甚少,所以不敢妄下定论。身处软件开发这个行业,近一两年来,对...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
相关热词 c# 数组类型 泛型约束 c#的赛狗日程序 c# 传递数组 可变参数 c# 生成存储过程 c# list 补集 c#获得所有窗体 c# 当前秒数转成年月日 c#中的枚举 c# 计算校验和 连续随机数不重复c#
立即提问