C++实现Vector出现错误,哪位大佬看看怎么处理。 5C

我自定义一个MyVector,用来存储任意类型的对象,但我实现的时候出现以下错误,哪位大佬能帮帮我呀?一共三个文件:MyVector.h,MyVector.cpp和main.
cpp

1.MyVector.h

//
// Created by Howard on 2019/7/5.
//

#ifndef TEST_MYVECTOR_H
#define TEST_MYVECTOR_H

#endif //TEST_MYVECTOR_H

#include <iostream>

using namespace std;

template<typename T>
class MyVector {
    friend ostream &operator << <T> (ostream &out, const MyVector<T> &obj);   // 重载左移<< 右移>> 才将重载函数声明为友元函数
public:
    MyVector(int size = 0);   // 构造函数
    MyVector(const MyVector &obj);    // 拷贝构造函数
    ~MyVector();       // 析构函数

public:
    T &operator[](int index);

    MyVector &operator=(const MyVector &obj);


public:
    int getlen() {
        return m_len;
    }

protected:
    T *m_space;
    int m_len;
};

2.MyVector.cpp

//
// Created by Howard on 2019/7/5.
//

#include <iostream>

using namespace std;

#include "MyVector.h"


int size = 100;


// MyVector<int> myv1(10)
template<typename T>
MyVector<T>::MyVector(int size)   // 构造函数
{
    m_space = new T[size];
    m_len = size;
}


// MyVector<int> myv2 = myv1
template<typename T>
MyVector<T>::MyVector(const MyVector &obj)    // 拷贝构造函数
{
    // 根据myv1的大小分配内存
    m_len = obj.m_len;
    m_space = new T[size];
    // cpy数据
    for (int i = 0; i < m_len; i++) {
        m_space[i] = obj[i];
    }
}

template<typename T>
MyVector<T>::~MyVector()         // 析构函数
{
    if (m_space != NULL) {
        delete[] m_space;
        m_space = NULL;
        m_len = 0;
    }
}

template<typename T>
T &MyVector<T>::operator[](int index) {
    return m_space[index];
}

template<typename T>
MyVector<T> &MyVector<T>::operator=(const MyVector<T> &obj) {
    // 先把a2旧的内存释放掉
    if (m_space != NULL) {
        delete[] m_space;
        m_space = NULL;
        m_len = 0;
    }

    // 根据a1分配内存
    m_len = obj.m_len;
    m_space = new T[size];

    // cpy数据
    for (int i = 0; i < obj.m_len; i++) {
        m_space[i] = obj.m_space[i];
    }
    return *this;    // a2 = a1 返回给a2的自身


}


template<typename T>
ostream &operator<< <T>(ostream &out, const MyVector<T> &obj) {
    for (int i = 0; i < obj.m_len; i++) {
        out << obj.m_space[i] << " ";
    }
    // out << endl;
    return out;
}

3.main.cpp

#include <iostream>

using namespace std;

#include "MyVector.cpp"

int main() {
    MyVector<int> myv1(10);
    for (int i = 0; i < myv1.getlen(); i++) {
        myv1[i] = i + 1;
        cout << myv1[i] << " ";
    }
    cout << endl;

    MyVector<int> myv2 = myv1;
    for (int i = 0; i < myv2.getlen(); i++) {
        cout << myv2[i] << " ";
    }

    cout << myv2 << endl;


    system("pause");
    return 0;
}

运行结果:
In file included from F:\code\c++\test\main.cpp:5:
F:\code\c++\test\MyVector.cpp:76:61: error: non-class, non-variable partial specialization 'operator<< ' is not allowed
ostream &operator<< (ostream &out, const MyVector &obj) {
^
F:\code\c++\test\MyVector.cpp:76:61: error: non-class, non-variable partial specialization 'operator<< ' is not allowed
ostream &operator<< (ostream &out, const MyVector &obj) {
^
In file included from F:\code\c++\test\MyVector.cpp:9,
from F:\code\c++\test\main.cpp:5:
F:\code\c++\test\MyVector.h: In instantiation of 'class MyVector':
F:\code\c++\test\main.cpp:8:23: required from here
F:\code\c++\test\MyVector.h:16:21: error: template-id 'operator<< ' for 'std::ostream& operator<<(std::ostream&, const MyVector&)' does not match any template declaration
friend ostream &operator << (ostream &out, const MyVector &obj); // 閲嶈浇宸︾Щ<< 鍙崇Щ>> 鎵嶅皢閲嶈浇鍑芥暟澹版槑涓哄弸鍏冨嚱鏁�
^~~~~~~~~~~~~~~
In file included from D:/PROGRA~1/JETBRA~1/X86_64~1.0/mingw64/lib/gcc/x86_64-w64-mingw32/8.1.0/include/c++/iostream:39,
from F:\code\c++\test\main.cpp:1:
D:/PROGRA~1/JETBRA~1/X86_64~1.0/mingw64/lib/gcc/x86_64-w64-mingw32/8.1.0/include/c++/ostream:682:5: note: candidates are: 'template typename std::enable_ifstd::__and_<std::__not_<std::is_lvalue_reference<_Tp >, std::__is_convertible_to_basic_ostream<_Ostream>, std::__is_insertable::__ostream_type, const Tp&, void> >::value, typename std::_is_convertible_to_basic_ostream<_Tp>::__ostream_type>::type std::operator<<(_Ostream&&, const _Tp&)'
operator<<(_Ostream&& __os, const _Tp& __x)
^~~~~~~~

错误提示

谁能告诉我,我哪个地方写错了?

c++

2个回答

  1. 你的main.cpp 包含的是#include "MyVector.cpp" 最好包含头文件

2.你的MyVector.h里 预处理有问题
应该把#endif //TEST_MYVECTOR_H 这个东西 放到最后

3.你的友元函数 ostream <<操作符有问题 导致你后面的
cout << myv2 << endl;
的<<运算符不知道是std::cout的还是 你自己写的MyVector的运算符

  1. 你的size变量声明有冲突,有个全局变量叫size,而类的构造函数里的局部变量又叫size
    我也不知道你到底要哪个size所以不好改

就这些 改完以后错误会少很多 但应该还有错误

 friend ostream &operator << <T> (ostream &out, const MyVector<T> &obj); 

为什么函数定义这里要加个 < T>

另外.h头文件中又定义了int size,后面的size都出现歧义了,没懂你想做什么

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
C++实现Vector出现错误,哪位大佬看看怎么处理。

我自定义一个MyVector,用来存储任意类型的对象,但我实现的时候出现以下错误,哪位大佬能帮帮我呀?一共三个文件:MyVector.h,MyVector.cpp和main. cpp 1.MyVector.h ``` // // Created by Howard on 2019/7/5. // #ifndef TEST_MYVECTOR_H #define TEST_MYVECTOR_H #endif //TEST_MYVECTOR_H #include <iostream> using namespace std; template<typename T> class MyVector { friend ostream &operator << <T> (ostream &out, const MyVector<T> &obj); // 重载左移<< 右移>> 才将重载函数声明为友元函数 public: MyVector(int size = 0); // 构造函数 MyVector(const MyVector &obj); // 拷贝构造函数 ~MyVector(); // 析构函数 public: T &operator[](int index); MyVector &operator=(const MyVector &obj); public: int getlen() { return m_len; } protected: T *m_space; int m_len; }; ``` 2.MyVector.cpp ``` // // Created by Howard on 2019/7/5. // #include <iostream> using namespace std; #include "MyVector.h" int size = 100; // MyVector<int> myv1(10) template<typename T> MyVector<T>::MyVector(int size) // 构造函数 { m_space = new T[size]; m_len = size; } // MyVector<int> myv2 = myv1 template<typename T> MyVector<T>::MyVector(const MyVector &obj) // 拷贝构造函数 { // 根据myv1的大小分配内存 m_len = obj.m_len; m_space = new T[size]; // cpy数据 for (int i = 0; i < m_len; i++) { m_space[i] = obj[i]; } } template<typename T> MyVector<T>::~MyVector() // 析构函数 { if (m_space != NULL) { delete[] m_space; m_space = NULL; m_len = 0; } } template<typename T> T &MyVector<T>::operator[](int index) { return m_space[index]; } template<typename T> MyVector<T> &MyVector<T>::operator=(const MyVector<T> &obj) { // 先把a2旧的内存释放掉 if (m_space != NULL) { delete[] m_space; m_space = NULL; m_len = 0; } // 根据a1分配内存 m_len = obj.m_len; m_space = new T[size]; // cpy数据 for (int i = 0; i < obj.m_len; i++) { m_space[i] = obj.m_space[i]; } return *this; // a2 = a1 返回给a2的自身 } template<typename T> ostream &operator<< <T>(ostream &out, const MyVector<T> &obj) { for (int i = 0; i < obj.m_len; i++) { out << obj.m_space[i] << " "; } // out << endl; return out; } ``` 3.main.cpp ``` #include <iostream> using namespace std; #include "MyVector.cpp" int main() { MyVector<int> myv1(10); for (int i = 0; i < myv1.getlen(); i++) { myv1[i] = i + 1; cout << myv1[i] << " "; } cout << endl; MyVector<int> myv2 = myv1; for (int i = 0; i < myv2.getlen(); i++) { cout << myv2[i] << " "; } cout << myv2 << endl; system("pause"); return 0; } ``` 运行结果: In file included from F:\code\c++\test\main.cpp:5: F:\code\c++\test\MyVector.cpp:76:61: error: non-class, non-variable partial specialization 'operator<< <T>' is not allowed ostream &operator<< <T>(ostream &out, const MyVector<T> &obj) { ^ F:\code\c++\test\MyVector.cpp:76:61: error: non-class, non-variable partial specialization 'operator<< <T>' is not allowed ostream &operator<< <T>(ostream &out, const MyVector<T> &obj) { ^ In file included from F:\code\c++\test\MyVector.cpp:9, from F:\code\c++\test\main.cpp:5: F:\code\c++\test\MyVector.h: In instantiation of 'class MyVector<int>': F:\code\c++\test\main.cpp:8:23: required from here F:\code\c++\test\MyVector.h:16:21: error: template-id 'operator<< <int>' for 'std::ostream& operator<<(std::ostream&, const MyVector<int>&)' does not match any template declaration friend ostream &operator << <T> (ostream &out, const MyVector<T> &obj); // 閲嶈浇宸︾Щ<< 鍙崇Щ>> 鎵嶅皢閲嶈浇鍑芥暟澹版槑涓哄弸鍏冨嚱鏁� ^~~~~~~~~~~~~~~ In file included from D:/PROGRA~1/JETBRA~1/X86_64~1.0/mingw64/lib/gcc/x86_64-w64-mingw32/8.1.0/include/c++/iostream:39, from F:\code\c++\test\main.cpp:1: D:/PROGRA~1/JETBRA~1/X86_64~1.0/mingw64/lib/gcc/x86_64-w64-mingw32/8.1.0/include/c++/ostream:682:5: note: candidates are: 'template<class _Ostream, class _Tp> typename std::enable_if<std::__and_<std::__not_<std::is_lvalue_reference<_Tp> >, std::__is_convertible_to_basic_ostream<_Ostream>, std::__is_insertable<typename std::__is_convertible_to_basic_ostream<_Tp>::__ostream_type, const _Tp&, void> >::value, typename std::__is_convertible_to_basic_ostream<_Tp>::__ostream_type>::type std::operator<<(_Ostream&&, const _Tp&)' operator<<(_Ostream&& __os, const _Tp& __x) ^~~~~~~~ ![错误提示](https://img-ask.csdn.net/upload/201907/05/1562337978_764008.png) 谁能告诉我,我哪个地方写错了?

vector容器push_back出现错误,哪位大神来帮帮小白

#pragma once #include "GNSSHeader.h" #include <vector> using namespace std; class CPreProcess { public: CPreProcess(void); ~CPreProcess(void); public: vector<observe_o>observe; void ReadData(); void ReadRenix302(observe_o * temp_O,observe_n *temp_N,observe_n *temp_C,observe_glon * temp_G); void ReadRenix210(observe_o * temp_O,observe_n *temp_N,observe_n *temp_C,observe_glon * temp_G); void ReadNavFile(CString filename,observe_n *temp_N,observe_n *temp_C,observe_glon * temp_G,BOOL GPSOK,BOOL BDSOK,BOOL GLOOK); }; 以上是头文件.h文件 我想请问一下,为什么我在 .cpp文件ReadData()函数中把读入的东西push_back中observe,显示读取位错误,也就是中observe没有地址,放不进去

不定时出现vector iterators incompatible错误提示,该如何调试解决?

我的程序(程序是用C++语言,vs2010做的)正常运行时都很正常,不会报错,但偶尔会出现错误提示,显示vector iterators incompatible。 提示错误后系统还能继续运行一会,不会直接关闭。但是出现这个错误的概率很低也很不固定,有的时候三四天连着跑也不会出现问题,有的时候一会就会出现几次这个问题,现在我不是很懂应该从哪里调试找到问题,因为代码很多不知道应该如何定位到问题的出错行,不太好放代码上来,所以想请大神们看看我这个问题有没有什么调试手段,或者是有类似错误经验?并上错误截图。 ![图片说明](https://img-ask.csdn.net/upload/201810/11/1539250970_981945.jpg)

vector变量出现的内存异常,困扰好久,求解!

![出现的异常如图](https://img-ask.csdn.net/upload/201903/16/1552743405_169952.png) 定义是 vector<wholepoint> allpoint_rec = { }; 此时出错的时候,allpoint_rec是size为0. 并且前边已经顺序结构已经执行过allpoint_rec.pushback(XXX) 一般是程序跑个半小时左右会出现问题,应该不是语法错误 困扰好久好久 各位大神求解

linux vector clear报段错误

linux下写了一个程序,利用用到vector<vector<string> >inputData这样的数据结构,从oracle数据库表读取数据,读完之后,调用inputData.clear()清空容器,直接报段错误。 gdb 调试,bt给出的信息是 std::vector<std::vector<std::basic_string<char,std::char_traits<char>,std::allocator<char> >,std::allocator<std::basic_string<char,std::char_traits<char>,std::allocator<char> > > >,std::allocator<std::vector<std::basic_string<char,std::char_traits<char>,std::allocator<char> >,std::allocator<std::basic_string<char,std::char_traits<char>,std::allocator<char> > > > >::clear() will be anbandoned 请问有没有哪位大神可以指教,是什么原因?

利用vector<string>实现子串的查找

我想用下面这个程序实现子字符串的查找功能,为什么不行呢,大家伙帮我看看问题出在哪。。。 #include<iostream> #include<string> #include<vector> using namespace std; int findstr(vector<string> vec,string s ) { int n=0; for(vector<string>::size_type i=0;i!=vec.size();++i) if(strcmp(vec[i],s)==0) n++; return n; } void main() { vector<string> vec1; string s2("you"); string word; while(cin>>word) { vec1.push_back(word); } int k=findstr(vec1,s2); if(k==0) puts("Not find."); else cout<<s2<<" "<<k<<endl; }

c语言编程时出现错误为:1.#QNAN0000000,麻烦大佬们看一下问题出在哪儿了,感谢

![图片说明](https://img-ask.csdn.net/upload/201911/11/1573471041_542290.png) # 数值分析大作业 ## c语言 这个是数值分析大作业,我是按照书上一步一步编写的,前366行都是没问题的,问题就出在双步位移QR分解那里,但是我真的无能为力了,感谢大佬们相救,感谢。 ``` 代码如下:(有些printf是我测试用的) #include<stdio.h> #include<math.h> const int n=10,L=10; double err=1e-12; //定义主函数 int main() { int i,j; double A[n][n],B[n][n]; //B[][]是为保证矩阵A(n-1)[][]不被破坏的中间矩阵 //调用函数声明 void faketriangle(double a[n][n]); //构造拟上三角化矩阵函数 void QR(double a[n][n]); void doublestepQR(double a[n][n]); printf("矩阵A为:\n"); //定义矩阵A for(i=0;i<n;i++) { for(j=0;j<n;j++) { if(i==j) { A[i][j]=1.52*cos(1+i+1.2*(1+j)); }else { A[i][j]=sin(0.5*(1+i)+0.2*(1+j)); } printf("%0.12f\t",A[i][j]); } printf("\n"); } printf("\n"); printf("矩阵A(n-1)为:\n"); //调用构造拟上三角化矩阵函数A(n-1) faketriangle(A); for(i=0;i<n;i++) { for(j=0;j<n;j++) { B[i][j]=A[i][j]; } } printf("\n"); printf("矩阵A(n-1)分解为QR矩阵\n"); QR(A); printf("\n"); doublestepQR(B); } //构造拟上三角化矩阵函数A(n-1) 函数主体 void faketriangle(double a[n][n]) { int i,j,r; double sum,d,c,h,t; double u[n],w[n],q[n],p[n]; //算法开始迭代 for(r=0;r<n-2;r++) { sum=0; for(i=r+2;i<n;i++) { sum+=fabs(a[i][r]); } //判断是否满足a[i][r]=0(i=r+2,..,n)? if(sum>0) { sum=0; //计算d for(i=r+1;i<n;i++) { sum+=a[i][r]*a[i][r]; } d=sqrt(sum); //计算c if(a[r+1][r]>0) { c=-d; }else { c=d; } //计算h h=c*c-c*a[r+1][r]; //向量u[r]的建立 for(i=0;i<n;i++) { if(i<r+1) { u[i]=0; }else if(i==r+1) { u[i]=a[i][r]-c; }else { u[i]=a[i][r]; } // printf("%0.12f\n",u[i]); } //求解向量p for(i=0;i<n;i++) { sum=0; for(j=0;j<n;j++) { sum+=a[j][i]*u[j]; } p[i]=sum/h; // printf("%0.12f\n",p[i]); } // //求解矩阵q for(i=0;i<n;i++) { sum=0; for(j=0;j<n;j++) { sum+=a[i][j]*u[j]; } q[i]=sum/h; // printf("%0.12f\n",q[i]); } //求t sum=0; for(i=0;i<n;i++) { sum+=p[i]*u[i]; } t=sum/h; // printf("%0.12f\n",t); //求w[] for(i=0;i<n;i++) { w[i]=q[i]-t*u[i]; // printf("%0.12f\n",w[l]); } //求a(r+1) for(i=0;i<n;i++) { for(j=0;j<n;j++) { a[i][j]=a[i][j]-(w[i]*u[j]+u[i]*p[j]); // printf("%0.12f\t",a[i][j]); } // printf("\n"); } } } //输出矩阵A(n-1) for(i=0;i<n;i++) { for(j=0;j<n;j++) { printf("%0.12f\t",a[i][j]); } printf("\n"); } } //将 A(n-1)矩阵进行QR分解 void QR(double a[n][n]) { int i,j,k,r; double sum,d,c,h; double Q[n][n],u[n],w[n],p[n],R[n][n],b[n][n]; //定义矩阵Q[][] for(i=0;i<n;i++) { for(j=0;j<n;j++) { if(i==j) { Q[i][j]=1; }else { Q[i][j]=0; } // printf("%0.12f\t",Q[i][j]); } // printf("\n"); } // printf("\n"); //算法迭代 for(r=0;r<n-1;r++) { sum=0; for(i=r+1;i<n;i++) { sum+=fabs(a[i][r]); } if(sum>0) { //计算d sum=0; for(i=r;i<n;i++) { sum+=a[i][r]*a[i][r]; } d=sqrt(sum); //计算c if(a[r][r]>0) { c=-d; }else { c=d; } //计算h h=c*(c-a[r][r]); //构造向量u[] for(i=0;i<n;i++) { if(i<r) { u[i]=0; }else if(i==r) { u[i]=a[i][r]-c; }else { u[i]=a[i][r]; } } //计算w[] for(i=0;i<n;i++) { sum=0; for(j=0;j<n;j++) { sum+=Q[i][j]*u[j]; } w[i]=sum; } //计算Q(r+1) for(i=0;i<n;i++) { for(j=0;j<n;j++) { Q[i][j]=Q[i][j]-w[i]*u[j]/h; } } //计算P[] for(j=0;j<n;j++) { sum=0; for(i=0;i<n;i++) { sum+=a[i][j]*u[i]/h; } p[j]=sum; } //计算a[r+1] for(i=0;i<n;i++) { for(j=0;j<n;j++) { a[i][j]=a[i][j]-u[i]*p[j]; } } } } printf("Q矩阵为:\n"); //输出Q[][]、R[][] for(i=0;i<n;i++) { for(j=0;j<n;j++) { printf("%0.12f\t",Q[i][j]); } printf("\n"); } printf("\n"); printf("R矩阵为:\n"); for(i=0;i<n;i++) { for(j=0;j<n;j++) { R[i][j]=a[i][j]; printf("%0.12f\t",R[i][j]); } printf("\n"); } printf("RQ相乘后的矩阵为:\n"); //求解R[][]*Q[][] for(i=0;i<n;i++) { for(j=0;j<n;j++) { sum=0; for(k=0;k<n;k++) { sum+=R[i][k]*Q[k][j]; } b[i][j]=sum; printf("%0.12f\t",b[i][j]); } printf("\n"); } // printf("QR相乘后的矩阵为:\n"); // //求解Q[][]*R[][] // for(i=0;i<n;i++) // { // for(j=0;j<n;j++) // { // sum=0; // for(k=0;k<n;k++) // { // sum+=Q[i][k]*R[k][j]; // } // b[i][j]=sum; // printf("%0.12f\t",b[i][j]); // } // printf("\n"); // } } //以上没问题 //定义复数结构体 struct complex { double re; double im; }; //对A(n-1)进行双步位移的QR分解 void doublestepQR(double a[n][n]) { //M[][]QR分解函数声明 void MQR(double a[n][n],double M[n][n],int m); int i,j,k,m,r,l; double A[n][n],M[n][n],I[n][n],A2[n][n]; double x,y,z,sum; double s,t; struct complex lambda[n]; struct complex s1,s2; k=0;m=n-1; step3: if(fabs(a[m][m-1])<=err) { lambda[m].re=a[m][m]; lambda[m].im=0; m--; goto step4; }else { goto step5; } step4: if(m==0) { lambda[m].re=a[0][0]; lambda[m].im=0; goto step11; }else if(m==-1) { goto step11; }else { goto step3; } step5: x=a[m-1][m-1]+a[m][m]; y=a[m-1][m-1]*a[m][m]-a[m-1][m]*a[m][m-1]; z=x*x-4*y; if(z>=0) { z=sqrt(z); s1.re=(x+z)/2; s1.im=0; s2.re=(x-z)/2; s2.im=0; }else { z=sqrt(fabs(z)); s1.re=(x)/2; s1.im=(z)/2; s2.re=x/2; s2.im=(-z)/2; } step6: if(m==1) { lambda[m].re=s1.re; lambda[m].im=0; lambda[m-1].re=s2.re; lambda[m-1].im=s2.im; goto step11; }else { goto step7; } step7: if(fabs(a[m-1][m-2])<=err) { if(z>=0) { lambda[m-1].re=(x+sqrt(z))/2; //两个特征值 lambda[m-1].im=0; lambda[m-2].re=(x-sqrt(z))/2; lambda[m-2].im=0; }else { lambda[m-1].re=(x)/2; lambda[m-1].im=(sqrt(fabs(z)))/2; lambda[m-2].re=x/2; lambda[m-2].im=(-sqrt(fabs(z)))/2; } m=m-2; goto step4; }else { goto step8; } step8: if(k==L) { goto step12; }else { goto step9; } step9: // for(i=0;i<m;i++) // { // for(j=0;j<m;j++) // { // a[i][j]=a[i][j]; // } // } s=a[m-1][m-1]+a[m][m]; t=a[m-1][m-1]*a[m][m]-a[m][m-1]*a[m-1][m]; //定义矩阵I[][] for(i=0;i<m;i++) { for(j=0;j<m;j++) { if(i==j) { I[i][j]=1; }else { I[i][j]=0; } } } // printf("%M[][]为:\n"); //计算矩阵M[][] for(i=0;i<m;i++) { for(j=0;j<m;j++) { sum=0; for(l=0;l<m;l++) { sum+=a[i][l]*a[l][j]; } M[i][j]=sum-s*a[i][j]+t*I[i][j]; printf("%0.12f\t",M[i][j]); } printf("\n"); } printf("\n"); //调用M[][]QR分解、计算A(k+1)的函数 MQR(a,M,m); step10: k++; goto step3; step11: printf("特征值已计算完毕。\n"); for(i=0;i<n;i++) { printf("%0.12f+%0.12fi\n",lambda[i].re,lambda[i].im); } for(i=0;i<n;i++) { if(lambda[i].im==0) { // vector(); } } step12: printf("未得到所有特征值。\n"); } //M[][]QR分解、计算A(k+1)的函数 void MQR(double a[n][n],double M[n][n],int m) { int i,j,r; double sum,d,c,h,t; double B[n][n],C[n][n],p[n],q[n],v[n],w[n],u[n]; printf("B:\n"); for(i=0;i<m;i++) { for(j=0;j<m;j++) { B[i][j]=M[i][j]; printf("%f\t",B[i][j]); } printf("\n"); } for(i=0;i<m;i++) { for(j=0;j<m;j++) { C[i][j]=a[i][j]; } } //循环计算矩阵A(k+1) for(r=0;r<m;r++) //r的范围 { sum=0; for(i=r+1;i<m;i++) { sum+=fabs(B[i][r]); } printf("sum:\n"); printf("%0.12f\n",sum); //sum有问题 printf("\n\n\n"); printf("r:%d\n\n\n\n\n",r); if(sum>0) { //计算d sum=0; for(i=r;i<m+1;i++) { sum+=B[i][r]*B[i][r]; printf("B:%0.12f\n",B[i][r]); //B[][]? printf("\n"); } printf("sum:%0.12f\n",sum); //sum有问题 fiest!! printf("\n"); d=sqrt(sum); printf("%0.12f\n",d); //d有问题 printf("\n"); //计算c if(B[r][r]>0) { c=-d; }else { c=d; } printf("%0.12f\n",c); //c有问题 printf("\n"); //计算h h=c*(c-B[r][r]); printf("%0.12f\n",h); //h有问题 printf("\n"); //构造向量u[] for(i=0;i<m;i++) { if(i<r) { u[i]=0; }else if(i==r) { u[i]=B[i][r]-c; }else { u[i]=B[i][r]; } } //计算v[] for(i=0;i<m;i++) { sum=0; for(j=r;j<m;j++) { sum+=B[j][i]*u[j]; } v[i]=sum/h; } //计算B(r+1) for(i=0;i<m;i++) { for(j=0;j<m;j++) { B[i][j]=B[i][j]-u[i]*v[j]; } } //计算p[] for(i=0;i<m;i++) { sum=0; for(j=r;j<m;j++) { sum+=C[j][i]*u[j]; } p[i]=sum/h; } //计算q[] for(i=0;i<m;i++) { sum=0; for(j=r;j<m;j++) { sum+=C[i][j]*u[j]; } q[i]=sum/h; } //计算t sum=0; for(i=r;i<m;i++) { sum+=p[i]*u[i]; } t=sum/h; //计算w[] for(i=0;i<m;i++) { w[i]=q[i]-t*u[i]; } //计算C[r+1] for(i=0;i<m;i++) { for(j=0;j<m;j++) { C[i][j]=C[i][j]-w[i]*u[j]-u[i]*p[j]; } } }else { ; } } for(i=0;i<m;i++) { for(j=0;j<m;j++) { a[i][j]=C[i][j]; printf("%f\t",a[i][j]); } printf("\n"); } } ```

求助,c++ vector使用出现问题

#include<iostream> #include<vector> using namespace std; void merge( vector<int>& a, int first, int mid, int last ) { vector<int> s1 = { a.begin() + first, a.begin() + mid }; vector<int> s2 = { a.begin() + mid + 1, a.begin() + last }; int i = 0; int j = 0; int k = 0; int len1 = mid - first + 1; int len2 = last - mid; for (; ( i < len1 ) && ( j <= len2 ); ++k) { if (s1[ i ] < s2[ j ]) a[ k ] = s1[ i++ ]; else a[ k ] = s2[ j++ ]; } while (i++ < len1) a[ k++ ] = s1[ i ]; while (j++ < len2) a[ k++ ] = s2[ j ]; } void mergesort( vector<int>& a, int first, int last ) { if (first < last) { int mid = ( first + last ) / 2; mergesort( a, first, mid ); mergesort( a, mid + 1, last ); merge( a, first, mid, last ); } } int main() { vector<int> a = { 3, 44, 38, 5, 47, 25, 36, 26, 27, 2, 46, 4, 5, 50,99 }; mergesort( a, 0, a.size()-1 ); for (auto i : a) cout << i<<" "; cout << endl; return 0; } 刚学的归并排序 调试看不懂哪里有问题

用vector时最后输出正确没有报错但却出现 Debug assertion failed

题目是:将若干个整数输入vector容器,用迭代器将相邻的两个元素之和输出。 下面是代码: ![图片说明](https://img-ask.csdn.net/upload/201609/20/1474377301_760031.png) 当没有输入和输入的数字个数为奇数时,都有正确结果并且不会出现Debug assertion failed,如图: ![图片说明](https://img-ask.csdn.net/upload/201609/20/1474377381_104140.png) ![图片说明](https://img-ask.csdn.net/upload/201609/20/1474377390_461810.png) 但是当输入数字个数为偶数时,虽然有正确的结果输出,但是伴随有Debug assertion failed的出现,如图: ![图片说明](https://img-ask.csdn.net/upload/201609/20/1474377456_569116.png) 是else 后面的偶数语句中超出了vector的范围导致的么?请大家帮忙指出错误和出现Debug assertion failed这类情况的解决办法,谢谢大家!

Zoj4109 不知道为什么代码一直段错误,请大佬帮看看

[Zoj4109链接](http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=6011 "") 题目处理方法为并查集+优先队列 本蒟蒻Segmentation fault代码如下: ``` #include <iostream> #include <stdio.h> #include <string.h> #include <string> #include <vector> #include <algorithm> #include <queue> #include <math.h> #include <map> #include <set> #include <stdlib.h> #include <ctype.h> #include <stack> #include <bitset> #include <iterator> using namespace std; #define ull unsigned long long #define ll long long #define ls k<<1 #define rs k<<1|1 #define lson l,mid,k<<1 #define rson mid+1,r,k<<1|1 typedef pair<int,int> pii; int lowbit(int x){return x&(-x);} const int maxn=1e6+5; vector<int> G[maxn]; int vis[maxn],n,m; int pre[maxn],cnt,mn[maxn]; int findRoot(int x){ if(x==pre[x]) return x; return pre[x]=findRoot(pre[x]); } void initial(void){ scanf("%d%d",&n,&m); for(int i=1;i<=n;++i) G[i].clear(),pre[i]=i,vis[i]=0,mn[i]=i; cnt=n; for(int i=0;i<m;++i){ int u,v;scanf("%d%d",&u,&v); G[u].push_back(v);G[v].push_back(u); int x=findRoot(u),y=findRoot(v); if(x!=y){ --cnt; mn[x]=mn[y]=min(mn[x],mn[y]); pre[x]=y; //问题原因大概是在这里,将本行改为下方注释内容即可AC,但是不理解为什么。请大佬指点! // if(x>y) pre[x]=y; // else pre[y]=x; } } } int ans[maxn],tp; void solve(void){ tp=0; priority_queue<int,vector<int>,greater<int> > q; for(int i=1;i<=n;++i){ int x=findRoot(i); if(!vis[mn[x]]) q.push(mn[x]),vis[mn[x]]=1; } while(!q.empty()){ int u=q.top();q.pop(); ans[tp++]=u; for(int i=0;i<G[u].size();++i)if(!vis[G[u][i]]){ vis[G[u][i]]=1; q.push(G[u][i]); } } printf("%d\n%d",cnt,ans[0]); for(int i=1;i<tp;++i) printf(" %d",ans[i]); puts(""); } int main(void){ int T;scanf("%d",&T); while(T--){ initial(); solve(); } return 0; } ```

(急求大佬们的帮助)C++ 如何把文件中的数据写进vector再传给类

(C++ 如何把文件(文件一行存的是一个类对象的数据)中的数据读出存入到vector容器中,再传给一个临时类对象,或者有更好的方法?我是小白,有C和Python的一点基础 取出数据之后还可以修改再传进文件中,我想做的是银行管理系统,要做登录,存取款,转账,现在是被文件的读取给难住了,望大佬们指点.最好有点关键代码,谢谢qwq

openmp 能否并行处理数组和vector

用openmp做多核并行处理遇到了问题, 例如有个vector <string > a, 想要对下面并行 #program opm parallel for num_threads(2) for (int i=0;i<a.size();i++) cout <<a[i]; 并行下a[i]被共享读,设置处理器个数为1,2,4,6,8个(本人机器12个核), 发现处理速度没变,有时候还会报错。 如何实现上面并行? 上面的例子就是一个我遇到问题的简单化,但是想实现的思想差不多。

关于c++的vector嵌套问题

``` class Person { public: CString name; CString location; CString primary; CString junior; CString high; CString college; CString work; vector<CString> vecfriends; vector<CString> vecgroup; }; vector<Person> vecperson; ``` 像这样的嵌套,我要访问person中的friends的每一个元素 应该怎么实现,代码怎么写

vector iterator not dereferencable怎么处理啊

求解,下面这段代码是可以运行的,不过我把处理的数据换成 ``` (IP (NP (NP (NP (CP (IP (VP (VV ()(NP (NR 法新社)(NR 伦敦) (NT 一日) (NN 电) (NN )) (NN 火星) (NN 探测)))))(NP (NN 计划)))(NP (NN 发言人)))(NP (NR 巴拉特)))(VP (VV 说) (PU ,)(IP (IP (VP (VV 一枚)(IP (VP (LCP (IP (NP (NP (NR 美国))(NP (NN 卫星)))(VP (ADVP (AD 无法))(PP (P 与)(NP (CP (IP (VP (ADVP (AD 已))(VP (VV 登陆)(NP (NN 火星)))))(DEC 的))(NP (NP (NP (NP (NR 欧洲))(ADJP (JJ 小)) (NP (NN 猎犬)))(QP (OD 二)(CLP (M 号))) (NP (NN ()))(NP (NN BEAGLE))) (NP (QP (CD 2))(NP (NN )))) (NP (NN 登陆艇)))) (ADVP (AD 连)) (VP (VV 系))))(LC 后))(ADVP (AD ,)) (VP (VV 有意)(NP (CP (IP (VP (ADVP (AD 从小))(VP (VV 猎犬)(NP (QP (OD 二)(CLP (M 号)))(NP (NN 搜集)(NN 信号))))))(DEC 的))(NP (NN 希望))))))))(PU ,) (VP (NP (NT 如今))(ADVP (AD 只好)) (VP (VV 寄)(VP (VV 望)(PP (P 于)(NP (NP (PN 它的))(NP (NN 母)(NN 船) (NN 火星)) (ADJP (JJ 特)) (NP (NN 快车))))))) (PU .)))) ``` 之后就不能运行了,然后报错说vector iterator not dereferencable ``` #include <iostream> #include <vector> #include <string> #include <iterator> #include <queue> #include <iomanip> #include <cstdlib> using namespace std; typedef vector<string>::const_iterator iter; const int word_length = 10;//Max word length, should be even class SyntaxTree{ struct Node{ string tag; vector<Node*> children; int leaf_num; Node(string tag,vector<Node*> children,int leaf_num=0){ this->tag = tag; this->children = children; this->leaf_num = leaf_num; } }; Node * _root; public: void parseTree(const vector<string>& vec){ iter be = vec.begin(); _root = parseTree(be); } void printTree(){ queue<Node*> que; que.push(_root); int level_num = 1; bool end_flag = true; while(que.size() != 0 && end_flag){ end_flag = false; int new_level_num = 0; while(level_num--){ Node *temp = que.front(); printAuxi(temp->leaf_num,temp->tag); que.pop(); for(int i=0;i!=temp->children.size();i++){ end_flag = true; que.push(temp->children[i]); new_level_num++; } if(temp->children.size() == 0){ que.push(new Node(" ",vector<Node*>(),1));//Empty Node for aligning new_level_num++; } } level_num = new_level_num; cout<<endl; cout<<endl; } } private: void printAuxi(int num,string str){ if(str.size() % 2 == 1) str += " "; int pad = (word_length * num - str.size()) / 2; cout<<setw(pad + str.size())<<str; cout<<setw(pad)<<" "; } Node * parseTree(iter& b){ if(*b == ")" || *b == "]"){ b++; return NULL; } else if( *b == "(" || *b == "["){ Node *temp = new Node(*(b+1),vector<Node*>()); b += 2; Node *child; while((child = parseTree(b)) != NULL){ temp->children.push_back(child); temp->leaf_num += child->leaf_num; } return temp; } else{ return new Node(*b++,vector<Node*>(),1); } return NULL;//nosense } }; vector<string> convert(const string& sytree){ vector<string> ret; for(string::const_iterator i = sytree.begin();i != sytree.end();i++){ if(*i == ' ' | *i == '\t') continue; else if(*i == '(' || *i == ')' || *i == '[' || *i == ']') ret.push_back(string(i,i+1)); else{ string::const_iterator j = i+1; for (;j != sytree.end() && *j != ' ' && *j != '\t' && *j != '(' && *j != ')' && *j != '[' && *j != ']';j++) ; ret.push_back(string(i,j)); i = --j; } } return ret; } int main(){ string test = "(S(NP I)(VP(VP (V shot) (NP (Det an) (N elephant)))(PP (P in) (NP (Det my) (N pajamas)))))"; vector<string> syt = convert(test); SyntaxTree syn; syn.parseTree(syt); syn.printTree(); return 0; } ``` 求帮忙解答一下,我C++几乎是小白啊

如何实现vector容器存储类但是提示Stack overflew?

C++刚入门 不太会,请各位大神帮忙查一下这个错误是为什么,真的万分感谢!!! 设计一个CMyClass,它仅包含一个int类型的成员变量m_nValue,该类能够自动实现记录添加新类到Vector容器中,不需要类的用户再做任何特别处理的情况下,实现用一个简单的容器中存储一个类的所有实例。 但是在编译的过程中出现了![图片说明](https://img-ask.csdn.net/upload/201812/31/1546223044_726574.jpg)这个报错。 最终程序的正确输出结果应该是: ``` The first end: 100 1 0 10 The second end: 100 1 0 10 1000 The third end: 100 1 0 ``` ``` #include "pch.h" #include <iostream> #include <vector> #include <iterator> #include <algorithm> using namespace std; class CMyClass { public: int m_nValue; public: static vector<CMyClass>member; CMyClass(); CMyClass(int value); ~CMyClass(); static void ShowList(); friend ostream & operator<<(ostream & output, const CMyClass & temp); }; std::vector<CMyClass> CMyClass::member; CMyClass::CMyClass() { m_nValue = 0; member.push_back(*this); } CMyClass::CMyClass(int value) { m_nValue = value; member.push_back(*this); } CMyClass::~CMyClass() { member.pop_back(); } void CMyClass::ShowList() { //vector<CMyClass>::iterator it; //for (it = member.begin(); it != member.end(); it++); for(int i=0;i<member.size();i++) { cout << member.at(i) << endl; } } ostream & operator<<(ostream & output, const CMyClass & temp) { output << temp.m_nValue; return output; } int main() { CMyClass a(100); CMyClass b(1); CMyClass c; CMyClass *d = new CMyClass; *d = 10; cout << "The first end: " << endl; CMyClass::ShowList(); if (1) { CMyClass e(1000); cout << "The second end: " << endl; CMyClass::ShowList(); } delete d; cout << "The third end: " << endl; CMyClass::ShowList(); return 0; } ```

C++容器问题。老是出现段错误。

#include <iostream> using namespace std; #include <list> int main(void) { list<int> Boy; for(int i = 1; i <= 100; ++i) { Boy.push_back(i); } list<int>::iterator it = Boy.begin(); int num = 1; while(Boy.size() > 1) { if(num%3 == 0) { Boy.remove(*it); } else { ++it; } if(it == Boy.end()) { it = Boy.begin(); } ++num; } cout << *it << endl; return 0; }

C++ VECTOR push_back 出现stack_overflow

#include<iostream> #include<vector> #include<iterator> using namespace std; class CMyClass { public: CMyClass() {} CMyClass(int a) { this->m_nValue = a; vec.push_back(*this); } CMyClass(const CMyClass&c) { m_nValue = c.m_nValue; } ~CMyClass() { /*不知道怎么指向当前类*/ vector<CMyClass>::iterator it; for (it = vec.begin(); it != vec.end(); it++) { if (it->vec == *this) vec.erase(it); } } friend bool operator==(vector<CMyClass>v, CMyClass& c2) { int length = v.size(); for (int i = 0; i < length; i++) { if (&v[i] == &c2) return true; } return false; } friend ostream& operator<<(ostream& out, CMyClass& c) { out << c.m_nValue << endl; return out; } static void ShowList() { vector<CMyClass>::iterator it; for (it = vec.begin(); it != vec.end(); it++) { cout << *it; } } private: int m_nValue; static vector<CMyClass>vec; }; vector<CMyClass>CMyClass::vec; int main() { CMyClass a(100); CMyClass b(1); CMyClass c; CMyClass* d = new CMyClass; *d = 10; cout << "The first end:" << endl; CMyClass::ShowList(); if (1) { CMyClass e(1000); cout << "The second end:" << endl; CMyClass::ShowList(); } delete d; cout << "The third end:" << endl; CMyClass::ShowList(); return 0; } 类CMyClass中的vector类型的静态成员变量,目的是在创建对象时把他加入到容器中,在析构对象时把它从该容器中删除。现在debug,出现了overflow的错误,求教!

新手求教:一个简单的函数出现段错误的原因?

在牛客网上做题。不知道为什么加上 if (array[i][0]>target)break;这句代码之后会显示段错误?? bool Find(int target, vector<vector<int> > array) { for(int i=0;i<array.size();i++) { if (array[i][0]>target)break;//为什么加上这句代码之后显示段错误? for(int j=0;j<array[i].size();j++) { if (array[i][j]==target)return true; } } return false; }

return vector<int>(); 是怎么发挥作用的?

有一个leetcode上的题:找到vector里相加等于target的数的下标。 比如: nums = [2, 7, 11, 15], target = 9, Because nums[0] + nums[1] = 2 + 7 = 9, return [0, 1]. 我是这么写的: class Solution { public: vector<int> twoSum(vector<int>& nums, int target) { vector<int>nums_; int i,j; for(i=0;i<nums.size();++i){ for(j=i+1;j<nums.size();++j){ if(nums[i]+nums[j]==target){ nums_={i,j}; return nums_; } } } } }; 可是报错, 然后我抄了有一个答案发现加一句return vector<int>();就运行正常了。 class Solution { public: vector<int> twoSum(vector<int>& nums, int target) { vector<int>nums_; int i,j; for(i=0;i<nums.size();++i){ for(j=i+1;j<nums.size();++j){ if(nums[i]+nums[j]==target){ nums_={i,j}; return nums_; } } } return vector<int>(); } }; 我想知道 return vector<int>();到底是怎么回事,为什么不加它程序会报错?

给struct里的vector赋值

``` /* x a b c x无关 x有关 */ #include <iostream> #include <vector> using namespace std; struct staff { int happy; vector<staff> subs; staff(int h) { happy = h; } }; struct info { int laimaxhappy; int bulaimaxhappy; info(int lai, int bulai) { laimaxhappy = lai; bulaimaxhappy = bulai; } }; info process(staff* s) { int lai = s->happy; int bulai = 0; if(s->subs.size() == 0) { return info(s->happy, 0); } else { for(staff it : s->subs) { info subinfo = process(&it); lai += subinfo.bulaimaxhappy; bulai += max(subinfo.laimaxhappy, subinfo.bulaimaxhappy); } return info(lai, bulai); } } int getMax(staff* boss) { info treeInfo = process(boss); return max(treeInfo.laimaxhappy, treeInfo.bulaimaxhappy); } int main() { staff s1(1); staff s2(2); staff s3(3); staff s4(4); staff s5(5); vector<staff> v; v.push_back(s1); v.push_back(s2); v.push_back(s3); v.push_back(s4); v.push_back(s5); vector<staff> v1sub; v1sub.push_back(s2); v1sub.push_back(s3); s1.subs = v1sub; vector<staff> v2sub; v2sub.push_back(s4); s2.subs = v2sub;///期望s2.subs这个vector里有一个s4,可是debug发现没有 vector<staff> v3sub; v3sub.push_back(s5); s3.subs = v3sub;///期望s3.subs这个vector里有一个s5,可是debug发现没有 cout << getMax(&s1) << endl; } ```

大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了

大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

我以为我学懂了数据结构,直到看了这个导图才发现,我错了

数据结构与算法思维导图

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

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

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

Linux 会成为主流桌面操作系统吗?

整理 |屠敏出品 | CSDN(ID:CSDNnews)2020 年 1 月 14 日,微软正式停止了 Windows 7 系统的扩展支持,这意味着服役十年的 Windows 7,属于...

讲一个程序员如何副业月赚三万的真实故事

loonggg读完需要3分钟速读仅需 1 分钟大家好,我是你们的校长。我之前讲过,这年头,只要肯动脑,肯行动,程序员凭借自己的技术,赚钱的方式还是有很多种的。仅仅靠在公司出卖自己的劳动时...

学习总结之HTML5剑指前端(建议收藏,图文并茂)

前言学习《HTML5与CSS3权威指南》这本书很不错,学完之后我颇有感触,觉得web的世界开明了许多。这本书是需要有一定基础的web前端开发工程师。这本书主要学习HTML5和css3,看...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

搜狗输入法也在挑战国人的智商!

故事总是一个接着一个到来...上周写完《鲁大师已经彻底沦为一款垃圾流氓软件!》这篇文章之后,鲁大师的市场工作人员就找到了我,希望把这篇文章删除掉。经过一番沟通我先把这篇文章从公号中删除了...

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

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

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

新一代神器STM32CubeMonitor介绍、下载、安装和使用教程

关注、星标公众号,不错过精彩内容作者:黄工公众号:strongerHuang最近ST官网悄悄新上线了一款比较强大的工具:STM32CubeMonitor V1.0.0。经过我研究和使用之...

记一次腾讯面试,我挂在了最熟悉不过的队列上……

腾讯后台面试,面试官问:如何自己实现队列?

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

冒泡排序动画(基于python pygame实现)

本项目效果初始截图如下 动画见本人b站投稿:https://www.bilibili.com/video/av95491382 本项目对应github地址:https://github.com/BigShuang python版本:3.6,pygame版本:1.9.3。(python版本一致应该就没什么问题) 样例gif如下 ======================= 大爽歌作,mad

Redis核心原理与应用实践

Redis核心原理与应用实践 在很多场景下都会使用Redis,但是到了深层次的时候就了解的不是那么深刻,以至于在面试的时候经常会遇到卡壳的现象,学习知识要做到系统和深入,不要把Redis想象的过于复杂,和Mysql一样,是个读取数据的软件。 有一个理解是Redis是key value缓存服务器,更多的优点在于对value的操作更加丰富。 安装 yum install redis #yum安装 b...

现代的 “Hello, World”,可不仅仅是几行代码而已

作者 |Charles R. Martin译者 | 弯月,责编 | 夕颜头图 |付费下载自视觉中国出品 | CSDN(ID:CSDNnews)新手...

带了6个月的徒弟当了面试官,而身为高级工程师的我天天修Bug......

即将毕业的应届毕业生一枚,现在只拿到了两家offer,但最近听到一些消息,其中一个offer,我这个组据说客户很少,很有可能整组被裁掉。 想问大家: 如果我刚入职这个组就被裁了怎么办呢? 大家都是什么时候知道自己要被裁了的? 面试软技能指导: BQ/Project/Resume 试听内容: 除了刷题,还有哪些技能是拿到offer不可或缺的要素 如何提升面试软实力:简历, 行为面试,沟通能...

!大部分程序员只会写3年代码

如果世界上都是这种不思进取的软件公司,那别说大部分程序员只会写 3 年代码,恐怕就没有程序员这种职业。

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

2020阿里全球数学大赛:3万名高手、4道题、2天2夜未交卷

阿里巴巴全球数学竞赛( Alibaba Global Mathematics Competition)由马云发起,由中国科学技术协会、阿里巴巴基金会、阿里巴巴达摩院共同举办。大赛不设报名门槛,全世界爱好数学的人都可参与,不论是否出身数学专业、是否投身数学研究。 2020年阿里巴巴达摩院邀请北京大学、剑桥大学、浙江大学等高校的顶尖数学教师组建了出题组。中科院院士、美国艺术与科学院院士、北京国际数学...

为什么你不想学习?只想玩?人是如何一步一步废掉的

不知道是不是只有我这样子,还是你们也有过类似的经历。 上学的时候总有很多光辉历史,学年名列前茅,或者单科目大佬,但是虽然慢慢地长大了,你开始懈怠了,开始废掉了。。。 什么?你说不知道具体的情况是怎么样的? 我来告诉你: 你常常潜意识里或者心理觉得,自己真正的生活或者奋斗还没有开始。总是幻想着自己还拥有大把时间,还有无限的可能,自己还能逆风翻盘,只不是自己还没开始罢了,自己以后肯定会变得特别厉害...

HTTP与HTTPS的区别

面试官问HTTP与HTTPS的区别,我这样回答让他竖起大拇指!

程序员毕业去大公司好还是小公司好?

虽然大公司并不是人人都能进,但我仍建议还未毕业的同学,尽力地通过校招向大公司挤,但凡挤进去,你这一生会容易很多。 大公司哪里好?没能进大公司怎么办?答案都在这里了,记得帮我点赞哦。 目录: 技术氛围 内部晋升与跳槽 啥也没学会,公司倒闭了? 不同的人脉圈,注定会有不同的结果 没能去大厂怎么办? 一、技术氛围 纵观整个程序员技术领域,哪个在行业有所名气的大牛,不是在大厂? 而且众所...

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

立即提问
相关内容推荐