いくつかのmakeファイルやエミュレータなどを実行した後、ソースコードファイル(* .cc)はまだ同じファイルであるにもかかわらず、「壊れたリンク」として読み込まれます。 (*.cc)ファイルは私のgitリポジトリから来ており、そことは別のコンピュータでは(*.cc)ファイルがソースコードファイルとして正しく読み取られているので、これは正しいファイルであることを知っています。また、gitコマンドを使用してgit status
ファイルが変更されていないことを確認することもできます。もしそうなら、唯一の結論は、Linuxファイルシステムのプロパティが破損しているということです。
これらのエラーを修正する方法は?
以下は、ファイルから実行するいくつかのコマンドです。
$chmod 777 producer_consumer.cc
chmod: cannot operate on dangling symlink ‘producer_consumer.cc’
$lsattr producer_consumer.cc
lsattr: Operation not supported While reading flags on producer_consumer.cc
$readlink producer_consumer.cc
// EPOS Synchronizer Abstraction Test Program
#include <utility/ostream.h>
#include <thread.h>
#include <semaphore.h>
#include <alarm.h>
using namespace EPOS;
const int iterations = 100;
OStream cout;
const int BUF_SIZE = 16;
char buffer[BUF_SIZE];
Semaphore empty(BUF_SIZE);
Semaphore full(0);
int consumer()
{
int out = 0;
for(int i = 0; i < iterations; i++) {
full.p();
cout << "C<-" << buffer[out] << "\t";
out = (out + 1) % BUF_SIZE;
Alarm::delay(5000);
empty.v();
}
return 0;
}
int main()
{
Thread * cons = new Thread(&consumer);
// producer
int in = 0;
for(int i = 0; i < iterations; i++) {
empty.p();
Alarm::delay(5000);
buffer[in] = 'a' + in;
cout << "P->" << buffer[in] << "\t";
in = (in + 1) % BUF_SIZE;
full.v();
}
cons->join();
cout << "The end!" << endl;
delete cons;
return 0;
}
私のLinuxは次のとおりです
Linux Mint 17.3 XCFE - 3.19.0-32-generic #37~14.04.1-Ubuntu SMP Thu Oct 22 09:37:25 UTC 2015 i686 i686 i686 GNU/Linux
以下は、ノーチラスファイルマネージャのファイルプロパティのイメージです。
編集する
I have no idea how you ended up with this.
ただ前回のようにどうするか調べて、直してからまたやりました。私はGUI gitツールであるSmartgitを使用していますが、ファイルシステムからファイルを削除するたびにSmartgitインターフェイスに移動し、クリックしてステータスをリセット(つまり元に戻す)するたびに、次のようなクレイジーファイルリンクが表示されます。しかし、奇妙なことは、git status
コンソールで表示してもファイルが変更されず、リモートのgitリポジトリにあるファイルとまったく同じです。
また、コマンドラインを介して次のことを行う場合、Smartgitに固有のものではありません。
git checkout HEAD -- philosophers_dinner.cc
ファイルを削除すると、クレイジーリンクのように生き返ります。これで、次の2つのコマンドで一日中Linuxを使用できます。
# firstly we delete the file
rm philosophers_dinner.cc
# this command will break the file
git checkout HEAD -- philosophers_dinner.cc
# these command will fix the break file by git reset
readlink philosophers_dinner.cc > philosophers_dinner.cc.new
mv philosophers_dinner.cc{.new,}
最初は古いGitかもしれないと思いました(1.9.3を使っています)。その後、2.9.3にアップデートし、まだこれを行います。私のLinuxが古すぎるため、18.0ではなくMint 17.3かもしれませんが、インストールしたとき、ほとんどの作業は17.3のように動作しませんでした。
ベストアンサー1
最も興味深い!
あなたのproducer_consumer.cc
ファイルはシンボリックリンクです。しかし、これは古いシンボリックリンクではありません。これは完全に狂った目標への象徴的なリンクです。これは、リンク先がC ++プログラムの完全なソースコードである非常に長いファイル名であるためです。もちろん、このシンボリックリンクはぶら下がっているシンボリックリンクです。ノーチラスで見られる動作は、head
これらのシンボリックリンクで予想されるものとまったく同じです。
お客様は、いかなる形でも「腐敗」が存在するという結論を立証する証拠を提供していません。奇妙ですが、これは完全に許可されているシンボリックリンクです。さまざまな一般的なツールを使用してこれらのシンボリックリンクを作成する方法はいくつかあります。たとえば、以下はシェル置換を使用した初心者の練習です。
あなたがどのようにこの奇妙な混乱に陥ったのかはあなただけが知っているだけで、私たちには公開しませんでした。それを削除する方法は非常に簡単です。以下は2つのコマンドです。そのうちの1つは主に実行されました。
linkProducer_consumer.cc> Producer_consumer.cc.newを読む mv Producer_consumer.cc{.new,}
同様に、今後どのように再び問題が発生しないようにする方法は、単に漠然と「ああ、私が何かをした」ではなく、World Zeroの具体的な情報を提供したので、自分だけが知ることができます。それはおそらく、ある時点で何かをするためにmakefileを実行したかもしれません。このシンボリックリンクの存在に影響を与えることも、そうでない場合もあります。
したがって、これら2つのコマンドを再実行できます。