<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);"><span style="font-size:18px;">这里总结一些c++常遇到的问题</span></span>

不同类型之间的转换。

<span style="font-size:18px;">//1 string --> const char*
std::string s_1 = "lsw";
const char *cs_1 = s_1.c_str();
printf("const char * cs is %s \n", cs_1); //2 const char* --> string
const char *cs_2 = "lsw";
std::string s_2(cs_2);
printf("std::string s_2 is %s\n", s_2.c_str()); //3 string --> char*
std::string s_3 = "lsw";
char *cs_3;
auto len = s_3.length();
cs_3 = new char[len + 1];
char *res_3 = strcpy(cs_3, s_3.c_str());
printf("string to char* === %s", res_3); //4 char* --> string
char *cs_4 = "lsw"; //c++ 11标准中这里有警告,不推荐这么用
std::string s_4(cs_4); //5 const char* --> char *
const char* cs_5 = "lsw";
char *cs_6 = new char[100];//足够大
char *res_5 = strcpy(cs_6, cs_5); </span><p class="p1"><span style="font-size:18px;"><span class="s1"> printf</span><span class="s2">(</span>"cs_6 = %s \n"<span class="s2">, cs_6);</span></span></p><p class="p1"><span class="s2"><span style="font-size:18px;">
</span></span></p>

string, const char* ---> int, double, long

<span style="font-size:18px;">double	atof(const char *);
int atoi(const char *);
long atol(const char *);</span>

int --- > string

<span style="font-size:18px;">    char buff[100];
sprintf(buff, "%d", 990);
std::string sb = buff;</span>

已知strcpy的函数原型:char *strcpy(char *strDest, const char *strSrc)其中strDest 是目的字符串,strSrc 是源字符串。不调用C++/C 的字符串库函数,请编写函数 strcpy

/**
已知strcpy函数的原型是
char *strcpy(char *strDest, const char *strSrc);
其中strDest是目的字符串,strSrc是源字符串。
(1)不调用C++/C的字符串库函数,请编写函数 strcpy
(2)strcpy能把strSrc的内容复制到strDest,为什么还要char * 类型的返回值?
答:为了 实现链式表达式。
例如 int length = strlen( strcpy( strDest, “hello world”) );
*/
char *myStrcpy(char *str1, const char *str2) {
assert(str1 != nullptr && (str2 != nullptr));
char *res = str1;
while ((*str1++ = *str2++) != '\0') {
continue;
} return res;
} int myStrLen(const char* str) {
assert(str != nullptr);
auto len = 0;
while (*str++ != '\0') {
++ len;
} return len;
}

其他的一些知识

1、sizeof 和 strlen

char a[] = "12";
//这里sizeof输出 3 是a的位数包括 '\0'
cout << sizeof(a) << endl; char *p = a;
//输出 8,是指针p的字节数
cout << sizeof(p) << endl; char *str = "12";
//输出 2,不包含'\0'
cout << strlen(str) << endl; 2、宏定义
#define Min(a, b) ((a)>=(b)?(b):(a)) 3、string定义 .h
//
// MyString.h
// TestCPP
//
// Created by lsw on 14-12-24.
// Copyright (c) 2014年 lsw. All rights reserved.
// #ifndef __TestCPP__MyString__
#define __TestCPP__MyString__ #include <stdio.h>
class MyString {
public:
MyString(const char *str = NULL); // 普通构造函数
MyString(const MyString &other); // 拷贝构造函数
~MyString(void); // 析构函数
MyString & operator =(const MyString &other); // 赋值函数
private:
char *m_data; // 用于保存字符串 private:
int myStrlen(const char* str);
}; #endif /* defined(__TestCPP__MyString__) */ .cpp
//
// MyString.cpp
// TestCPP
//
// Created by lsw on 14-12-24.
// Copyright (c) 2014年 lsw. All rights reserved.
// #include "MyString.h"
#include <iostream>
#include <assert.h> MyString::MyString(const char* str) {
if (str == nullptr) {
m_data = new char[1];
m_data[0] = '\0';
} else {
auto len = myStrlen(str);
m_data = new char[len + 1];
assert(m_data != nullptr);
strcpy(m_data, str);
}
} MyString::MyString(const MyString &other) {
auto len = strlen(other.m_data);
m_data = new char[len + 1];
assert(m_data != nullptr);
strcpy(m_data, other.m_data);
} MyString::~MyString() {
delete [] m_data;
} MyString & MyString::operator=(const MyString &other) {
if (this == &other) {
return *this;
} delete [] m_data;
auto len = strlen(other.m_data);
m_data = new char[len + 1];
assert(m_data != nullptr);
strcpy(m_data, other.m_data);
return *this;
} int MyString::myStrlen(const char *str) {
assert(str != nullptr); int len = 0;
while (*str++ != '\0') {
++len;
} return len;
}

随机推荐

  1. open_binary_frm

    参数uchar* head 是已经分配好内存的64个字节的地址 http://mysql.taobao.org/monthly/2015/08/07/ /** *先从.frm文件读取64字节 *第28 ...

  2. SQL中返回一个字符串在另一个中存在的次数

    ALTER FUNCTION [reg].[f_GetSameStringCntNoSort] ( @str1 VARCHAR(),--源字符串,取该串中的@strLen长度的字符是否在目的字符串 @ ...

  3. POJ 2528 (线段树 离散化) Mayor's posters

    离散化其实就是把所有端点放在一起,然后排序去个重就好了. 比如说去重以后的端点个数为m,那这m个点就构成m-1个小区间.然后给这m-1个小区间编号1~m-1,再用线段树来做就行了. 具体思路是,从最后 ...

  4. MVC+Ef项目(4) 抽象业务逻辑层BLL层

    接下来,我们就要到业务逻辑层了,简单的说,业务逻辑层就是调用Repository(可以看做是DAL数据库访问层) 先来看看项目的架构 我们现在就开始来做BLL层.  同样,先编写  UserInfoS ...

  5. linux sed 命令

    转载:http://www.cnblogs.com/dong008259/archive/2011/12/07/2279897.html sed是一个很好的文件处理工具,本身是一个管道命令,主要是以行 ...

  6. appserver配置虚拟主机

    1, apach配置文件开启虚拟主机服务(C:\AppServ\Apache2.2\conf\httpd.conf)大概561行的位置 # Virtual hostsInclude conf/extr ...

  7. OK335xS ethtool 移植

    /******************************************************************* * OK335xS ethtool 移植 * 声明: * 由于 ...

  8. 【英语】Bingo口语笔记(43) - u长短音

  9. 【Python】入门 list有些不懂

    # -*- coding: utf-8 -*- # -*- coding: cp936 -*- 首行加这个 代码里就可以加注释 raw_input("Press Enter Exit&quo ...

  10. 查看MySQL的警告信息

    在王MySQL数据库导入数据的时候经常会出现警告,这些警告很容易被忽视,今天到数据的时候突然想看看警告的内容是什么,百度了一下mysql查看警告的命令 show warnings; 命令很简明,一查看 ...