C++笔试题库-------Coding整理
1. 反转字符串
char* strrev1(const char* str)
{
int len = strlen(str);
char *temp = new char[len + ];
char *p = temp + len;
*p = '\0';
p--; while(*str != '\0')
{
*p-- = *str++;
}
p = NULL;
return temp;
}
2. 实现strcmp,对比两个字符串,相同返回0,前者大于后者返回正数,反之,返回负数
首先,函数原型得写正确:int strcmp(char *source, char *dest)
int strcmp(char *source, char *dest)
{ int ret = ;
while(!(ret = *(unsigned char *)source - *(unsigned char *)dest) && *dest)
{
++source;
++dest;
} if(ret < )
ret = -;
else if(ret > )
ret = ; return ret;
}
3. strcpy的实现
char *strcpy(char *dest, const char *src)
{
if(NULL == dest || NULL = src) return NULL;
char* r = dest;
while((*(dest++) = *(src++)) != '\0')
;
return r;
}
3. 请定义一个宏,比较两个数a、b的大小,不能使用大于、小于、if语句
#define Max((a),(b)) ((a)/(b))?(a):(b)
4. 还是关于宏的问题:
下面例子输出的是什么,做了什么运算得出的结果?
#define SQR(X) X*X int _tmain(int argc, _TCHAR* argv[])
{
int a = ;
int k = ;
int m = ;
a /= SQR(k+m)/SQR(k+m);
printf("%d\n",a);
return ;
}
解释:宏没有类型检查,只是做了简单的符号对换!其运算相当于下面语句:
a/=k+m*k+m/k+m*k+m;
即 a = a/7,所以,答案为:1
5. const 符号常量;
(1)const char *p
(2)char const *p
(3)char * const p
说明上面三种描述的区别;
解释:(1)(2)都是同一个意思,p是一个指针,指向一个字符常量,p自身的内容是可变的,但是p指向的内容是不可变的;
(3)与前两者不同,p是一个常量指针,初始化之后,p自身的内容不可变,但是p指向的内容是可变的。
6. socket缓冲区大小设置
//设置发送和接收缓冲区
int rcvbuf;
int rcvbufsize=sizeof(int);
if(getsockopt(m_Socket,SOL_SOCKET,SO_RCVBUF,(char*)
&rcvbuf,&rcvbufsize)!=SOCKET_ERROR)
{
if(rcvbuf<)
rcvbuf=;
setsockopt(m_Socket,SOL_SOCKET,SO_RCVBUF,(char*)
&rcvbuf,rcvbufsize);
}
if(getsockopt(m_Socket,SOL_SOCKET,SO_SNDBUF,(char*)
&rcvbuf,&rcvbufsize)!=SOCKET_ERROR)
{
if(rcvbuf<)
rcvbuf=;
setsockopt(m_Socket,SOL_SOCKET,SO_SNDBUF,(char*)
&rcvbuf,rcvbufsize);
}
7. 在不实例化struct的情况下,求成员变量的偏移量
#define FIND(struc, e) (unsigned int)(&((struc*)0)->e) typedef struct stu
{
char a[];
int b;
double d;
}stu; int main()
{
printf("%d\n",FIND(stu,a));
printf("%d\n",FIND(stu,b));
printf("%d\n",FIND(stu,d));
return ;
}
8. 设计仅能在堆创建的类
思路:将析构函数设置为private,从而使得如果在栈上创建该类的话,会出现编译期间错误!
#include<iostream>
using namespace std; class onlyHeap
{
public:
onlyHeap()
{
cout<<"constructor"<<endl;
} void destroy()
{
delete this;
} private:
~onlyHeap()
{
cout<<"destructor"<<endl;
}
}; int main()
{
//onlyHeap he; //error while complier
onlyHeap *he = new onlyHeap();
he->destroy();
return ;
}
9. 设计仅能在栈上创建的类
思路:重载 new 和 delete 操作符为 private。
#include <iostream>
using namespace std;
class OnlyStack
{
public: OnlyStack()
{
cout<<"构造"<<endl;
}
~OnlyStack()
{
cout<<"析构"<<endl;
}
private:
void* operator new (size_t t);
void operator delete(void *ptr);
}; int main()
{
//A* a = new A; //会报错
OnlyStack a;
return ;
}
10. dynamic_cast 与 static_cast 的区别
dynamic_cast
用法:dynamic_cast <type-id> (expression)
可以使用 dynamic_cast 操作符将基类类型对象的引用或指针转换为同一继承层次中其他类型的引用或指针。它涉及运行时类型检查。
dynamic_cast 运算符可以在执行期决定真正的类型。
如果 downcast 是安全的(也就说,如果基类指针或者引用确实指向一个派生类对象)这个运算符会传回适当转型过的指针。downcast:基类=>继承类
如果 downcast 不安全,这个运算符会传回空指针(也就是说,基类指针或者引用没有指向一个派生类对象)。
static_cast
用法:static_cast < type-id > ( expression )
该运算符把expression转换为type-id类型,但没有运行时类型检查来保证转换的安全性。
它主要有如下几种用法:
①用于类层次结构中基类(父类)和派生类(子类)之间指针或引用的转换。
进行上行转换(把派生类的指针或引用转换成基类表示)是安全的;
进行下行转换(把基类指针或引用转换成派生类表示)时,由于没有动态类型检查,所以是不安全的。
②用于基本数据类型之间的转换,如把int转换成char,把int转换成enum。这种转换的安全性也要开发人员来保证。
③把空指针转换成目标类型的空指针。
④把任何类型的表达式转换成void类型。
注意:static_cast不能转换掉expression的const、volatile、或者__unaligned属性。
11. strlen 和 sizeof的使用
const char *p = "Hello World";
char p[] = "Hello World";
分别求长度和所占用空间大小。
提示:求长度都可以用strlen(p),求占内存空间大小第一个不能用sizeof,第二个可以用sizeof。另外,第二个:strlen(p) = 11, sizeof(p) = 12
http://blog.csdn.net/lincyang/article/category/710309
C++笔试题库-------Coding整理的更多相关文章
- acwing 算法面试、笔试题公开课整理记录
week1 Google KickStart 2019 A轮 讲解视频地址AcWing 549. 训练 tag: 排序 遍历 在线练习地址AcWing 550. 包裹 在线练习地址Ac ...
- Oracle笔试题库 附参考答案
1. 下列不属于ORACLE的逻辑结构的是(C) 区 段 数据文件 表空间 2. 下面哪个用户不是ORACLE缺省安装后就存在的用户(A) A . SYSDBA B. SYSTEM C. SCOTT ...
- Oracle笔试题库之问答题篇-总共60道
1.把表A从表空间TSP1更改成表空间TSP2的方法 解答:alter table A move tablespace TSP2 2.删除表的列: 解答:alert table 表名 drop 列名 ...
- C++笔试题库之编程、问答题 100~150道
101. winsock建立连接的主要实现步骤? 答: 服务器端:socket()建立套接字,绑定(bind)并监听(listen),用accept()等待客户端连接, accept()发现有客户端连 ...
- Java笔试题库之选题题篇【71-140题】
71下面哪几个函数是public void method(){̷}的重载函数?() A.public void method( int m){̷} B.public int method(){̷} C ...
- C++笔试题库之编程、问答题 200~300道
201下面的代码有什么问题?并请给出正确的写法. void DoSomeThing(char* p) { char str[16]; int n; assert(NULL != p); sscanf( ...
- C++笔试题库之编程、问答题 150~200道
151.写出判断ABCD四个表达式的是否正确, 若正确, 写出经过表达式中 a的值 int a = 4; (A)a += (a++); (B) a += (++a) ;(C) (a++) += a;( ...
- Java笔试题库之选题题篇【1-70题】
1.下面中哪两个可以在A的子类中使用:( ) class A { protected int method1 (int a, int b) { return 0; } } A. public int ...
- Java笔试题库之选题题篇【141-210题】
141.Struts框架可以支持以下哪种程序开发语言? A.C B.C++ C.Java D.C# 解答:C 142.在Servlet处理请求的方式为. A.以进程的方式 B.以程序的方式 C.以线程 ...
随机推荐
- php foreach 使用&(与运算符)引用赋值要注意的问题
首先了解一下“引用赋值”,看一个例子: <?php <?php $a=123; $a=123; $b=$a; $b=&$a; $a=321; $a=321; echo"$ ...
- A Script Pro nginx URL重写规则无法播放MP4解决方法
I am using nginx and I have already add the line location /file/ { rewrite ^/-]+)/([-]+)/([^/]*)/([- ...
- jQuery在on绑定事件时,使用Function.prototype.bind上下文,只能用off(event)解绑函数,否则可能导致事件叠加
因为一个bind函数,未解绑成功导致事件叠加,搞了一下午. keyup事件绑定: this.$document.on('keyup', this.keyUp.bind(this)); 原解绑函数: t ...
- Cordova VS React Native 谁是未来? - b
对于原生native还是倍加推崇的,极佳的用户体验和性能让我学的如痴如醉,可是互联网这个世界可以用一句话可以总结:没有什么是不可能的.自从阿里淘宝天猫横空出世,它们教会了人们如何在网上购物,然后仿佛一 ...
- CSS预处理器之SASS用法指南
CSS预处理器之SASS用法指南 一.什么是SASS Sass是是一种基于ruby编写的CSS预处理器,提供了许多便利的写法,大大节省了设计者的时间,使得CSS的开发,变得简单和可维护. 诞生于200 ...
- 【Java】java的内存浅析
一.闲谈下 201407月记着那时候身体垮了下来,呵呵.想说,对自己的说,也是对大家的负责吧.那时候胸疼胸闷,然后几乎累垮了,我还坚持了一星期,那一星期真的迷迷糊糊.完全不能看代码,看代码就晕.一直想 ...
- 根据div 标签 查看数组@class=modulwrap 下面的/table/tbody/tr/td
<div class="modulwrap"> <div class="request_title"> <span class=& ...
- Microsoft Office 2013 激活方法
Microsoft Office 2013 激活方法 Microsoft Office 2013是微软的新一代Office办公软件,全面采用Metro界面,包括Word.PowerPoint.Ex ...
- P1894セチの祈り
描述 在 Ninian 的花园里,有许多琼花,环绕着中间的凉亭.有 N 片琼花,组成一个环.Ninian 想在凉亭中发动 [セチの祈り] , 需要划分出三个区域的琼花,为了平均,要最大化面积最小的区域 ...
- github继续折腾
又在折腾github了,本来以前在neworiginou这个github上上传过项目的: 现在想在另一个github上joely上传项目,发现按以前的流程做个测试,居然没能上传成功! 经发现,以前的n ...