c++ 多线程同步 互斥对象 输入输出流

#include

#include

using namespace std;

// 声明两个线程函数

DWORD WINAPI ThreadProc1(
LPVOID lpParameter // thread data

);

DWORD WINAPI ThreadProc2(
LPVOID lpParameter // thread data

);

// 全局票数

int gTicket = 100;

// 互斥对象

HANDLE hMutex;

int main()
{
// 创建两个线程句柄

HANDLE hThread1 = CreateThread(NULL, 0, ThreadProc1, NULL, 0, NULL);
HANDLE hThread2 = CreateThread(NULL, 0, ThreadProc2, NULL, 0, NULL);

// 创建互斥对象  
hMutex = CreateMutex(NULL, false, NULL); 

// 关闭两个线程句柄  
CloseHandle(hThread1); 
CloseHandle(hThread2); 

// 主线程睡4秒,方便两个线程函数能够获取CPU时间片  
Sleep(4000); 

system("pause"); 
return 0; 

}

// 定义两个线程函数

DWORD WINAPI ThreadProc1(LPVOID lpParameter )
{
while(true)
{
WaitForSingleObject(hMutex, INFINITE);
if(gTicket > 0)
{
cout<<"thread1 sell ticket "<<gTicket--<<endl;
}
else
{
break;
}
ReleaseMutex(hMutex);
}
return 0;
}

DWORD WINAPI ThreadProc2(LPVOID lpParameter )
{
while(true)
{
WaitForSingleObject(hMutex, INFINITE);
if(gTicket > 0)
{
cout<<"thread2 sell ticket "<<gTicket--<<endl;
}
else
{
break;
}
ReleaseMutex(hMutex);
}
return 0;
}
用断点调试,竟然发现了这样的问题。线程1的函数获取互斥对象的拥有权(并未释放拥有权),接着切换CPU时间片,进入到了线程2函数的WaitForSingleObject,然后调用了线程2函数的 cout<<"thread2 sell ticket "<<gTicket--<<endl;,这是怎么一回事呢,线程1函数还未释放拥有权,线程2函数怎么还能运行的?

使用互斥对象,显示的结果有时候会是这样。百思不得其解。

c++

2个回答

结果
既然对全局变量加锁了,为什么输入输出流还可以被打断??

输入输出流
1. 用控制符输出格式,例:
#include <iostream>
#include <iomanip>//利用控制符输出必须包含iomanip头文件
using namespace std;
int main()
{int a;
cout<<"input a:";
cin>>a;
cout&l......
答案就在这里:C++输入输出流
----------------------Hi,地球人,我是问答机器人小S,上面的内容就是我狂拽酷炫叼炸天的答案,除了赞同,你还有别的选择吗?

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
c++ 多线程同步 互斥对象 输入输出流
#include <iostream> #include <windows.h> using namespace std; // 声明两个线程函数 DWORD WINAPI ThreadProc1( LPVOID lpParameter // thread data ); DWORD WINAPI ThreadProc2( LPVOID lpParameter // thread data ); // 全局票数 int gTicket = 100; // 互斥对象 HANDLE hMutex; int main() { // 创建两个线程句柄 HANDLE hThread1 = CreateThread(NULL, 0, ThreadProc1, NULL, 0, NULL); HANDLE hThread2 = CreateThread(NULL, 0, ThreadProc2, NULL, 0, NULL); // 创建互斥对象 hMutex = CreateMutex(NULL, false, NULL); // 关闭两个线程句柄 CloseHandle(hThread1); CloseHandle(hThread2); // 主线程睡4秒,方便两个线程函数能够获取CPU时间片 Sleep(4000); system("pause"); return 0; } // 定义两个线程函数 DWORD WINAPI ThreadProc1(LPVOID lpParameter ) { while(true) { WaitForSingleObject(hMutex, INFINITE); if(gTicket > 0) { cout<<"thread1 sell ticket "<<gTicket--<<endl; } else { break; } ReleaseMutex(hMutex); } return 0; } DWORD WINAPI ThreadProc2(LPVOID lpParameter ) { while(true) { WaitForSingleObject(hMutex, INFINITE); if(gTicket > 0) { cout<<"thread2 sell ticket "<<gTicket--<<endl; } else { break; } ReleaseMutex(hMutex); } return 0; } 用断点调试,竟然发现了这样的问题。线程1的函数获取互斥对象的拥有权(并未释放拥有权),接着切换CPU时间片,进入到了线程2函数的WaitForSingleObject,然后调用了线程2函数的 cout<<"thread2 sell ticket "<<gTicket--<<endl;,这是怎么一回事呢,线程1函数还未释放拥有权,线程2函数怎么还能运行的? 使用互斥对象,显示的结果有时候会是这样。百思不得其解。
MFC多线程同步问题,互斥量
共享资源是一些类对象的MAP,每个对象(某设备实例)中有不同的互斥量同步不同的类变量(本意是防止多线程访问同一个对象),现在迷糊了,互斥量放在类里面是不是不当?是不是在访问对象的时候就加互斥量来的方便(对整个对象进行加锁 - 因为对整个类操作较多,这么做貌似锁太深了)?求大神帮助
多线程编程 互斥 同步问题
如题![图片说明](https://img-ask.csdn.net/upload/201509/16/1442407645_803703.jpg) 问题描述: 1、设计程序write,read线程,wirte线程从消息队列尾端tail写入,read线程从消息队列头部head读取。 2、当写线程执行效率非常快,会发生什么情况? 3、当读线程执行效率非常快,会发生什么情况?
互斥是不是一个系统级别的变量
同步跨进程的线程可以使用互斥对象,所以互斥对象是不是一个系统级别的变量,而不是属于单个进程空间的?
多线程同步方案同步选择
在WIN32的C++多线程开发中的生产消费使用的同步方案中,一般会采用 条件变量,来做为等待判断的条件。 我在网狐的工作线程中看见了一种新的使用方法: 工作线程使用 GetQueuedCompletionStatus 等待事件触发。 生产线程使用 PostQueuedCompletionStatus 产生消息,另 GetQueuedCompletionStatus 触发执行。 我在网络中找资料,并没有关于多线程 同步使用 IOCP 完型端口的案例。 都是使用信号量,互斥,临界,事件,性能上临界的性能相对较优,我看了网狐的实现方式,这种采用 IOCP的方法反而是最简单的。 问题来了: 使用IOCP 作为生产消费的实现方案,有什么优势或者相关的资料呢?国内网络找到的都是清一色的网络编程的异步I/O。
多线程真的比单线程执行效率高吗?
对于单核CPU下多线程程序在同一时间点都只能有一个线程运行,对于多核CPU可以实现真正的并发同步运行,这种说法正确吗? 另外在多线程的情况下使用互斥对象来实现线程同步,这样的话多线程程序的运行效率受影响吗?
每次导入一个命名空间,空间内的变量便会初始化一次嘛?
如题,当有多个文件引入同一个命名空间时,命名空间内定义的变量会在每一次引入时都初始化嘛 问题由来: 我在调试程序的时候发现,本应该只初始化一次的变量初始化了两次。。 调试表现为输出两句初始化 ![图片说明](https://img-ask.csdn.net/upload/202002/14/1581665931_915213.png) 这有悖我的程序意愿 程序文件列表 类文件 |--RRCSer.h |--RRCSer.cpp 主程序文件: |--main.cpp 程序的打印功能是使用一个我自定义的类CLogger来实现的,我将它定义于命名空间中 static CLogger s_logger;//全局静态日志器 问题: 我想要实现每次只有一个线程在打印消息,其他线程等待上一线程打印完毕再继续打印,我选择用互斥对象(定义为CLogger的成员变量)来实现这个功能。可调试过程中发现本应该只初始化一次的互斥对象,初始化了两次,实际调试窗口中,两个互斥对象的地址也不一样,导致主线程与子线程输出冲突(我暂时使用主线程先休眠一段时间的方法解决了这个问题) 问题输出: ![图片说明](https://img-ask.csdn.net/upload/202002/14/1581666481_781933.png) 进一步的调试,发现s_logger 对象被创建了两次,也就是说主线程与子线程用的两个互斥对象。。。导致两线程共同输出消息时的冲突。我的s_logger定义于RRCSer.h头文件里的命名空间中,并且这个命名空间被main.cpp和RRCSer.cpp引入,从而得出以上问题,再问问有什么推荐的方法可以解决这个问题 大致的代码如下(只提供出现问题的代码): RRCSer.h: ``` namespace Ser { class CLogger { public: CLogger(); ~CTestCLogger(); private: HANDLE m_mutex }; static CLogger s_logger; } ``` RRCSer.cpp ``` #include <RRCSer.h> using namespace Ser; CLogger::CLogger() { } CLogger::~CLogger() { } ``` main.cpp ``` #include "RRCSer.cpp" using namespace Ser; int main() { return 0; } ```
C/C++的互斥器Mutex是什么,求初步介绍
C/C++的互斥器Mutex是什么,求初步介绍: 今天重新看了EFFCETIVE C++,那个互斥器是什么东东,多线程编程怎么用?
多线程互斥失败的问题
请教一下各位,我有个地方需要多个线程排队访问某个资源的问题,我有个排队 对象 queue,他有两个函数queueIn(进队列),和queueOut(出队列), 为了简单起见我这里只用了两个线程去排队,queue里面有个mutex用于互斥,queueIn里面会去lock这个互斥量,queueOut会去unlock这个互斥量,程序启动 了以后两个线程会在自己的run函数(qt,其他的类似)里面去调用queue.queueIn()进行排队,因为有互斥量的存在按道理一个线程会lock成功,而另一个线程会阻塞在里面直到前一个线程调用queueOut释放掉互斥量,但是呢结果是这两个线程居然都lock互斥量成功了,都直接通过了这个阻塞函数,互斥量居然没起到他的作用,请教一下各位大神,这种情况该怎么处理,我就是想弄个阻塞队列,让多个线程阻塞在queueIn这里,等待上一个线程资源访问完成再依次序通过,但是在目前两个线程这种简单情况下互斥量是类成员,居然表现得像是函数的局部变量一样,没起到互斥作用,请帮助解决一下,谢谢
自己创建了一个互斥体对象 怎么把它删除掉 CloseHandle(hMutex)怎么删不了互斥体对象
HANDLE hMutex = OpenMutex(MUTEX_ALL_ACCESS, FALSE,__TEXT("我的互斥体对象")); if (hMutex == NULL) { CreateMutex(NULL, NULL, __TEXT("我的互斥体对象")); }
linux可以用互斥锁控制多个线程的执行顺序吗?如何实现?
假设有三个线程:1、2、3,各自打印A,B,C。 是否可以只用互斥锁就实现“ACBCACBC……”的打印输出? (不使用其他的线程同步方法)
利用互斥对象实现线程同步,并且将线程设计成一个类,但是报错了,作业。。。
源代码: #include <windows.h> #include <iostream> #include<stdio.h> using namespace std; int tickets=100; HANDLE hMutex; class MyThread { private: char name; HANDLE hThread; public: MyThread(char name2) { name=name2; hThread=CreateThread(NULL,0,FunProc,NULL,0,NULL); } DWORD WINAPI FunProc(LPVOID lpParameter) { while (true) { WaitForSingleObject(hMutex,INFINITE); if (tickets>0) { printf("%c:%d",name,tickets); tickets=tickets-1; } else { break; } ReleaseMutex(hMutex); } return 0; } ~MyThread() { CloseHandle(hThread); } }; void main(){ char x,y,z; hMutex=(HANDLE)CreateMutex(NULL,FALSE,NULL); MyThread thread_x(x); MyThread thread_y(y); MyThread thread_z(z); Sleep(5000); } 报错是这样的: error C3867: “MyThread::FunProc”: 函数调用缺少参数列表;请使用“&MyThread::FunProc”创建指向成员的指针
linux 多线程加互斥锁没用
程序执行结果: girl(0xb707fb70) withdraw 1000.000000 from Account 101 boy(0xb7880b70) withdraw 1000.000000 from Account 101 account balance:0.000000 几个程序如下: account.c程序源码: #include "account.h" #include <malloc.h> #include <assert.h> #include <string.h> //create Account Account* create_account(int code,double balance){ Account *a = (Account*)malloc(sizeof(Account)); assert(a !=NULL); a->code = code; a->balance = balance; //对互斥锁初始化 pthread_mutex_init(&a->mutex,NULL); return a; } //destroy Account void destroy_account(Account *a){ assert(a != NULL); pthread_mutex_destroy(&a->mutex); free(a); } //qu money double withdraw(Account *a,double amt){ assert(a != NULL); pthread_mutex_lock(&a->mutex); if(amt < 0 || amt > a->balance){ pthread_mutex_unlock(&a->mutex); return 0.0; } double balance = a->balance; sleep(1); balance -= amt; a->balance = balance; pthread_mutex_unlock(&a->mutex); return amt; } //cun money double deposit(Account *a,double amt){ assert(a !=NULL); pthread_mutex_lock(&a->mutex); if(amt < 0){ pthread_mutex_unlock(&a->mutex); return 0.0; } double balance = a->balance; sleep(1); balance += amt; a->balance = balance; pthread_mutex_unlock(&a->mutex); return amt; } //see money double get_balance(Account *a){ assert(a != NULL); pthread_mutex_lock(&a->mutex); double balance = a->balance; pthread_mutex_unlock(&a->mutex); return balance; } account.h头文件源码: #ifndef __ACCOUNT_H__ #define __ACCOUNT_H__ #include <pthread.h> typedef struct { int code; double balance; //定义互斥锁 pthread_mutex_t mutex; }Account; //create Account extern Account* create_account(int code,double balance); //destroy Account extern void destroy_account(Account *a); //qu money extern double withdraw(Account *a,double amt); //cun money extern double deposit(Account *a,double amt); //see money extern double get_account(Account *a); #endif 调用程序account-test.c源码: #include "account.h" #include <pthread.h> #include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct{ char name[20]; Account *account; double amt; }OperArg; //取款操作线程运行函数 void* withdraw_fn(void *arg){ OperArg *oa = (OperArg*)arg; double amt = withdraw(oa->account,oa->amt); printf("%8s(0x%lx) withdraw %f from Account %d\n",oa->name,pthread_self(), amt,oa->account->code); return (void*)0; } //存款线程运行函数 void* deposit_fn(void *arg){ OperArg *oa = (OperArg*)arg; double amt = deposit(oa->account,oa->amt); printf("%8s(0x%lx) deposit %f from Account %d\n",oa->name,pthread_self(), amt,oa->account->code); return (void*)0; } int main(void){ int err; pthread_t boy,girl; Account *a = create_account(101,10000); OperArg o1,o2; strcpy(o1.name,"boy"); o1.account = a; o1.amt = 1000; // OperArg o1 = {"boy",a,1000}; strcpy(o2.name,"girl"); o2.account = a; o2.amt = 1000; if((err = pthread_create(&boy,NULL,withdraw_fn,(void*)&o1)) != 0){ perror("pthread create error"); } if((err = pthread_create(&girl,NULL,withdraw_fn,(void*)&o2)) != 0){ perror("pthread create error"); } pthread_join(boy,NULL); pthread_join(girl,NULL); printf("account balance:%f\n",get_balance(a)); destroy_account(a); return 0; } 请问为什么互斥锁不起作用啊?怎么解决啊,多谢!
大学狗linux线程同步与互斥求助呀
#include <stdio.h> #include <pthread.h> #include <unistd.h> #define false 0 #define ture 1 int flag[2]; static int a = 1; int turn; void *p0(){ while (ture){ flag [0]=ture; //this means I want the critical section turn = 0;//this means i have the chance. while (flag[1]&&turn==0);//this is for busywaiting ,until the other is not intersted any more. a--;//I am in! flag[0]=false;//I am not interested any more. printf ("这是第一个线程a=%d\n",a);// not about critical section sleep(1);//I block } } void *p1(){ while (ture){ flag[1]=ture ; turn = 1; while (flag[0]&&turn==1); a++;//linjiequ flag[1]=false ; printf ("这是第二个线程a=%d\n",a); sleep(1);//other code } // result is the first thread a=o then second thread a=1 } int main(){ flag[0]=false; flag[1]=false; int err1,err2; pthread_t id1,id2; err1=pthread_create(&id2, NULL, p1, NULL); err2=pthread_create(&id1, NULL, p0, NULL);//while create system do not run the p0/p1 body. pthread_join( id2, NULL);//let id1 runs pthread_join( id1, NULL);//let id1 runs and main waits } 我不理解main里到底是怎么运行的,create了两个进程以后第一个join就让id2进程运行嘛,对应着让p1运行 所以这第一下应该就可以打出这是第二个进程a=2然后挂起再运行进程id1嘛,id1又打出这是第一个进程a=1 接着再id2 id1一直循环下去。但是编译运行的结果却是先打印 这是第一个进程a=0 然后是这是第二个进程a=1 然后循环下去 甚至把其中的一个join给//,结果也还是一样 可是不是应该有一个进程就得不到机会运行了吗?所以问题来了. 1 为什么是这个顺序? 2 为什么//一个join以后还是有两个进程运行
线程局部存储与线程互斥
关于线程局部存储,既然是为了保证各个线程有自己私有的全局变量和静态共享变量,那么它与线程同步机制(临界区、信号量、事件、互斥量)有什么关联呢? 望各路大侠参与讨论、指导!新申请的账号,没有积分,多海涵!
mfc界面的多线程并发访问,如何能够保证互斥?
我用timer的方法没秒钟调用一个函数,这个函数会访问界面上的一个编辑框中的内容,但是发现运行久了界面会出错,应该是多线程没有互斥引起的,怎么处理这个问题比较方便?
java 线程,同步,互斥问题
X类中有A,B两个方法,如何实现:同一线程、同一对象、同一时刻只能访问其中A,B一个;且不同对象能同时访问A或B。
C++中多线程使用临界区域进行互斥,造成死锁,百思不得其解求指点为啥会死锁
C++中多线程使用临界区域进行互斥,造成死锁,百思不得其解求指点为啥会死锁 ``` // 在主界面中显示提示信息 void CIOCPModel::_ShowMessage(const int column,const CString szFormat,...) { // 根据传入的参数格式化字符串 CString strMessage; va_list arglist; // 处理变长参数 va_start(arglist, szFormat); strMessage.FormatV(szFormat,arglist); va_end(arglist); EnterCriticalSection(&m_csTest); // 在主界面中显示 CAA_5Axis_SingleDlg* pMain = (CAA_5Axis_SingleDlg*)m_pMain; if( m_pMain!=NULL ) { //pMain->ShowMsg(strMessage); pMain->AddInformation(strMessage,column); TRACE( strMessage+_T("\n") ); } LeaveCriticalSection(&m_csTest); } ``` 上面的函数,在主线程和由主线程启动的多个子线程中都会被调用,单步跟踪的时候跟着跟着就死锁卡死了,百思不得其解,我有退出临界区啊,为啥还会死锁呢? 求大神解答··· PS:AddInformation(strMessage,column);是在主界面的ListControl中插入一项数据而已;
C++互斥锁迷惑的点,求大神们解答
使用pthread_mutex_t mutex = NULL和 pthread_mutex_t mutex = PTHREAD_M UTEX_INITIALIZER进行初始化互斥对象, 1、使用NULL的好像没有生效(意思是没有锁住互斥对象),是这样理解的吗? 2、使用这种静态初始化互斥对象,不需要使用pthread_mutex_destroy()进行销毁, 而使用动态初始化的方式进行初始化互斥对象的话需要使用这个destroy(),是我这样理解的吗。
Delphi的线程同步的Mutex是引用计数的吗?引用计数的作用是什么?
Delphi的线程同步的Mutex是引用计数的吗?引用计数的作用是什么?
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
Linux(服务器编程):15---两种高效的事件处理模式(reactor模式、proactor模式)
前言 同步I/O模型通常用于实现Reactor模式 异步I/O模型则用于实现Proactor模式 最后我们会使用同步I/O方式模拟出Proactor模式 一、Reactor模式 Reactor模式特点 它要求主线程(I/O处理单元)只负责监听文件描述符上是否有事件发生,有的话就立即将时间通知工作线程(逻辑单元)。除此之外,主线程不做任何其他实质性的工作 读写数据,接受新的连接,以及处...
为什么要学数据结构?
一、前言 在可视化化程序设计的今天,借助于集成开发环境可以很快地生成程序,程序设计不再是计算机专业人员的专利。很多人认为,只要掌握几种开发工具就可以成为编程高手,其实,这是一种误解。要想成为一个专业的开发人员,至少需要以下三个条件: 1) 能够熟练地选择和设计各种数据结构和算法 2) 至少要能够熟练地掌握一门程序设计语言 3) 熟知所涉及的相关应用领域的知识 其中,后两个条件比较容易实现,而第一个...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n
进程通信方式总结与盘点
​ 进程通信是指进程之间的信息交换。这里需要和进程同步做一下区分,进程同步控制多个进程按一定顺序执行,进程通信是一种手段,而进程同步是目标。从某方面来讲,进程通信可以解决进程同步问题。 ​ 首先回顾下我们前面博文中讲到的信号量机制,为了实现进程的互斥与同步,需要在进程间交换一定的信息,因此信号量机制也可以被归为进程通信的一种方式,但是也被称为低级进程通信,主要原因为: 效率低:一次只可操作少量的...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观
听说了吗?阿里双11作战室竟1根网线都没有
双11不光是购物狂欢节,更是对技术的一次“大考”,对于阿里巴巴企业内部运营的基础保障技术而言,亦是如此。 回溯双11历史,这背后也经历过“小米加步枪”的阶段:作战室从随处是网线,交换机放地上的“一地狼藉”;到如今媲美5G的wifi网速,到现场却看不到一根网线;从当年使用商用AP(无线路由器),让光明顶双11当天断网一分钟,到全部使用阿里自研AP……阿里巴巴企业智能事业部工程师们提供的基础保障...
在阿里,40岁的奋斗姿势
在阿里,40岁的奋斗姿势 在阿里,什么样的年纪可以称为老呢?35岁? 在云网络,有这样一群人,他们的平均年龄接近40,却刚刚开辟职业生涯的第二战场。 他们的奋斗姿势是什么样的呢? 洛神赋 “翩若惊鸿,婉若游龙。荣曜秋菊,华茂春松。髣髴兮若轻云之蔽月,飘飖兮若流风之回雪。远而望之,皎若太阳升朝霞;迫而察之,灼若芙蕖出渌波。” 爱洛神,爱阿里云 2018年,阿里云网络产品部门启动洛神2.0升...
关于研发效能提升的思考
研发效能提升是最近比较热门的一个话题,本人根据这几年的工作心得,做了一些思考总结,由于个人深度有限,暂且抛转引入。 三要素 任何生产力的提升都离不开这三个因素:人、流程和工具,少了其中任何一个因素都无法实现。 人,即思想,也就是古人说的“道”,道不同不相为谋,是制高点,也是高层建筑的基石。 流程,即方法,也是古人说的“法”。研发效能的提升,也就是要提高投入产出比,既要增加产出,也要减...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip install selenium -i https://pypi.tuna.tsinghua.edu.cn/simple/ 
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆  每天早上8:30推送 作者| Mr.K   编辑| Emma 来源| 技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯
程序员该看的几部电影
##1、骇客帝国(1999) 概念:在线/离线,递归,循环,矩阵等 剧情简介: 不久的将来,网络黑客尼奥对这个看似正常的现实世界产生了怀疑。 他结识了黑客崔妮蒂,并见到了黑客组织的首领墨菲斯。 墨菲斯告诉他,现实世界其实是由一个名叫“母体”的计算机人工智能系统控制,人们就像他们饲养的动物,没有自由和思想,而尼奥就是能够拯救人类的救世主。 可是,救赎之路从来都不会一帆风顺,到底哪里才是真实的世界?
入职阿里5年,他如何破解“技术债”?
简介: 作者 | 都铎 作为一名技术人,你常常会听到这样的话: “先快速上线” “没时间改” “再缓一缓吧” “以后再解决” “先用临时方案处理” …… 当你埋下的坑越来越多,不知道哪天哪位同学就会踩上一颗雷。特别赞同“人最大的恐惧就是未知,当技术债可说不可见的时候,才是最让人不想解决的时候。” 作为一个程序员,我们反对复制粘贴,但是我们经常会见到相似的代码,相同的二方包,甚至整个代码...
Python绘图,圣诞树,花,爱心 | Turtle篇
每周每日,分享Python实战代码,入门资料,进阶资料,基础语法,爬虫,数据分析,web网站,机器学习,深度学习等等。 公众号回复【进群】沟通交流吧,QQ扫码进群学习吧 微信群 QQ群 1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle()...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东
破14亿,Python分析我国存在哪些人口危机!
2020年1月17日,国家统计局发布了2019年国民经济报告,报告中指出我国人口突破14亿。 猪哥的朋友圈被14亿人口刷屏,但是很多人并没有看到我国复杂的人口问题:老龄化、男女比例失衡、生育率下降、人口红利下降等。 今天我们就来分析一下我们国家的人口数据吧! 一、背景 1.人口突破14亿 2020年1月17日,国家统计局发布了 2019年国民经济报告 ,报告中指出:年末中国大陆总人口(包括31个
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ......
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!
2020年的1月,我辞掉了我的第一份工作
其实,这篇文章,我应该早点写的,毕竟现在已经2月份了。不过一些其它原因,或者是我的惰性、还有一些迷茫的念头,让自己迟迟没有试着写一点东西,记录下,或者说是总结下自己前3年的工作上的经历、学习的过程。 我自己知道的,在写自己的博客方面,我的文笔很一般,非技术类的文章不想去写;另外我又是一个还比较热衷于技术的人,而平常复杂一点的东西,如果想写文章写的清楚点,是需要足够...
别低估自己的直觉,也别高估自己的智商
所有群全部吵翻天,朋友圈全部沦陷,公众号疯狂转发。这两周没怎么发原创,只发新闻,可能有人注意到了。我不是懒,是文章写了却没发,因为大家的关注力始终在这次的疫情上面,发了也没人看。当然,我...
Java坑人面试题系列: 包装类(中级难度)
Java Magazine上面有一个专门坑人的面试题系列: https://blogs.oracle.com/javamagazine/quiz-2。 这些问题的设计宗旨,主要是测试面试者对Java语言的了解程度,而不是为了用弯弯绕绕的手段把面试者搞蒙。 如果你看过往期的问题,就会发现每一个都不简单。 这些试题模拟了认证考试中的一些难题。 而 “中级(intermediate)” 和 “高级(ad
深度学习入门笔记(十八):卷积神经网络(一)
欢迎关注WX公众号:【程序员管小亮】 专栏——深度学习入门笔记 声明 1)该文章整理自网上的大牛和机器学习专家无私奉献的资料,具体引用的资料请看参考文献。 2)本文仅供学术交流,非商用。所以每一部分具体的参考资料并没有详细对应。如果某部分不小心侵犯了大家的利益,还望海涵,并联系博主删除。 3)博主才疏学浅,文中如有不当之处,请各位指出,共同进步,谢谢。 4)此属于第一版本,若有错误,还需继续修正与...
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
节后首个工作日,企业们集体开晨会让钉钉挂了
By 超神经场景描述:昨天 2 月 3 日,是大部分城市号召远程工作的第一天,全国有接近 2 亿人在家开始远程办公,钉钉上也有超过 1000 万家企业活跃起来。关键词:十一出行 人脸...
Java基础知识点梳理
Java基础知识点梳理 摘要: 虽然已经在实际工作中经常与java打交道,但是一直没系统地对java这门语言进行梳理和总结,掌握的知识也比较零散。恰好利用这段时间重新认识下java,并对一些常见的语法和知识点做个总结与回顾,一方面为了加深印象,方便后面查阅,一方面为了学好java打下基础。 Java简介 java语言于1995年正式推出,最开始被命名为Oak语言,由James Gosling(詹姆
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合
你也能看懂的:蒙特卡罗方法
蒙特卡罗方法,也称统计模拟方法,是1940年代中期由于科学技术的发展和电子计算机的发明,而提出的一种以概率统计理论为指导的数值计算方法。是指使用随机数(或更常见的伪随机数)来解决很多计算问题的方法 蒙特卡罗方法可以粗略地分成两类:一类是所求解的问题本身具有内在的随机性,借助计算机的运算能力可以直接模拟这种随机的过程。另一种类型是所求解问题可以转化为某种随机分布的特征数,比如随机事件出现的概率,或...
相关热词 c# 为空 判断 委托 c#记事本颜色 c# 系统默认声音 js中调用c#方法参数 c#引入dll文件报错 c#根据名称实例化 c#从邮件服务器获取邮件 c# 保存文件夹 c#代码打包引用 c# 压缩效率
立即提问