狠狠撸

狠狠撸Share a Scribd company logo
Webエンジニアの視点
~開発現場からの視点で~
株式会社ツインスパーク/日本Rubyの会
高桥征义
自己绍介
高桥征义
所属
株式会社
ツインスパーク
仕事
Webアプリ
ケーション
開発
别の肩书
日本Ruby
の会 会長
日本Ruby
の会
目的
Ruby利用者
の支援
Ruby開発者
の支援
活动内容
日本Ruby
会議の開催
Rubyist
Magazine
の発行
各種イベント
への参加
地域Ruby
会議の後援
本日の
お題
Web
エンジニア
の視点
開発現場
からの視点で
研究開発
ではなく
事業戦略
でもなく
技術とビジネス
のベタな話
思い
ついた話
とある宴会
での議論
デザイナーと
プログラマ
プログラマは
HTMLを
書くべきか
意見が
対立
話が噛み
合ない
業務システムと
コミュニティ
サイト
違う
ビジネス
異なる
前提
残念な
すれ違い
本日の
内容
3つ
第1部
4つの
世界
Web開発にも
いろいろある
ジョエルの
パクリ
第2部
Web開発
の変遷
技術の
変わり方
言語を
中心に
第3部
未来の话
どうなる
どうする
正直よく
分からない
話半分程度に
聞いていた
だければ
よろしく
お願いします
第1部
4つの世界
5つの世界
ジョエル?オン
?ソフトウェア
奥别产デベロッパの祭典@东京:奥别产エンジニアの视点
ソフトウェアに
関するエッセイ
5つの世界
Webでも
公開
奥别产デベロッパの祭典@东京:奥别产エンジニアの视点
ソフトウェア
の世界を5つ
に分けて説明
?パッケージ
?インターナル
?组み込み
?ゲーム
?使い捨て
1つ目
パッケージ
箱売り
ダウンロード
販売
オープン
ソース
2つ目
インターナル
業務
システム
一つの会社,
一つの状況
で使われる
ユーザビリティ
優先度は
高くない
開発速度
は重要
3つ目
组み込み
ハードと
セット
アップデート
できない
品質要求
が高い
速度重要
プロセッサ
の遅さを
カバー
4つ目
ゲーム
当たれば
でかい
ほとんど
当たらない
どこで儲けて
どこで損するか
どこまで損して
大丈夫か
ポートフォリオ
が重要(らしい)
5つ目
使い捨て
ちょっとした
コード
仕事中に
よく書く奴
一回だけ
使用
二度と
使わない
スクリプト
が典型
違う世界
での事例
当てはま
らない
自分は
どの世界に
いるのか
情報収集時
は要注意
Web
の世界
異なる世界
に分かれる
4つの世界
2×2の
マトリクス
業務
システム
メディア
自社
開発
A B
受託
開発
C D
2つの
対立軸
業務システム
vsメディア
自社惫蝉受託
私はメディア
で受託が中心
業務システム
vsメディア
業務
システム
業務に使わ
れるもの
インターナル
に近い
ユーザ層
は限定
メディア
コンシューマ
向けサイト
ITというより
メディア産業
の一種かも
コーポレート
サイト
コミュニティ
サイト
ポータル
サイト
セールス
プロモーション
サイト
この2つは
性格が異なる
受託の场合
顧客の
違い
業務システム
の顧客
情報システム
部門
予算は
大きめ
メディア
の顧客
企画宣伝
部門
予算は
少なめ
直接収益化は
困難?無理
機能の
違い
業務システム
の機能
差別化の
根幹
絶対に譲れ
ないものも
メディアの
場合
機能は
なくても可
差別化の
ポイント
早さ
リリース
時期
広い意味の
ユーザ体験
伝達する
情報とセット
素朴でも
構わない
静的でも
構わない
速度と
コスト
ここでの
ポイント
私たちは何を
売っているのか
何が売り
なのか
見失い
がち
技術の
変化
メディアに
業務システム
の速度感
業務システムに
メディアの
コスト感
混乱
もう一つ
の軸
自社か
受託か
主な违い
要件管理
自社でなければ
細かく管理
できない
Webは
更新が重要
受託の
難しさ
自社開発
の困難
正直
詳しくない
人材を常に
抱えておく
のが難しそう
運用時と
開発時
常に开発
コスト的に
見合うように
する必要
業務
システム
メディア
自社
開発
A B
受託
開発
C D
まとめ
自分の位置を
把握する
第2部
Web開発
の変遷
3つの
時代区分
~2000年顷
Webの
黎明期
CGIの
全盛期
C/Perl/
VB(ASP)
既存言語+
便利な関数
回線も
貧弱
ブラウザ
も貧弱
牧歌的な
時代
2001年~
2005年頃
Webアプリ
の特性への
理解が進む
Java
(Struts)と
PHPの登場
サーバサイド
の特徴を
踏まえた開発
開発の
パターンが
見えてきた
Webアプリ
ケーション
フレームワーク
作業の省力化
?効率化が
進む
主に
業務システム
寄りの動き
もう一つ
の流れ
PHP
言語自体が
薄いWeb
アプリケーション
フレームワーク
便利な関数が
てんこもり
HTMLに言語
を埋め込み
手軽さに
軸足を置く
メディア側
で歓迎
2006年以降
Ruby on
Rails
必要最低限の
ことのみ
記述
フレームワーク
の徹底化
書かなくても
良い部分は
一切書かない
汎用言語の
枠内で実現
Java的な
流れとPHP的
な流れの融合
業務系的な
流れとメディア
的な流れの融合
プログラミング
言語の中でだけ
考えるのは不十分
プログラミング
言語について
掘り下げ
もう一つの
言語
設定
ファイル
プログラミング
言語の
2つの視点
書きたいことが何でも書ける
書きたいことが簡単に書ける
相反しがち
自由度
書きたいことが
何でも書ける
难易度
書きたいことが
簡単に書ける
何でも書ける
言語の極北
アセンブラ
C/C++
ポータビリティ
等の問題
正直、そこまで
何でも書きたい
わけじゃない
書けないことも
ある言語で十分
簡単に書ける
言語の極北
設定
ファイル
CSV
ini
XML
独自記法
プログラマ
ではない人でも
書ける
決められた事
しか書けない
特にロジックを
書くのが困難
■ プログラミング言語/設定ファイル
設定ファイル プログラミング
言語
自由度?高
难易度?高
自由度?低
难易度?低
中間が
欲しい
DSL
Domain
Speci?c
Language
ドメイン
特化言語
一種の
簡易言語
ほどほどの
記述力
ほどほどの
書きやすさ
言語内
DSL
独自言語の
ように見える
汎用言語
Ruby on
Railsで駆使
class Person < AR:Base
has_many :groups
belongs_to :company
validates_presence_of :name
end
■ プログラミング言語/設定ファイル/DSL
設定ファイル プログラミング
言語
DSL
自由度?高
难易度?高
自由度?低
难易度?低
他フレーム
ワークにも
多大な影響
ご清聴
ありがとう
ございました

More Related Content

奥别产デベロッパの祭典@东京:奥别产エンジニアの视点