免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 7513 | 回复: 12
打印 上一主题 下一主题

[C++] 字符串连接数字的宏定义 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-04-21 22:28 |只看该作者 |正序浏览
假如我有int型变量  a1 a2 a3 a4 a5 a6 a7 a8 a9 a10

想实现
for(int i=1;i<=10;++i)
{
    //完成ai 赋值操作
}

求宏定义连接 字符串和数字

多谢各位了...

论坛徽章:
0
13 [报告]
发表于 2009-04-22 17:18 |只看该作者
其实我们都达到 LZ 的要求了。:wink:

论坛徽章:
0
12 [报告]
发表于 2009-04-22 17:17 |只看该作者
如果那些变量是一起声明的,那么在它们在函数栈空间里面一定也是连续的,而且栈是由高往低生长的。

#define VARS_SET(var_head, var_count, Value)  {for(int i = 0; i < var_count; i++) *(&var_head - i) = Value;}

  int a1,a2,a3,a4,a5;
  VARS_SET(a1, 5, 100);

论坛徽章:
0
11 [报告]
发表于 2009-04-22 15:42 |只看该作者
不知道你是不是想要这样的:


  1. #include <iostream>
  2. #include<sstream>
  3. #include <string>

  4. using namespace std;

  5. int main()
  6. {
  7.     int a[] = { 10, 20, 30, 40, 50, 60, 70, 80, 90 };
  8.     stringstream sString;
  9.     for ( int i = 0; i < sizeof( a ) / sizeof( int ); i++ )
  10.     {   
  11.         sString << a[ i ];
  12.     }   
  13.     cout << sString.str() << endl;
  14.     return 0;
  15. }
复制代码

论坛徽章:
2
青铜圣斗士
日期:2015-11-26 06:15:59数据库技术版块每日发帖之星
日期:2016-07-24 06:20:00
10 [报告]
发表于 2009-04-22 14:59 |只看该作者
原帖由 皇家救星 于 2009-4-22 11:32 发表
这样都能编译通过 好诡异啊


int main()
{
    using namespace std;

    int a0=0,a1=1,a2=2,a3=3,a4=4;
    int* pa[] = { &a0 , &a1 , &a2 , &a3 , &a4 };
    for (int i=0;i<sizeof(pa)/sizeof(pa[0]);++i)
        *pa[ i ] = *pa[ i ] + i;

    cout<<a0<<" "<<a1<<" "<<a2<<" "<<a3<<" "<<a4<<endl;
    cin.get();
}

这是源代码预处理之后的结果。 显然是合法的C++代码嘛。
当然能编译通过。

我觉得这就是楼主的需求 ……
将a0, a1, a2, ... 这种设计, 转换到数组的设计。
楼主好像没看出来……

[ 本帖最后由 OwnWaterloo 于 2009-4-22 15:01 编辑 ]

论坛徽章:
0
9 [报告]
发表于 2009-04-22 11:32 |只看该作者
原帖由 OwnWaterloo 于 2009-4-21 23:25 发表
#include
#include

int main()
{
    using namespace std;

    int a0=0,a1=1,a2=2,a3=3,a4=4;
    int* pa[] = { BOOST_PP_ENUM_PARAMS(5,&a) };
    for (int i=0;i

这样都能编译通过 好诡异啊

突然冒出来一个&a

论坛徽章:
0
8 [报告]
发表于 2009-04-22 05:09 |只看该作者
#define CONCAT(mystring,mynumber) mystring#mynumber

这样?

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:53:172015亚冠之水原三星
日期:2015-06-02 16:34:202015年亚冠纪念徽章
日期:2015-10-19 18:13:37程序设计版块每日发帖之星
日期:2015-11-08 06:20:00
7 [报告]
发表于 2009-04-22 00:55 |只看该作者
只能一个一个的连,或者用数组

论坛徽章:
0
6 [报告]
发表于 2009-04-22 00:11 |只看该作者

回复 #1 迷離 的帖子

这个写的是不算太清楚!呵呵,没理解LZ的意思! :wink:

论坛徽章:
2
青铜圣斗士
日期:2015-11-26 06:15:59数据库技术版块每日发帖之星
日期:2016-07-24 06:20:00
5 [报告]
发表于 2009-04-21 23:33 |只看该作者

回复 #4 迷離 的帖子

已经和你需要的功能很接近了吧?

这个for循环:
    for (int i=0;i<sizeof(pa)/sizeof(pa[0]);++i)
        *pa[ i ] = *pa[ i ] + i;

操作的就是:
int a0=0,a1=1,a2=2,a3=3,a4=4;

从输出就可以看出这点。


要完全达到你的目标 ……   我真想不出什么办法 ……
将a0, a1, ... an, 重构为 int a[n-1] 吧。。。
  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP