c++一些问题总结
<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;
}
随机推荐
- 1038: [ZJOI2008]瞭望塔
半平面交. 半平面指的就是一条直线的左面(也不知道对不对) 半平面交就是指很多半平面的公共部分. 这道题的解一定在各条直线的半平面交中. 而且瞭望塔只可能在各个点或者半平面交折线的拐点处. 求出半平面 ...
- QDialog之屏蔽Esc键
简述 Qt中Esc键会在一些控件中默认的进行一些事件的触发,比如:QDialog,按下Esc键窗口消失.大多数情况下,我们不需要这么做,那么就需要对默认事件进行屏蔽. 简述 源码分析 事件过滤器 事件 ...
- HDU 1051 Wooden Sticks【LIS】
题意:给出n个木头的重量wi,长度li,如果满足w[i+1]>=w[i]且l[i+1]>=l[i],则不用耗费另外的加工时间,问至少需要多长时间加工完这些木头. 第一次做这一题目也没有做出 ...
- spring、springmvc、mybatis整合笔记
这段时间上一个项目刚做完,下一个项目还没开始,趁这个时候来认真总结一下上个项目使用的ssm开发框架.由于,项目中关于使用ssm这部分的代码和配置是我们项目的整体架构师一个独立完成的,我们只负责业务部分 ...
- codevs 4927 线段树练习5
赶在期末考试之前把这道傻逼题调了出来. #include<iostream> #include<cstdio> #include<cstring> #include ...
- 切记一定要防止恶意用户直接访问Ajax请求地址
多年前的一个web项目, 有一个地方是用ajax发送短信验证码, 当时没考虑好, 没判断来路, 这几天被人恶意滥用发送了很多垃圾短信, 投诉到公司来了. 今天一看代码吓出一身冷汗! 以后一定要记得判 ...
- 12月2日,上海Cloud Foundry Summit, Azure Cloud Foundry 团队期待和你见面!
12月2日,上海Cloud Foundry Summit, Azure Cloud Foundry 团队期待和你见面! 12日2日对中国Cloud Foundry的用户和开源社区来说,是极有意义的一天 ...
- 部署在IIS服务器的asp.net 网站,禁止访问指定类型文件
网站上的一些文件不希望用户访问,可以通过下面的方式简单实现.不需写代码(在IIS6下试验过). 第一步,在IIS中实现映射. 哪些文件需要特殊处理. 通俗的将就是将哪种类型的文件交给特定的工厂来处理. ...
- T-SQL备忘(2):聚合函数运算和NULL
我们看表的数据: 而select AVG(Age) from Member1的结果为27.自己算一下就知道136/6 =22.666.而不是27,因此知道实际上Age为NULL的行没有参与运算.即: ...
- SQLSERVER 检查字段值域并输出行数和值列表
select * from ( SELECT 'C_DILEI' as fen,'地类' as fcn, 'NVARCHAR'as ftype, '2'as flen, ( SELECT count( ...