我如何将这段代码转换为C ++?
string[] strarr = {"ram","mohan","sita"};
foreach(string str in strarr) {
listbox.items.add(str);
}
Answers:
std::array<std::string, 3> strarr = {"ram", "mohan", "sita"};
for(const std::string& str : strarr) {
listbox.items.add(str);
}
std::string strarr[] = {"ram", "mohan", "sita"};
for(int i = 0; i < 3; ++i) {
listbox.items.add(strarr[i]);
}
要么
std::string strarr[] = {"ram", "mohan", "sita"};
std::vector<std::string> strvec(strarr, strarr + 3);
std::vector<std::string>::iterator itr = strvec.begin();
while(itr != strvec.end()) {
listbox.items.add(*itr);
++itr;
}
boost::array<std::string, 3> strarr = {"ram", "mohan", "sita"};
BOOST_FOREACH(std::string & str, strarr) {
listbox.items.add(str);
}
for(int i = 0; i < sizeof(strarr)/sizeof(strarr[0]); i++)第一个代码示例中那样,如何处理数组的大小呢?
在习惯了varC#中的关键字之后,我开始auto在C ++ 11中使用该关键字。它们都通过推断来确定类型,并且在您只希望编译器为您确定类型时很有用。这是代码的C ++ 11端口:
#include <array>
#include <string>
using namespace std;
array<string, 3> strarr = {"ram", "mohan", "sita"};
for(auto str: strarr) {
listbox.items.add(str);
}
Boost具有一个宏,可以为您完成此操作。
只是为了好玩(新的lambda函数):
static std::list<string> some_list;
vector<string> s;
s.push_back("a");
s.push_back("b");
s.push_back("c");
for_each( s.begin(), s.end(), [=](string str)
{
some_list.push_back(str);
}
);
for_each( some_list.begin(), some_list.end(), [](string ss) { cout << ss; } );
虽然建议做一个简单的循环:-)
就像是:
const char* strarr = {"ram","mohan","sita", 0L};
for(int i = 0; strarr[i]; ++i)
{
listbox.items.add(strarr[i]);
}
也适用于标准C。不确定在C ++中如何在没有null元素的情况下检测strarr的结尾,但是上述方法应该可以工作。
sizeof(strarr)/sizeof(strarr[0])可以获取数组中元素的数量;但是,如果它是一个动态分配的数组(或者如果您拥有的只是一个指针),那么就无法获取大小-您必须通过其他一些带外方法来获取它。
std::size_t。
string [] strarr = {“ ram”,“ mohan”,“ sita”};
#include <string>
std::string strarr = { "ram", "mohan", "sita" };
要么
const char* strarr[] = { "ram", "mohan", "sita" };
foreach(strarr中的字符串str){listbox.items.add(str); }
for (int i = 0; i < sizeof strarr / sizeof *strarr; ++i)
listbox.items.add(strarr[i]);
注意:您也可以将字符串放入std :: vector而不是数组中:
std::vector<std::string> strvec;
strvec.push_back("ram");
strvec.push_back("mohan");
strvec.push_back("sita");
for (std::vector<std::string>::const_iterator i = strvec.begin(); i != strvec.end(); ++i)
listbox.items.add(*i);
简单形式:
std::string data[] = {"ram","mohan","sita"};
std::for_each(data,data+3,std::bind1st(std::mem_fun(&Y::add), &(listbox.items)));
一个实际的例子:
#include <algorithm>
#include <string>
#include <iostream>
#include <functional>
class Y
{
public:
void add(std::string value)
{
std::cout << "Got(" << value << ")\n";
}
};
class X
{
public:
Y items;
};
int main()
{
X listbox;
std::string data[] = {"ram","mohan","sita"};
std::for_each(data,data+3,std::bind1st(std::mem_fun(&Y::add), &(listbox.items)));
}
使用boost是最好的选择,因为它可以帮助您提供简洁明了的代码,但是如果您要坚持使用STL
void listbox_add(const char* item, ListBox &lb)
{
lb.add(item);
}
int foo()
{
const char* starr[] = {"ram", "mohan", "sita"};
ListBox listBox;
std::for_each(starr,
starr + sizeof(starr)/sizeof(char*),
std::bind2nd(std::ptr_fun(&listbox_add), listBox));
}
使用C ++ 14:
#include <string>
#include <vector>
std::vector<std::string> listbox;
...
std::vector<std::string> strarr {"ram","mohan","sita"};
for (const auto &str : strarr)
{
listbox.push_back(str);
}
for (const auto &str : {"ram","mohan","sita"} ) ...吗?
std::for_each。