C++ Programmer's Cookbook

{C++ 基础} {C++ 高级} {C#界面,C++核心算法} {设计模式} {C#基础}

c/c++面试试题转载

 

1. 以下三条输出语句分别输出什么?[C]
char str1[]       = "abc";
char str2[]       = "abc";
const char str3[] = "abc";
const char str4[] = "abc";
const char* str5  = "abc";
const char* str6  = "abc";
cout << boolalpha << ( str1==str2 ) << endl; //
输出什么?
cout << boolalpha << ( str3==str4 ) << endl; //
输出什么?
cout << boolalpha << ( str5==str6 ) << endl; //
输出什么?

13.
C++内建型别 A B,在哪几种情况下B能隐式转化为A[C++中等]
答:
a. class B : public A { ……} // B
公有继承自A,可以是间接继承的
b. class B { operator A( ); } // B
实现了隐式转化为A的转化
c. class A { A( const B& ); } // A
实现了non-explicit的参数为B(可以有其他带默认值的参数)构造函数
d. A& operator= ( const A& ); //
赋值操作,虽不是正宗的隐式类型转换,但也可以勉强算一个

12.
以下代码中的两个sizeof用法有问题吗?[C]
void UpperCase( char str[] ) //
str 中的小写字母转换成大写字母
{
    for( size_t i=0; i<sizeof(str)/sizeof(str[0]); ++i )
        if( 'a'<=str[i] && str[i]<='z' )
            str[i] -= ('a'-'A' );
}
char str[] = "aBcDe";
cout << "str
字符长度为: " << sizeof(str)/sizeof(str[0]) << endl;
UpperCase( str );
cout << str << endl;

7.
以下代码有什么问题?[C]
void char2Hex( char c ) //
将字符以16进制表示
{
    char ch = c/0x10 + '0'; if( ch > '9' ) ch += ('A'-'9'-1);
    char cl = c%0x10 + '0'; if( cl > '9' ) cl += ('A'-'9'-1);
    cout << ch << cl << ' ';
}
char str[] = "I love
中国";
for( size_t i=0; i<strlen(str); ++i )
    char2Hex( str[i] );
cout << endl;

4.
以下代码有什么问题?[C++]
struct Test
{
    Test( int ) {}
    Test() {}
    void fun() {}
};
void main( void )
{
    Test a(1);
    a.fun();
    Test b();
    b.fun();
}

5.
以下代码有什么问题?[C++]
cout << (true?1:"1") << endl;

8.
以下代码能够编译通过吗,为什么?[C++]
unsigned int const size1 = 2;
char str1[ size1 ];
unsigned int temp = 0;
cin >> temp;
unsigned int const size2 = temp;
char str2[ size2 ];

9.
以下代码中的输出语句输出0吗,为什么?[C++]
struct CLS
{
    int m_i;
    CLS( int i ) : m_i(i) {}
    CLS()
    {
        CLS(0);
    }
};
CLS obj;
cout << obj.m_i << endl;

10. C++
中的空类,默认产生哪些类成员函数?[C++]
答:
class Empty
{
public:
    Empty();                          //
缺省构造函数
    Empty( const Empty& );            //
拷贝构造函数
    ~Empty();                         //
析构函数
    Empty& operator=( const Empty& ); //
赋值运算符
    Empty* operator&();               //
取址运算符
    const Empty* operator&() const;   //
取址运算符 const
};

3.
以下两条输出语句分别输出什么?[C++]
float a = 1.0f;
cout << (int)a << endl;
cout << (int&)a << endl;
cout << boolalpha << ( (int)a == (int&)a ) << endl; //
输出什么?
float b = 0.0f;
cout << (int)b << endl;
cout << (int&)b << endl;
cout << boolalpha << ( (int)b == (int&)b ) << endl; //
输出什么?

2.
以下反向遍历array数组的方法有什么错误?[STL]
vector array;
array.push_back( 1 );
array.push_back( 2 );
array.push_back( 3 );
for( vector::size_type i=array.size()-1; i>=0; --i ) //
反向遍历array数组
{
    cout << array[i] << endl;
}

6.
以下代码有什么问题?[STL]
typedef vector IntArray;
IntArray array;
array.push_back( 1 );
array.push_back( 2 );
array.push_back( 2 );
array.push_back( 3 );
//
删除array数组中所有的2
for( IntArray::iterator itor=array.begin(); itor!=array.end(); ++itor )
{
    if( 2 == *itor ) array.erase( itor );
}

11.
写一个函数,完成内存之间的拷贝。[考虑问题是否全面]
答:
void* mymemcpy( void *dest, const void *src, size_t count )
{
    char* pdest = static_cast<char*>( dest );
    const char* psrc = static_cast<const char*>( src );
    if( pdest>psrc && pdest<psrc+cout )
能考虑到这种情况就行了
    {
        for( size_t i=count-1; i!=-1; --i )
                pdest[i] = psrc[i];
    }
    else
    {
        for( size_t i=0; i<count; ++i )
            pdest[i] = psrc[i];
    }
    return dest;
}
int main( void )
{
    char str[] = "0123456789";
    mymemcpy( str+1, str+0, 9 );
    cout << str << endl;

    system( "Pause" );
    return 0;
}

posted on 2005-12-24 19:32 梦在天涯 阅读(2710) 评论(1)  编辑 收藏 引用 所属分类: CPlusPlus

评论

# re: c/c++面试试题转载 2008-07-06 00:42 追风少年

一看下一跳,原来自己基础还是不怎么的。
看样子还得务实点。  回复  更多评论   


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


公告

EMail:itech001#126.com

导航

统计

  • 随笔 - 461
  • 文章 - 4
  • 评论 - 746
  • 引用 - 0

常用链接

随笔分类

随笔档案

收藏夹

Blogs

c#(csharp)

C++(cpp)

Enlish

Forums(bbs)

My self

Often go

Useful Webs

Xml/Uml/html

搜索

  •  

积分与排名

  • 积分 - 1785188
  • 排名 - 5

最新评论

阅读排行榜