回答編集履歴
2
エラーになる話の追記
answer
CHANGED
|
@@ -43,4 +43,30 @@
|
|
|
43
43
|
|
|
44
44
|
「以前kazma-sさんから頂いたプログラム」がどのようなコードだったかは知りませんが、たぶん、ノード単位で使うことを想定していなかったのだと思われます。ノード単位でアクセスしたい場合は、ノード毎に取得できるAPIを呼び出す必要があります。それらも含めてライブラリのドキュメントに書いてありますし、サンプルにも簡単な例が書いてあります。他人から貰ったコードをそのまま使うのではなく、あくまで参考とするのが普通です。ライブラリのドキュメントをよく読んだ上で、利用可能な部分は使う、利用できなさそうな部分は別の物に起きかけるなど、自分でできるようにならないと、プログラムが完成することはないでしょう。
|
|
45
45
|
|
|
46
|
-
なお、`\t`が何かというとことに答えないのは、この質問が、[XY 問題](https://ja.meta.stackoverflow.com/questions/2701)になってしまっているからです。
|
|
46
|
+
なお、`\t`が何かというとことに答えないのは、この質問が、[XY 問題](https://ja.meta.stackoverflow.com/questions/2701)になってしまっているからです。
|
|
47
|
+
|
|
48
|
+
---
|
|
49
|
+
|
|
50
|
+
【追記】
|
|
51
|
+
|
|
52
|
+
例示のCのコードについてエラーになると言われたので、なぜ、エラーになる場合があるのかについて解説します。なお、CやC++の基礎的な知識が前提となりますので、あらかじめご了承ください。
|
|
53
|
+
|
|
54
|
+
例示の**C**のコードを**C++として**コンパイルした場合、コンパイラの種類やバージョン、および、オプションによっては、
|
|
55
|
+
|
|
56
|
+
* 問題なくコンパイルできる。
|
|
57
|
+
* 警告が表示されるがコンパイルできる。
|
|
58
|
+
* エラーとなりコンパイルできない。
|
|
59
|
+
|
|
60
|
+
の3パターンがあらわれます。これは文字列リテラルに関する歴史的経緯とその後のC++の対応によるものです。
|
|
61
|
+
|
|
62
|
+
まず、C++はCを拡張した作られた言語ですが、CがそのままC++として必ず動くわけではありません。C++はCの完全上位互換ではなく、Cとは非互換な部分があります。今回はその非互換な部分の一つが現れた結果です。.
|
|
63
|
+
|
|
64
|
+
`"abc"`のような文字列リテラルの型は、Cでの`char[N]`です。`N`はそのリテラルの終端null文字を含む大きさになります。しかし、文字列リテラルを構成する各文字を変更することは未定義な動作です。そこで、C++では、文字列リテラルの型は`const char[N]`と`const`修飾子によって保護するようになりました。(Cが作られた当初は、`const`修飾子そのものがなかったため、保護するという作りにしませんでした。その後の互換性から未だに`char[N]`のままです。)
|
|
65
|
+
|
|
66
|
+
賢明な読者の方々であれば、`const`あり型の値を`const`なし型の値に代入することはキャストをしないとできないことはご存じかと思います。つまり、C++では`const char[N]`を`char *`に代入することはできないと言うことです。しかし、Cとの互換性のためにC++03までは特別に文字列リテラルから`char *`へ代入することは許容されていました。C++11になって、そのような例外を認めず、明示的にキャストしない限り認めないとなったのです。
|
|
67
|
+
|
|
68
|
+
このことが複雑な事情を産みました。C++03までしか対応していない古いコンパイラであれば問題ありませんが、C++11に対応したコンパイラの場合、仕様を厳密に適用するのか、警告で済ますのか、仕様を無視するのかの選択が生まれ、コンパイルオプションによって選択できるようにしました。そのため、コンパイラの種類、バージョン、および、コンパイルオプションによって、コンパイルができたりできなかったり、警告やエラーが出る出ないも変わってくると言うことです。
|
|
69
|
+
|
|
70
|
+
なお、`char s[] = "abc";`と書く場合はC++11以上でも問題ありません。なぜなら、この場合は文字列リテラル部分は配列の初期化子として扱われ、`char s[] = {'a', 'b', 'c', '\0'};`相当の動作になるからです。これも、C/C++をご存じであれば、知っていて当たり前のことですね。
|
|
71
|
+
|
|
72
|
+
このようにCとC++は似ているようで、結構な違いあります。自分が書いているコードがCなのか、C++なのか、また、Cとしてコンパイルしているのか、C++としてコンパイルしているのかを正しく区別できないと、C/C++を扱うのは難しいです。特に、Visual StudioのC++コンパイラは、拡張子によってCなのかC++なのか扱いが変わるという動作がデフォルトになっており、さらに混乱することになるでしょう。
|
1
より正確な表現に変更
answer
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
|
|
5
5
|
> strtokが必要だとわかりました。
|
|
6
6
|
|
|
7
|
-
**MeCabを使
|
|
7
|
+
**MeCabを使って形態素を取り出すのに`strtok`は必要ありません。**MeCab内で各ノードはすでに分割されており、それぞれのノードへアクセスするためのAPI(ライブラリの関数)があります。`strtok`等で再度結果を分割する必要はありません。もし、そのようなことが必要な場合は、正しいAPIを使用していない事になります。
|
|
8
8
|
|
|
9
9
|
参考: [MeCab ライブラリ](https://taku910.github.io/mecab/libmecab.html)
|
|
10
10
|
|