vecotr 容器中插入多条字符串,再将 vector 的地址转换为 char**

代码如下:

#include <stdio.h>

#include <string>
#include <vector> int main() {
std::vector<std::string> url_vector;
url_vector.push_back("www.baidu.com");
url_vector.push_back("www.taobao.com");
url_vector.push_back("www.google.com"); const char** urls = new const char*[url_vector.size() + 1];
for (size_t i = 0; i < url_vector.size(); i++) {
urls[i] = url_vector[i].c_str();
} // print
for (size_t j = 0; j < url_vector.size(); j++) {
// 移动 char* 指针
printf("%s\n", urls[j]);
printf("-----------------------分割线-------------1\n");
for (size_t k = 0; k < url_vector[j].size(); k++) {
// 移动 char** 指针
printf("%c", urls[j][k]);
}
printf("\n-----------------------分割线-------------2\n");
} return 0;
}

调试:

分析:

0 w w w . b a i d u . c o m  
1 w w w . t a o b a o . c o m
2 w w w . g o o g l e . c o m

char* 指针是解引用字符串的首地址,即 char[0],char[1],char[2] 分别存放的是三个字符串的首地址

char** 指针是解引用字符串中各个字符的地址,比如,char[0][0],char[1][0],char[2][0] 分别放的是三个字符串的首字母

我们可以查看它们所有的地址,

#include <stdio.h>

#include <string>
#include <vector> int main() {
std::vector<std::string> url_vector;
url_vector.push_back("www.baidu.com");
url_vector.push_back("www.taobao.com");
url_vector.push_back("www.google.com"); const char** urls = new const char*[url_vector.size() + 1];
for (size_t i = 0; i < url_vector.size(); i++) {
urls[i] = url_vector[i].c_str();
} // print
for (size_t j = 0; j < url_vector.size(); j++) {
// 移动 char* 指针
printf("%s\n", urls[j]);
printf("%p\n", urls[j]);
printf("-----------------------分割线-------------1\n");
for (size_t k = 0; k < url_vector[j].size(); k++) {
// 移动 char** 指针
printf("%c", urls[j][k]);
}
printf("\n-----------------------分割线-------------2\n");
for (size_t l = 0; l < url_vector[j].size(); l++) {
printf("%p\n", &urls[j][l]);
}
printf("\n-----------------------分割线-------------3\n");
} return 0;
}

结果:

笔记:

可以看作为一维数组(在内存中存储都是线性一维的)

一维数组 a[i] = *(a+i),同理二维 a[i][j] = *(a[i] + j) = *(*(a + i) + j)


printf("%p\n", urls[i]);
printf("%p\n", &urls[i]);
printf("%p\n", &urls);

打印 urls 的地址,

0x012F6964 存放的是字符串,见上图,

0x12F6820 存放的是 0x012F6964 地址,0xE4FE84 存放的是 0x012F6820 地址,见下图

另附:

How to convert vector<vector<int>>to int**?

std::vector<std::string> 与 char** 的转换的更多相关文章

  1. 单独删除std::vector <std::vector<string> > 的所有元素

    下面为测试代码: 1.创建 std::vector< std::vector<string> > vc2; 2.初始化 std::vector<string> vc ...

  2. matlab转c++代码实现(主要包含C++ std::vector,std::pair学习,包含数组与常数相乘,数组相加减,将数组拉成一维向量,图片的读入等内容)

    MATLAB部分: xmap = repmat( linspace( -regionW/2, regionW/2, regionW), regionH, 1 );%linspace [x1,x2,N] ...

  3. 关于==和equals()方法&Java中string与char如何转换&String,StringBuffer

    1.对于基本数据类型,可以直接使用==和!=进行内容比较 如:int x=30;        int y=30;         x==y;  //true 基本数据类型 简单类型(基本类型) bo ...

  4. std::vector<std::vector<> >

    上次看到这个有点晕了,其实这个vector保存的是std::vector<> #include <vector> #include <iostream> using ...

  5. string与char* 互相转换以及周边问题

    先插一个小知识点 string str = "abc" str += 'd'; cout<<str<<endl;  //"abcd"   ...

  6. string、char *的转换

    string转char* 主要有三种方法可以将str转换为char*类型,分别是:data(); c_str(); copy(); data()方法 string str = "hello& ...

  7. std::string,std::vector,std::accumulate注意事项

    在用string做字符串拼接时,会发现随着string的增大越来越慢,原因主要是string(和vector)是基于现行内存的数据结构,在海量数据时,经常会申请新的一块内存,把原有的数据拷贝过去然后再 ...

  8. C++ std::unordered_map使用std::string和char *作key对比

    最近在给自己的服务器框架加上统计信息,其中一项就是统计创建的对象数,以及当前还存在的对象数,那么自然以对象名字作key.但写着写着,忽然纠结是用std::string还是const char *作ke ...

  9. 实战c++中的string系列--std:vector 和std:string相互转换(vector to stringstream)

    string.vector 互转 string 转 vector vector  vcBuf;string        stBuf("Hello DaMao!!!");----- ...

  10. (原创)动态内存管理练习 C++ std::vector<int> 模拟实现

    今天看了primer C++的 “动态内存管理类”章节,里面的例子是模拟实现std::vector<std::string>的功能. 照抄之后发现编译不通过,有个库函数调用错误,就参考着自 ...

随机推荐

  1. [转帖]nmon使用及监控数据分析

    [使用] [监控数据分析] 参考链接:nmon监控数据分析 性能测试中,各个服务器资源占用统计分析是一个很重要的组成部分,通常我们使用nmon这个工具来进行监控以及监控结果输出. 一.在监控阶段使用类 ...

  2. [转帖]一口气看完45个寄存器,CPU核心技术大揭秘

    https://www.cnblogs.com/xuanyuan/p/13850548.html 序言 前段时间,我连续写了十来篇CPU底层系列技术故事文章,有不少读者私信我让我写一下CPU的寄存器. ...

  3. OpenEuler2203 基于容器和本地文件部署Redis Cluster的过程以及简单性能测试

    背景 其实文件搭建和集群搭建没有任何区别 这次用先用容器搭建出来,然后测试一下性能 想着再使用本地部署的方式搭建一下. 两项验证容器和基于文件的搭建的性能差异 部分资料来源: https://blog ...

  4. vue动画进入-完整的动画/有进入离开

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. 【代码分享】使用 avx2 + 查表法,优化凯撒加密

    作者:张富春(ahfuzhang),转载时请注明作者和引用链接,谢谢! cnblogs博客 zhihu Github 公众号:一本正经的瞎扯 接上一篇:[代码分享]使用 avx512 + 查表法,优化 ...

  6. 大数据面试题集锦-Hadoop面试题(一)

    目录 1.集群的最主要瓶颈 2.Hadoop运行模式 3.Hadoop生态圈的组件并做简要描述 4.解释"hadoop"和"hadoop 生态系统"两个概念 5 ...

  7. github 2fa中国认证及TOTP App

    Because of your contributions on GitHub, two-factor authentication will be required for your account ...

  8. 从 WebStorm 转到 VSCode!使用一周体验报告

    前言 最近我的 Jetbrains 开源项目授权到期了,想要续订的时候发现 Jetbrains 提高了开源项目申请门槛,我的 StarBlog 项目因为名字里包含 blog 这个词无法申请,虽然我在 ...

  9. Midjourney|文心一格prompt教程[Text Prompt(下篇)]:游戏、实物、人物、风景、动漫、邮票、海报等生成,终极模板教学

    Midjourney|文心一格prompt教程[Text Prompt(下篇)]:游戏.实物.人物.风景.动漫.邮票.海报等生成,终极模板教学 场景6:游戏 Prompt 真的越长越好吗? 按照 Mi ...

  10. LeetCode刷题日记 2020/03/25

    力扣刷题继续! 题目:计算三维形体表面积 题干 在 N * N 的网格上,我们放置一些 1 * 1 * 1  的立方体. 每个值 v = grid[i][j] 表示 v 个正方体叠放在对应单元格 (i ...