質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
char

charは文字データ型を指します。一文字分の文字コードの格納を想定としている型です。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

Q&A

解決済

2回答

1067閲覧

読み込んだ文字列と同じ数のchar配列を用意して格納したい。

退会済みユーザー

退会済みユーザー

総合スコア0

char

charは文字データ型を指します。一文字分の文字コードの格納を想定としている型です。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

0グッド

0クリップ

投稿2021/04/18 07:46

/////コメント部のコードですがなぜ new char[]で指定した数要素数を確保しているにも関わらず同じ値にならないのでしょうか?読み込んだ文字列のデータは7なので7と表示されるはずなのですが4と表示されてしまいます。つまりint r = sizeof(str) / sizeof(str[0]);が悪いのですがこれの何が悪いのでしょうか? 

やりたいことは読み込んだ文字列を同じ文字列の長さのchar配列を用意してそこに入れたいです。

イメージ説明

cpp

1#include <iostream> 2#include <string> 3#include <fstream> 4 5int main() 6{ 7 std::ifstream ifs; 8 ifs.open("sample.txt"); 9 10 if (ifs.is_open() == true) 11 { 12 std::string data; 13 ifs >> data; 14 std::cout << "data.size(): " << data.size() << std::endl; 15 16 char* str = new char[(int)data.size()]; 17//////////////////////////////////////////////////////////////////////////////////////////// 18 int r = sizeof(str) / sizeof(str[0]); // 19 std::cout << r <<std::endl; 20//////////////////////////////////////////////////////////////////////////////////////////// 21 22 23 // errno_t err = strcpy_s(str,(rsize_t)10, data.c_str()); 24 25 std::cout <<"内容: "<< data << std::endl; 26 } 27 else { 28 std::cout << "ファイルが開けません。" << std::endl; 29 } 30 31 32 33 return 0; 34}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

かんがえすぎ。

C++

1#include <iostream> 2#include <string> 3#include <fstream> 4 5int main() { 6 std::ifstream ifs("sample.txt"); 7 8 if ( !ifs.is_open() ) { 9 std::cout << "ファイルが開けません。" << std::endl; 10 return -1; 11 } 12 std::string data; 13 ifs >> data; 14 std::cout << "data.size(): " << data.size() << std::endl; 15 16 char* str = new char[data.size()+1]; 17 strcpy_s(str,data.size()+1, data.c_str()); 18 19 std::cout <<"内容:["<< str << "]\n"; 20 delete[] str; 21}

int r = sizeof(str) / sizeof(str[0]);が悪いのですがこれの何が悪いのでしょうか? 

char* str なんだから、sizeof(str) = sizeof(char*) であり、大抵8(あるいは4) を返します。
char str[100] だったら sizeof(str) = sizeof(char[100]) だから 100でしょうけどね。
んなわけで、sizeof(str) / sizeof(str[0]) がまともに動くのは str が固定長配列のときに限ります。

[おまけ] C++ なら sizeof(xxx) / sizeof(xxx[0]) あらため std::size 使いましょう。

C++

1#include <iostream> 2#include <vector> 3#include <iterator> 4 5int main() { 6 char cary[123]; 7 long lary[456]; 8 std::vector<int> ivec(789); 9 int* iary; 10 11 std::cout << std::size(cary) << std::endl; 12 std::cout << std::size(lary) << std::endl; 13 std::cout << std::size(ivec) << std::endl; 14//std::cout << std::size(iary) << std::endl; // ちゃんとエラーになってくれる 15}

投稿2021/04/18 07:55

編集2021/04/18 08:18
episteme

総合スコア16612

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yumetodo

2021/04/18 08:33

なお通常は「読み込んだ文字列を同じ文字列の長さのchar配列を用意してそこに入れたい」という要求が出ること自体に問題があり、std::stringで完結させるべきかとは思われます。
episteme

2021/04/18 10:39 編集

↑同意。 あとC++なんだから strcpy_s あらため: char* str = new char[data.size()+1]; str[data.copy(str, data.size()] = '\0';
guest

0

int r = sizeof(str) / sizeof(str[0]); //

sizeof(str) って、ポインタのサイズですよ

投稿2021/04/18 07:49

y_waiwai

総合スコア88042

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問