C/C++ 笔试、面试题目大汇总[转] - 阿里云开发者社区

文章推薦指數: 80 %
投票人數:10人

C++/C 语言没有办法知道指针所指的内存容量,除非在申请内存时记住它。

... C/C++ 笔试、面试题目大汇总[转]. 2017-10-09 1132 ... 下面关于“联合”的题目的输出? 开发者社区> 杨粼波> 正文 C/C++笔试、面试题目大汇总[转] 2017-10-09 1132 简介: 用运算符sizeof可以计算出数组的容量(字节数)。

sizeof(p),p为指针得到的是一个指针变量的字节数,而不是p所指的内存容量。

C++/C语言没有办法知道指针所指的内存容量,除非在申请内存时记住它。

+关注继续查看 1.求下面函数的返回值(微软)intfunc(x) {   intcountx=0;   while(x)   {      countx++;      x=x&(x-1);   }   returncountx; } 假定x=9999。

答案:8思路:将x转化为2进制,看含有的1的个数。

2.什么是“引用”?申明和使用“引用”要注意哪些问题?答:引用就是某个目标变量的“别名”(alias),对应用的操作与对变量直接操作效果完全相同。

申明一个引用的时候,切记要对其进行初始化。

引用声明完毕后,相当于目标变量名有两个名称,即该目标原名称和引用名,不能再把该引用名作为其他变量名的别名。

声明一个引用,不是新定义了一个变量,它只表示该引用名是目标变量名的一个别名,它本身不是一种数据类型,因此引用本身不占存储单元,系统也不给引用分配存储单元。

不能建立数组的引用。

3.将“引用”作为函数参数有哪些特点?(1)传递引用给函数与传递指针的效果是一样的。

这时,被调函数的形参就成为原来主调函数中的实参变量或对象的一个别名来使用,所以在被调函数中对形参变量的操作就是对其相应的目标对象(在主调函数中)的操作。

(2)使用引用传递函数的参数,在内存中并没有产生实参的副本,它是直接对实参操作;而使用一般变量传递函数的参数,当发生函数调用时,需要给形参分配存储单元,形参变量是实参变量的副本;如果传递的是对象,还将调用拷贝构造函数。

因此,当参数传递的数据较大时,用引用比用一般变量传递参数的效率和所占空间都好。

(3)使用指针作为函数的参数虽然也能达到与使用引用的效果,但是,在被调函数中同样要给形参分配存储单元,且需要重复使用"*指针变量名"的形式进行运算,这很容易产生错误且程序的阅读性较差;另一方面,在主调函数的调用点处,必须用变量的地址作为实参。

而引用更容易使用,更清晰。

4.在什么时候需要使用“常引用”? 如果既要利用引用提高程序的效率,又要保护传递给函数的数据不在函数中被改变,就应使用常引用。

常引用声明方式:const类型标识符&引用名=目标变量名;例1inta;constint&ra=a;ra=1;//错误a=1;//正确 例2stringfoo();voidbar(string&s); 那么下面的表达式将是非法的:bar(foo());bar("helloworld"); 原因在于foo()和"helloworld"串都会产生一个临时对象,而在C++中,这些临时对象都是const类型的。

因此上面的表达式就是试图将一个const类型的对象转换为非const类型,这是非法的。

引用型参数应该在能被定义为const的情况下,尽量定义为const。

5.将“引用”作为函数返回值类型的格式、好处和需要遵守的规则?格式:类型标识符&函数名(形参列表及类型说明){//函数体}好处:在内存中不产生被返回值的副本;(注意:正是因为这点原因,所以返回一个局部变量的引用是不可取的。

因为随着该局部变量生存期的结束,相应的引用也会失效,产生runtimeerror!注意事项:(1)不能返回局部变量的引用。

这条可以参照EffectiveC++[1]的Item31。

主要原因是局部变量会在函数返回后被销毁,因此被返回的引用就成为了"无所指"的引用,程序会进入未知状态。

 (2)不能返回函数内部new分配的内存的引用。

这条可以参照EffectiveC++[1]的Item31。

虽然不存在局部变量的被动销毁问题,可对于这种情况(返回函数内部new分配内存的引用),又面临其它尴尬局面。

例如,被函数返回的引用只是作为一个临时变量出现,而没有被赋予一个实际的变量,那么这个引用所指向的空间(由new分配)就无法释放,造成memoryleak。

(3)可以返回类成员的引用,但最好是const。

这条原则可以参照EffectiveC++[1]的Item30。

主要原因是当对象的属性是与某种业务规则(businessrule)相关联的时候,其赋值常常与某些其它属性或者对象的状态有关,因此有必要将赋值操作封装在一个业务规则当中。

如果其它对象可以获得该属性的非常量引用(或指针),那么对该属性的单纯赋值就会破坏业务规则的完整性。

(4)流操作符重载返回值申明为“引用”的作用:流操作符<>,这两个操作符常常希望被连续使用,例如:cout<=0&&n<=9)returnvals[n];  else{cout<>、赋值操作符=的返回值、拷贝构造函数的参数、赋值操作符=的参数、其它情况都推荐使用引用。

以上2-8参考:http://blog.csdn.net/wfwd/archive/2006/05/30/763551.aspx9.结构与联合有和区别? 1.结构和联合都是由多个不同的数据类型成员组成,但在任何同一时刻,联合中只存放了一个被选中的成员(所有成员共用一块地址空间),而结构的所有成员都存在(不同成员的存放地址不同)。

  2.对于联合的不同成员赋值,将会对其它成员重写, 原来成员的值就不存在了,而对于结构的不同成员赋值是互不影响的。

10.下面关于“联合”的题目的输出? a) #include  union { inti; charx[2]; }a; voidmain() { a.x[0]=10;  a.x[1]=1; printf("%d",a.i); } 答案:266(低位低地址,高位高地址,内存占用情况是Ox010A) b)   main()    {       union{         /*定义一个联合*/         inti;         struct{      /*在联合中定义一个结构*/            charfirst;            charsecond;         }half;       }number;       number.i=0x4241;    /*联合成员赋值*/       printf("%c%c\n",number.half.first,mumber.half.second);       number.half.first='a'; /*联合中结构成员赋值*/       number.half.second='b';       printf("%x\n",number.i);       getch();    }  答案:AB (0x41对应'A',是低位;Ox42对应'B',是高位)    6261(number.i和number.half共用一块地址空间)11.已知strcpy的函数原型:char*strcpy(char*strDest,constchar*strSrc)其中strDest是目的字符串,strSrc是源字符串。

不调用C++/C的字符串库函数,请编写函数strcpy。

答案: char*strcpy(char*strDest,constchar*strSrc) { if(strDest==NULL||strSrc==NULL) returnNULL; if(strDest==strSrc) returnstrDest; char*tempptr=strDest; while((*strDest++=*strSrc++)!=‘\0’) ; returntempptr; }12.已知String类定义如下: classString { public: String(constchar*str=NULL);//通用构造函数 String(constString&another);//拷贝构造函数 ~String();//析构函数 String&operater=(constString&rhs);//赋值函数 private: char*m_data;//用于保存字符串 }; 尝试写出类的成员函数实现。

答案: String::String(constchar*str) {  if(str==NULL)//strlen在参数为NULL时会抛异常才会有这步判断   {    m_data=newchar[1];    m_data[0]='\0';   }  else   {    m_data=newchar[strlen(str)+1];    strcpy(m_data,str);   } }  String::String(constString&another) {   m_data=newchar[strlen(another.m_data)+1];   strcpy(m_data,other.m_data); } String&String::operator=(constString&rhs) {   if(this==&rhs)     return*this;   delete[]m_data;//删除原来的数据,新开一块内存   m_data=newchar[strlen(rhs.m_data)+1];   strcpy(m_data,rhs.m_data);   return*this; } String::~String() {   delete[]m_data; }13..h头文件中的ifndef/define/endif的作用? 答:防止该头文件被重复引用。

14.#include 与#include"file.h"的区别?.h> 答:前者是从StandardLibrary的路径寻找和引用file.h,而后者是从当前工作路径搜寻并引用file.h。

15.在C++程序中调用被C编译器编译后的函数,为什么要加extern“C”? 首先,作为extern是C/C++语言中表明函数和全局变量作用范围(可见性)的关键字,该关键字告诉编译器,其声明的函数和变量可以在本模块或其它模块中使用。

通常,在模块的头文件中对本模块提供给其它模块引用的函数和全局变量以关键字extern声明。

例如,如果模块B欲引用该模块A中定义的全局变量和函数时只需包含模块A的头文件即可。

这样,模块B中调用模块A中的函数时,在编译阶段,模块B虽然找不到该函数,但是并不会报错;它会在连接阶段中从模块A编译生成的目标代码中找到此函数 extern"C"是连接申明(linkagedeclaration),被extern"C"修饰的变量和函数是按照C语言方式编译和连接的,来看看C++中对类似C的函数是怎样编译的: 作为一种面向对象的语言,C++支持函数重载,而过程式语言C则不支持。

函数被C++编译后在符号库中的名字与C语言的不同。

例如,假设某个函数的原型为:  voidfoo(intx,inty); 该函数被C编译器编译后在符号库中的名字为_foo,而C++编译器则会产生像_foo_int_int之类的名字(不同的编译器可能生成的名字不同,但是都采用了相同的机制,生成的新名字称为“mangledname”)。

_foo_int_int这样的名字包含了函数名、函数参数数量及类型信息,C++就是靠这种机制来实现函数重载的。

例如,在C++中,函数voidfoo(intx,inty)与voidfoo(intx,floaty)编译生成的符号是不相同的,后者为_foo_int_float。

同样地,C++中的变量除支持局部变量外,还支持类成员变量和全局变量。

用户所编写程序的类成员变量可能与全局变量同名,我们以"."来区分。

而本质上,编译器在进行编译时,与函数的处理相似,也为类中的变量取了一个独一无二的名字,这个名字与用户程序中同名的全局变量名字不同。

未加extern"C"声明时的连接方式 假设在C++中,模块A的头文件如下: //模块A头文件 moduleA.h #ifndefMODULE_A_H #defineMODULE_A_H intfoo(intx,inty); #endif   在模块B中引用该函数: //模块B实现文件 moduleB.cpp #include"moduleA.h" foo(2,3); 实际上,在连接阶段,连接器会从模块A生成的目标文件moduleA.obj中寻找_foo_int_int这样的符号! 加extern"C"声明后的编译和连接方式 加extern"C"声明后,模块A的头文件变为: //模块A头文件 moduleA.h #ifndefMODULE_A_H #defineMODULE_A_H extern"C"intfoo(intx,inty); #endif   在模块B的实现文件中仍然调用foo(2,3),其结果是: (1)模块A编译生成foo的目标代码时,没有对其名字进行特殊处理,采用了C语言的方式; (2)连接器在为模块B的目标代码寻找foo(2,3)调用时,寻找的是未经修改的符号名_foo。

如果在模块A中函数声明了foo为extern"C"类型,而模块B中包含的是externintfoo(intx,inty),则模块B找不到模块A中的函数;反之亦然。

所以,可以用一句话概括extern“C”这个声明的真实目的(任何语言中的任何语法特性的诞生都不是随意而为的,来源于真实世界的需求驱动。

我们在思考问题时,不能只停留在这个语言是怎么做的,还要问一问它为什么要这么做,动机是什么,这样我们可以更深入地理解许多问题):实现C++与C及其它语言的混合编程。

   明白了C++中extern"C"的设立动机,我们下面来具体分析extern"C"通常的使用技巧: extern"C"的惯用法 (1)在C++中引用C语言中的函数和变量,在包含C语言头文件(假设为cExample.h)时,需进行下列处理: extern"C" { #include"cExample.h" } 而在C语言的头文件中,对其外部函数只能指定为extern类型,C语言中不支持extern"C"声明,在.c文件中包含了extern"C"时会出现编译语法错误。

C++引用C函数例子工程中包含的三个文件的源代码如下: /*c语言头文件:cExample.h*/ #ifndefC_EXAMPLE_H #defineC_EXAMPLE_H externintadd(intx,inty); #endif /*c语言实现文件:cExample.c*/ #include"cExample.h" intadd(intx,inty) { returnx+y; } //c++实现文件,调用add:cppFile.cpp extern"C"  { #include"cExample.h" } intmain(intargc,char*argv[]) { add(2,3);  return0; } 如果C++调用一个C语言编写的.DLL时,当包括.DLL的头文件或声明接口函数时,应加extern"C"{ }。

(2)在C中引用C++语言中的函数和变量时,C++的头文件需添加extern"C",但是在C语言中不能直接引用声明了extern"C"的该头文件,应该仅将C文件中将C++中定义的extern"C"函数声明为extern类型。

C引用C++函数例子工程中包含的三个文件的源代码如下: //C++头文件cppExample.h #ifndefCPP_EXAMPLE_H #defineCPP_EXAMPLE_H extern"C"intadd(intx,inty); #endif //C++实现文件cppExample.cpp #include"cppExample.h" intadd(intx,inty) { returnx+y; } /*C实现文件cFile.c /*这样会编译出错:#include"cExample.h"*/ externintadd(intx,inty); intmain(intargc,char*argv[]) { add(2,3);  return0; } 15题目的解答请参考《C++中extern“C”含义深层探索》注解:16.关联、聚合(Aggregation)以及组合(Composition)的区别? 涉及到UML中的一些概念:关联是表示两个类的一般性联系,比如“学生”和“老师”就是一种关联关系;聚合表示has-a的关系,是一种相对松散的关系,聚合类不需要对被聚合类负责,如下图所示,用空的菱形表示聚合关系:                从实现的角度讲,聚合可以表示为: classA{...} classB{A*a;.....} 而组合表示contains-a的关系,关联性强于聚合:组合类与被组合类有相同的生命周期,组合类要对被组合类负责,采用实心的菱形表示组合关系:                实现的形式是: classA{...}classB{Aa;...} 参考文章:http://blog.csdn.net/wfwd/archive/2006/05/30/763753.aspx      http://blog.csdn.net/wfwd/archive/2006/05/30/763760.aspx17.面向对象的三个基本特征,并简单叙述之? 1.封装:将客观事物抽象成类,每个类对自身的数据和方法实行protection(private,protected,public) 2.继承:广义的继承有三种实现形式:实现继承(指使用基类的属性和方法而无需额外编码的能力)、可视继承(子窗体使用父窗体的外观和实现代码)、接口继承(仅使用属性和方法,实现滞后到子类实现)。

前两种(类继承)和后一种(对象组合=>接口继承以及纯虚函数)构成了功能复用的两种方式。

3.多态:是将父对象设置成为和一个或更多的他的子对象相等的技术,赋值之后,父对象就可以根据当前赋值给它的子对象的特性以不同的方式运作。

简单的说,就是一句话:允许将子类类型的指针赋值给父类类型的指针。

18.重载(overload)和重写(overried,有的书也叫做“覆盖”)的区别? 常考的题目。

从定义上来说: 重载:是指允许存在多个同名函数,而这些函数的参数表不同(或许参数个数不同,或许参数类型不同,或许两者都不同)。

重写:是指子类重新定义复类虚函数的方法。

从实现原理上来说: 重载:编译器根据函数不同的参数表,对同名函数的名称做修饰,然后这些同名函数就成了不同的函数(至少对于编译器来说是这样的)。

如,有两个同名函数:functionfunc(p:integer):integer;和functionfunc(p:string):integer;。

那么编译器做过修饰后的函数名称可能是这样的:int_func、str_func。

对于这两个函数的调用,在编译器间就已经确定了,是静态的。

也就是说,它们的地址在编译期就绑定了(早绑定),因此,重载和多态无关! 重写:和多态真正相关。

当子类重新定义了父类的虚函数后,父类指针根据赋给它的不同的子类指针,动态的调用属于子类的该函数,这样的函数调用在编译期间是无法确定的(调用的子类的虚函数的地址无法给出)。

因此,这样的函数地址是在运行期绑定的(晚绑定)。

19.多态的作用? 主要是两个:1.隐藏实现细节,使得代码能够模块化;扩展代码模块,实现代码重用;2.接口重用:为了类在继承和派生的时候,保证使用家族中任一类的实例的某一属性时的正确调用。

20.Ado与Ado.net的相同与不同? 除了“能够让应用程序处理存储于DBMS中的数据“这一基本相似点外,两者没有太多共同之处。

但是Ado使用OLEDB接口并基于微软的COM技术,而ADO.NET拥有自己的ADO.NET接口并且基于微软的.NET体系架构。

众所周知.NET体系不同于COM体系,ADO.NET接口也就完全不同于ADO和OLEDB接口,这也就是说ADO.NET和ADO是两种数据访问方式。

ADO.net提供对XML的支持。

21.Newdelete与mallocfree的联系与区别? 答案:都是在堆(heap)上进行动态的内存操作。

用malloc函数需要指定内存分配的字节数并且不能初始化对象,new会自动调用对象的构造函数。

delete会调用对象的destructor,而free不会调用对象的destructor.22.#defineDOUBLE(x)x+x,i=5*DOUBLE(5);i是多少? 答案:i为30。

23.有哪几种情况只能用intializationlist而不能用assignment?  答案:当类中含有const、reference成员变量;基类的构造函数都需要初始化表。

24.C++是不是类型安全的? 答案:不是。

两个不同类型的指针之间可以强制转换(用reinterpretcast)。

C#是类型安全的。

25.main函数执行以前,还会执行什么代码? 答案:全局对象的构造函数会在main函数之前执行。

26.描述内存分配方式以及它们的区别? 1)从静态存储区域分配。

内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。

例如全局变量,static变量。

2)在栈上创建。

在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。

栈内存分配运算内置于处理器的指令集。

3)从堆上分配,亦称动态内存分配。

程序在运行的时候用malloc或new申请任意多少的内存,程序员自己负责在何时用free或delete释放内存。

动态内存的生存期由程序员决定,使用非常灵活,但问题也最多。

27.struct和class的区别 答案:struct的成员默认是公有的,而类的成员默认是私有的。

struct和class在其他方面是功能相当的。

  从感情上讲,大多数的开发者感到类和结构有很大的差别。

感觉上结构仅仅象一堆缺乏封装和功能的开放的内存位,而类就象活的并且可靠的社会成员,它有智能服务,有牢固的封装屏障和一个良好定义的接口。

既然大多数人都这么认为,那么只有在你的类有很少的方法并且有公有数据(这种事情在良好设计的系统中是存在的!)时,你也许应该使用struct关键字,否则,你应该使用class关键字。

 28.当一个类A中没有生命任何成员变量与成员函数,这时sizeof(A)的值是多少,如果不是零,请解释一下编译器为什么没有让它为零。

(Autodesk) 答案:肯定不是零。

举个反例,如果是零的话,声明一个classA[10]对象数组,而每一个对象占用的空间是零,这时就没办法区分A[0],A[1]…了。

29.在8086汇编下,逻辑地址和物理地址是怎样转换的?(Intel) 答案:通用寄存器给出的地址,是段内偏移地址,相应段寄存器地址*10H+通用寄存器内地址,就得到了真正要访问的地址。

30.比较C++中的4种类型转换方式?  请参考:http://blog.csdn.net/wfwd/archive/2006/05/30/763785.aspx,重点是static_cast,dynamic_cast和reinterpret_cast的区别和应用。

31.分别写出BOOL,int,float,指针类型的变量a与“零”的比较语句。

答案: BOOL:  if(!a)orif(a) int:  if(a==0) float: constEXPRESSIONEXP=0.000001      if(a-EXP) pointer:if(a!=NULL)orif(a==NULL) 32.请说出const与#define相比,有何优点? 答案:1)const常量有数据类型,而宏常量没有数据类型。

编译器可以对前者进行类型安全检查。

而对后者只进行字符替换,没有类型安全检查,并且在字符替换可能会产生意料不到的错误。

   2)有些集成化的调试工具可以对const常量进行调试,但是不能对宏常量进行调试。

33.简述数组与指针的区别? 数组要么在静态存储区被创建(如全局数组),要么在栈上被创建。

指针可以随时指向任意类型的内存块。

(1)修改内容上的差别 chara[]=“hello”; a[0]=‘X’; char*p=“world”;//注意p指向常量字符串 p[0]=‘X’;//编译器不能发现该错误,运行时错误 (2)用运算符sizeof可以计算出数组的容量(字节数)。

sizeof(p),p为指针得到的是一个指针变量的字节数,而不是p所指的内存容量。

C++/C语言没有办法知道指针所指的内存容量,除非在申请内存时记住它。

注意当数组作为函数的参数进行传递时,该数组自动退化为同类型的指针。

chara[]="helloworld"; char*p=a; cout<data[j+1]) { tag=true; inttemp=data[j]; data[j]=data[j+1]; data[j+1]=temp; } } if(!tag) break; } } voidmain(void) { vectordata; ifstreamin("c:\\data.txt"); if(!in) { cout<>temp; data.push_back(temp); } in.close();//关闭输入文件流 Order(data); ofstreamout("c:\\result.txt"); if(!out) { cout<next==NULL) returnhead; Node*p1=head; Node*p2=p1->next; Node*p3=p2->next; p1->next=NULL; while(p3!=NULL) { p2->next=p1; p1=p2; p2=p3; p3=p3->next; } p2->next=p1; head=p2; returnhead; } (2)已知两个链表head1和head2各自有序,请把它们合并成一个链表依然有序。

(保留所有结点,即便大小相同) Node*Merge(Node*head1,Node*head2) { if(head1==NULL) returnhead2; if(head2==NULL) returnhead1; Node*head=NULL; Node*p1=NULL; Node*p2=NULL; if(head1->datadata) { head=head1; p1=head1->next; p2=head2; } else { head=head2; p2=head2->next; p1=head1; } Node*pcurrent=head; while(p1!=NULL&&p2!=NULL) { if(p1->data<=p2->data) { pcurrent->next=p1; pcurrent=p1; p1=p1->next; } else { pcurrent->next=p2; pcurrent=p2; p2=p2->next; } } if(p1!=NULL) pcurrent->next=p1; if(p2!=NULL) pcurrent->next=p2; returnhead; } (3)已知两个链表head1和head2各自有序,请把它们合并成一个链表依然有序,这次要求用递归方法进行。

(Autodesk) 答案: Node*MergeRecursive(Node*head1,Node*head2) { if(head1==NULL) returnhead2; if(head2==NULL) returnhead1; Node*head=NULL; if(head1->datadata) { head=head1; head->next=MergeRecursive(head1->next,head2); } else { head=head2; head->next=MergeRecursive(head1,head2->next); } returnhead; }41.分析一下这段程序的输出(Autodesk) classB { public: B() { cout<instanceof B) { cout<maxnumber) { sec_max=maxnumber; maxnumber=data[i]; } else { if(data[i]>sec_max) sec_max=data[i]; } } returnsec_max; }43.写一个在一个字符串(n)中寻找一个子串(m)第一个位置的函数。

KMP算法效率最好,时间复杂度是O(n+m)。

44.多重继承的内存分配问题:  比如有classA:publicclassB,publicclassC{}  那么A的内存结构大致是怎么样的? 这个是compiler-dependent的,不同的实现其细节可能不同。

如果不考虑有虚函数、虚继承的话就相当简单;否则的话,相当复杂。

可以参考《深入探索C++对象模型》,或者: http://blog.csdn.net/wfwd/archive/2006/05/30/763797.aspx45.如何判断一个单链表是有环的?(注意不能用标志位,最多只能用两个额外指针)  structnode{charval;node*next;}  boolcheck(constnode*head){}//returnfalse:无环;true:有环 一种O(n)的办法就是(搞两个指针,一个每次递增一步,一个每次递增两步,如果有环的话两者必然重合,反之亦然): boolcheck(constnode*head) {   if(head==NULL) returnfalse;   node*low=head,*fast=head->next;   while(fast!=NULL&&fast->next!=NULL)   {     low=low->next;     fast=fast->next->next;     if(low==fast)returntrue;   }   returnfalse; };;;[i]<.h>[9];[0];>.h> 版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。

具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。

如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

存储 C++ 邮箱监控页面 c++面向对象const 流媒体学习笔记ffmpeg c++面向对象const成员函数 sedawk学习笔记 开发者社区> 开发与运维 > 文章 作者高分内容 更多 golang下的UUID生成 162 Windows11启动Docker提示端口被占用无法启动 110 Kratos微服务框架下的消息队列应用 482 Kratos微服务框架下实现CQRS架构模式 276 Kratos微服务框架下的认证和鉴权 522 相关文章 winterspeed 怎么设置阿里云ECS服务器自定义脚本? 18639 0 jiankunking C#FTP上传下载(汇总) 1、C#上传下载ftp(支持断点续传) 2、 C#FTP上传下载(支持断点续传) 854 0 a里上云建设 阿里云服务器如何登录?阿里云服务器的三种登录方法 购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系. 27734 0 扬朋 常见业务问题汇总 1、isv之前授权时用的支付宝账号需要切到新的账号上原有token是否还能继续使用? 如果app_id有变更,需要商户重新授权 2、修改门店信息接口,store_id不填可以吗? 修改门店是根据alipay_store_id确定要修改的门店号,如果填写了store_id,会将这个支付宝门店的商户门店号修改。

339 0 y2hr4cjzssnlm C++11Lambda表达汇总总结 C++11Lambda表达汇总总结 29 0 技术小胖子 excel技巧汇总 924 0 杰克.陈 C#开源汇总 原文:C#开源汇总 商业协作和项目管理平台-TeamLab 网络视频会议软件-VMukti 驰骋工作流程引擎-ccflow 【免费】正则表达式测试工具-Regex-Tester Windows-Phone-7-SDK Excel-读写组件-ExcelLibrary . 5069 0 developerguy Linux常用命令汇总 1、shutdown-s时间如果是想马上关机就直接输入0或者now;2、init0这个是运行级别关机;3、halt这个命令不是很好用;4、poweroff这个命令也是很好用的。

ctrl+d     删除光标所在位置上的字符相当于VIM里x或者dlctrl+h... 837 0 科技小能手 VisualStudio2010实战演练C#语句总汇 1115 0 kdmktdi2qut24 阿里云服务器端口号设置 阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。

19982 0 +关注 杨粼波 网游的老兵 1151 文章 0 问答 作者高分内容 更多 golang下的UUID生成 162 Windows11启动Docker提示端口被占用无法启动 110 Kratos微服务框架下的消息队列应用 482 Kratos微服务框架下实现CQRS架构模式 276 Kratos微服务框架下的认证和鉴权 522 文章排行榜 最热 最新 1 函数计算HTTP触发器支持异步,解放双手搭建Web服务 24447 2 从这些云原生企业身上,我看到了数字化创新者该有的样子 22691 3 阿里巴巴云数据仓库MaxCompute数据安全最佳实践 9481 4 OpenYurt开源之夏开始申请啦 15825 5 云开发两周年庆—游戏畅玩领好礼 15716 6 【转载】基于MaxCompute的大数据安全方案 13243 7 【转载】大数据在线离线一体化解决方案最佳实践 12331 8 [版本更新]PolarDB-XonOSS提供冷热数据分离存储 5073 9 不破不立!Fastjson2.0性能炸裂,为了下一个十年 6334 10 万字长文带你玩转阿里云ECS云服务器(涵盖ECS产品购买、ECS管理、ECS快速部署云盘服务、ECS快照原理) 83643 11 开源之夏2022重磅来袭!欢迎报名阿里云PolarDB社区项目! 4885 12 简历面试|不会讲故事的人到底有多吃亏 80734 13 PolarDB-X与X-DB、PolarDB 4512 14 开发者玩转机器学习不能错过的15篇深度文章! 3572 15 阿里云视频云互动虚拟技术,打造虚拟直播最佳沉浸式体验 3435 16 2022年电工杯B题5G网络环境下应急物资配送问题思路分析 3354 17 AliIAC智能音频编解码器:在有限带宽条件下带来更高质量的音频通话体验 2355 18 Zabbix对Tomcat的监控 26186 19 一个前端开发工程师的天猫精灵自定义技能开发评测报告 75309 20 EMR-StarRocks白皮书来啦! 82364 1 复旦-阿里电子信息专业学位研究生专业实践基地合作对接会成功举行 105 2 MySQL原理-InnoDB引擎-行记录存储-Redundant行格式 62 3 阿里云云原生一体化数仓—离线实时一体化新能力解读 52 4 Docker安装redis 101 5 快手实时数仓保障体系研发实践 216 6 PythonHttpServer实现服务监听和地址回调 8335 7 使用实践:Hologres锁介绍以及排查锁 91 8 一文详解|增长那些事儿 76 9 直播预告|PostgreSQL内核解读系列第一讲:PostgreSQL系统概述 79 10 Maxcompute-UNION数据类型对齐的方法 73 11 首次曝光!唯一全域最高等级背后的阿里云云原生安全全景图 65 12 模拟IDCspark读写MaxCompute实践 77 13 不止于观测|阿里云可观测套件正式发布 65 14 一日一技:使用Python翻译HTML中的文本字符串 78 15 GitHub正式上线CopilotAI编程工具:每月收费10美元,学生免费 64 16 1分钟Serverless搭建你的首个个人网站(完成就送猫超卡) 243 17 一文搞懂Vue3中slot插槽的使用! 95 18 一日一技:在Python里面实现链式调用 75 19 “智物智造”杯2022物联网创新应用大赛,你的idea改变世界! 316 20 新手必会的静态站点生成器——Gridsome 152 推荐文章 最新的产品福利,顶级大咖观点,尽在《开发者评测局》 大咖圆桌会:产学研共话BizDevOps。

开发技能PK竞技大赛第三期 乘风者计划邀您入驻社区,精彩权益即刻享 相关电子书 更多 JS零基础入门教程(上册) 立即下载 性能优化方法论 立即下载 手把手学习日志服务SLS,云启实验室实战指南 立即下载



請為這篇文章評分?